撤销了disp类,但是bug依旧没有变化。

This commit is contained in:
EillesWan 2022-04-24 17:56:57 +08:00
parent ca2e8c9155
commit f3c5044800
6 changed files with 299 additions and 312 deletions

@ -38,12 +38,12 @@ A free opensource software which is used for creating all kinds of musics in Min
# 一定会好起来的 # 一定会好起来的
from msctspt.bugReporter import version from msctLib.buildIN import version
__ver__ = f'{version.version[1]} {version.version[0]}' __ver__ = f'{version.version[1]} {version.version[0]}'
__author__ = '金羿Eilles' __author__ = '金羿Eilles'
from msctLib.display import * import msctLib.display as disp
from msctLib.function import * from msctLib.function import *
@ -91,17 +91,19 @@ def __main__():
def test2(): def test2():
print('???', end=' ') print('???', end=' ')
disp.__root = disp.tk.Tk()
window = disp( disp.initWindow(
geometry='1200x800', geometry='1200x800',
menuWidget={ menuWidget={
'文件': {'新建': test, '打开': test}, '文件': {'新建': test, '打开': test},
'编辑': {'撤销': test, '重做': test}, '编辑': {'撤销': test, '重做': test},
'视图': {'缩放': test}, '视图': {'缩放': test},
'帮助': {'关于': authorWindowStarter}, '帮助': {'关于': disp.authorWindowStarter},
}, },
title='音·创 0.2 测试中', title_='音·创 0.2 测试中',
buttons=[ button=[
{ {
'新建': ('', test2), '新建': ('', test2),
'打开': ('', test2) '打开': ('', test2)
@ -110,10 +112,10 @@ def __main__():
'测试': ('', test2) '测试': ('', test2)
} }
], ],
debug=True, Debug=True,
) )
window.start() disp.winstart()
if __name__ == '__main__': if __name__ == '__main__':

Binary file not shown.

Binary file not shown.

@ -6,7 +6,7 @@
class version: class version:
libraries = ( libraries = (
'mido', 'amulet', 'amulet-core', 'amulet-nbt', 'piano_transcription_inference', 'pypinyin', 'mido', 'amulet', 'amulet-core', 'amulet-nbt', 'piano_transcription_inference', 'pypinyin',
'pyinstaller', 'py7zr','websockets', 'torch', 'requests' 'pyinstaller', 'py7zr','websockets', 'zhdate', 'requests'
) )
"""当前所需库""" """当前所需库"""

@ -34,294 +34,323 @@ tipsColor = PURPLE
# 注UI界面字体、代码字体 # 注UI界面字体、代码字体
fontPattern = ('DengXian Light', 'Fira Code') fontPattern = ('DengXian Light', 'Fira Code')
global __root
global title
global menuWidgets
global wordView
global buttons
global settingBox
global notemap
global infoBar
global debug
class disp: __root = None
'''音·创 的基本Tk窗口显示库''' '''窗口根'''
# 音·创 的基本Tk窗口显示函数
def __init__( def initWindow(
self, Debug: bool = False,
debug: bool = False, title_: str = '音·创',
title: str = '音·创', geometry: str = '0x0',
geometry: str = '0x0', iconbitmap: tuple = ('./resources/musicreater.ico', './resources/musicreater.ico'),
iconbitmap: tuple = ('./resources/musicreater.ico', './resources/musicreater.ico'), menuWidget: dict = {},
menuWidget: dict = {}, wordview: str = '音·创 Musicreater',
wordView: str = '音·创 Musicreater', button: list = [],
buttons: list = [], settingbox: list = [],
settingBox: list = [], notemap_: list = [],
notemap: list = [], infobar: str = '就绪',
infobar: str = '就绪', ) -> None:
) -> None: '''使用参数建立基本的 音·创 窗口
'''使用参数建立基本的 音·创 窗口 :param debug 是否将日志输出到控制台
:param root 根窗口 :param title 窗口标题
:param debug 是否将日志输出到控制台 wordview: str #言论部分显示的字样
:param title 窗口标题 button: list = [ # 操作按钮部分
wordview: str #言论部分显示的字样 dict = {
button: list = [ # 操作按钮部分 按钮名称 : tuple(按钮图标,执行函数)
dict = { },
按钮名称 : tuple(按钮图标,执行函数) ],
}, settingbox: list = [ # 设置部分显示的字样及其对应的设置函数
], (
settingbox: list = [ # 设置部分显示的字样及其对应的设置函数 设置名称:str,
( 值类型:tuple,
设置名称:str, 显示内容:str,
值类型:tuple, 设置操作函数:<function>,
显示内容:str, )
设置操作函数:<function>, ],
) map: list = [ # 一首曲目的音符数据
], 音符数据
map: list = [ # 一首曲目的音符数据 ]
音符数据 :param infobar str 显示信息用
] '''
:param infobar str 显示信息用
'''
if debug: if Debug:
log('载入参数') log('载入参数')
# 载入参量 注意!图标将不被载入参数 # 载入参量 注意!图标将不被载入参数
global title
global menuWidgets
global wordView
global buttons
global settingBox
global notemap
global infoBar
global debug
self.__root = tk.Tk()
'''窗口根'''
title = title_
'''窗口标题'''
self.title = title menuWidgets = menuWidget
'''窗口标题''' '''菜单设定项'''
self.menuWidgets = menuWidget wordView = wordview
'''菜单设定项''' '''言·论 所显示的文字'''
self.wordView = wordView buttons = button
'''言·论 所显示的文字''' '''快捷功能按钮'''
self.buttons = buttons settingBox = settingbox
'''快捷功能按钮''' '''设置框'''
self.settingBox = settingBox notemap = notemap_
'''设置框''' '''音符列表'''
self.notemap = notemap infoBar = infobar
'''音符列表''' '''信息显示版所显示的文字'''
self.infoBar = infobar debug = Debug
'''信息显示版所显示的文字''' '''是否打开调试模式'''
self.debug = debug setTitle()
'''是否打开调试模式'''
self.setTitle() setGeometry(geometry)
setIcon(*iconbitmap)
self.setGeometry(geometry) setMenu()
self.setIcon(*iconbitmap)
self.setMenu() initWidget()
self.initWidget() def winstart() -> None:
# 启动主消息循环
__root.mainloop()
def start(self) -> None: # =========================================================
# 启动主消息循环 # 设定函数部分
self.__root.mainloop() # =========================================================
# ========================================================= def setTitle( title_: str = '') -> None:
# 设定函数部分 '''设置窗口标题
# ========================================================= :param title: str 窗口标题'''
global title
if title:
title = title_
__root.title(title)
if debug:
log(f"设置窗口标题 {title}")
def setTitle(self, title: str = '') -> None: def setGeometry( geometry: str = '0x0') -> None:
'''设置窗口标题 '''设置窗口大小
:param title: str 窗口标题''' :param geometry: str 窗口大小'''
__root.geometry(geometry)
if debug:
log(f"设置窗口大小{geometry}")
if title: def setIcon( bitmap: str = './musicreater.ico', default: str = '') -> bool:
self.title = title '''设置窗口图标
self.__root.title(self.title) :param bitmap: str 图标路径
if self.debug: :param default: str 设置对于全局的默认图标路径
log(f"设置窗口标题 {self.title}") 注意default参数仅在Windows下有效其意为将所有没有图标的窗口设置默认图标如果在非Windows环境使用default参数将会引发一个错误
:retuen bool 是否成功设置图标'''
def setGeometry(self, geometry: str = '0x0') -> None: try:
'''设置窗口大小 if default:
:param geometry: str 窗口大小''' __root.iconbitmap(bitmap, default)
self.__root.geometry(geometry) log(f'设置图标为{bitmap},默认为{default}')
if self.debug:
log(f"设置窗口大小{geometry}")
def setIcon(self, bitmap: str = './musicreater.ico', default: str = '') -> bool:
'''设置窗口图标
:param bitmap: str 图标路径
:param default: str 设置对于全局的默认图标路径
注意default参数仅在Windows下有效其意为将所有没有图标的窗口设置默认图标如果在非Windows环境使用default参数将会引发一个错误
:retuen bool 是否成功设置图标'''
try:
if default:
self.__root.iconbitmap(bitmap, default)
log(f'设置图标为{bitmap},默认为{default}')
else:
self.__root.iconbitmap(bitmap)
log(f'设置图标为{bitmap}')
return True
except Exception as e:
log(str(e), 'ERROR')
if self.debug:
raise e
return False
def setMenu(self) -> None:
'''设置根菜单'''
if not self.menuWidgets:
# 如果传入空参数则返回当前菜单
try:
return self._RootMenu
except Exception as E:
if self.debug:
raise E
log('无法读取菜单信息', 'WARRING')
# 如果不是空参数则新建菜单
log('新建一个菜单')
self._RootMenu = {}
self._mainMenuBar = tk.Menu(self.__root)
for menuName, menuCmd in self.menuWidgets.items():
# 取得一个菜单名和一堆菜单函数及其显示名称
menu = tk.Menu(self._mainMenuBar, tearoff=0)
for cmdName, cmdFunc in menuCmd.items():
if cmdName:
menu.add_command(label=cmdName, command=cmdFunc)
log('菜单项 -- ' + cmdName)
else:
menu.add_separator()
log('分隔符 -- 分隔符')
self._mainMenuBar.add_cascade(label=menuName, menu=menu)
self._RootMenu[menuName] = menu
log('计入一个菜单 -- ' + menuName)
self.__root.config(menu=self._mainMenuBar)
log('菜单设置完毕')
def addMenu(self, menuRoot: str = '', menuLabel: str = '', menuCommand=None):
'''增加一个菜单项
:param menuRoot : str
菜单的根菜单即所属的菜单上的文字
:param menuLabel : str
所需要增加的项目显示的文字
:param menuCommand : <function>
'''
if menuRoot in self._RootMenu.keys:
# 如果已经有父菜单
if menuLabel:
# 增加菜单指令
self._RootMenu[menuRoot].add_command(
label=menuLabel, command=menuCommand
)
else:
# 增加分隔栏
self._RootMenu[menuRoot].add_separator()
else: else:
# 没有父菜单则新增一个父菜单 __root.iconbitmap(bitmap)
menu = tk.Menu(self._mainMenuBar, tearoff=False) log(f'设置图标为{bitmap}')
if menuLabel: return True
menu.add_command(label=menuLabel, command=menuCommand) except Exception as e:
log(str(e), 'ERROR')
if debug:
raise e
return False
def setMenu() -> None:
'''设置根菜单'''
global _RootMenu
global _mainMenuBar
if not menuWidgets:
# 如果传入空参数则返回当前菜单
try:
return _RootMenu
except Exception as E:
if debug:
raise E
log('无法读取菜单信息', 'WARRING')
# 如果不是空参数则新建菜单
log('新建一个菜单')
_RootMenu = {}
_mainMenuBar = tk.Menu(__root)
for menuName, menuCmd in menuWidgets.items():
# 取得一个菜单名和一堆菜单函数及其显示名称
menu = tk.Menu(_mainMenuBar, tearoff=0)
for cmdName, cmdFunc in menuCmd.items():
if cmdName:
menu.add_command(label=cmdName, command=cmdFunc)
log('菜单项 -- ' + cmdName)
else: else:
menu.add_separator() menu.add_separator()
self._mainMenuBar.add_cascade(label=menuRoot, menu=menu) log('分隔符 -- 分隔符')
self._RootMenu[menuRoot] = menu _mainMenuBar.add_cascade(label=menuName, menu=menu)
_RootMenu[menuName] = menu
log('计入一个菜单 -- ' + menuName)
__root.config(menu=_mainMenuBar)
log('菜单设置完毕')
def initWidget( def addMenu( menuRoot: str = '', menuLabel: str = '', menuCommand=None):
self, '''增加一个菜单项
) -> None: :param menuRoot : str
'''设置窗口小部件,分为: 菜单的根菜单即所属的菜单上的文字
:· WordView :param menuLabel : str
:快捷按钮面板 ButtonBar 所需要增加的项目显示的文字
:设置框 SettingBar :param menuCommand : <function>
:音轨框 TrackBar '''
:各个音轨的显示框 TrackFrame
:信息显示版 InfoBar global _RootMenu
''' global _mainMenuBar
self._wordviewBar = tk.Label(
self.__root,
bg='black',
fg='white',
text=self.wordView,
font=(fontPattern[0], 30),
)
# 定义 言·论 版面
log('言·论版面设置完成')
self._infoBar = tk.Label( if menuRoot in _RootMenu.keys:
self.__root, # 如果已经有父菜单
bg='white', if menuLabel:
fg='black', # 增加菜单指令
text=self.infoBar, _RootMenu[menuRoot].add_command(
font=(fontPattern[0], 10), label=menuLabel, command=menuCommand
)
# 定义 信息显示版
log('信息显示版设置完成')
self._buttonBar = tk.Frame(
self.__root,
bd=2,
)
# 定义 快捷按钮面板. 注意这里是以一个Frame为容器而不是一个Button列表后面的版面也以Frame容器居多
self.setButtonBar(self.buttons)
self._wordviewBar.pack(side='top', fill='x')
self._buttonBar.pack(side='top', fill='x')
self._infoBar.pack(side='bottom', fill='x')
def setButtonBar(
self,
buttonList: list = [],
defaultMissingTexturePath: str = './resources/uimage/missing_texture.png',
separatorButtonTexturePath: str = './resources/uimage/separator_line.png',
) -> None:
'''设置快捷按钮面板
:param buttonList : list
快捷按钮列表每个元素为一个字典字典的键为按钮名称值为一个元组元组中第一项为按钮的图标第二项为按钮的回调函数
'''
# 图标应该如下
# 新建 打开 保存 |
self._buttonBarList = []
'''按钮对象列表,注意软件调用的时候千万别动!'''
separatorimg = tk.PhotoImage(file=separatorButtonTexturePath)
for buttons in buttonList:
# 循环每个按钮组
for name, args in buttons.items():
# 循环每个按钮
try:
img = tk.PhotoImage(file=args[0])
except:
log('载入图片失败,使用默认图片','WARNING')
if self.debug:
raise FileNotFoundError(f'图片{args[0]}不存在')
img = tk.PhotoImage(file=defaultMissingTexturePath)
button = tk.Button(
self._buttonBar,
text=name,
command=args[1],
image=img,
bd=2,
compound='center',
font=(fontPattern[0], 10),
)
button.pack(side='left', padx=5, pady=5)
self._buttonBarList.append(button)
# 添加按钮
tk.Label(self._buttonBar, image=separatorimg).pack(
side='left', padx=5, pady=5
) )
else:
# 增加分隔栏
_RootMenu[menuRoot].add_separator()
else:
# 没有父菜单则新增一个父菜单
menu = tk.Menu(_mainMenuBar, tearoff=False)
if menuLabel:
menu.add_command(label=menuLabel, command=menuCommand)
else:
menu.add_separator()
_mainMenuBar.add_cascade(label=menuRoot, menu=menu)
_RootMenu[menuRoot] = menu
def setWordView(self, text: str) -> None: def initWidget(
'''重新设置言·论版的文字'''
self._wordviewBar['text'] = text ) -> None:
'''设置窗口小部件,分为:
:· WordView
:快捷按钮面板 ButtonBar
:设置框 SettingBar
:音轨框 TrackBar
:各个音轨的显示框 TrackFrame
:信息显示版 InfoBar
'''
def setInfoBar(self, text: str) -> None: global _wordviewBar
'''重新设置信息显示版的文字''' global _infoBar
self._infoBar['text'] = text global _buttonBar
_wordviewBar = tk.Label(
__root,
bg='black',
fg='white',
text=wordView,
font=(fontPattern[0], 30),
)
# 定义 言·论 版面
log('言·论版面设置完成')
_infoBar = tk.Label(
__root,
bg='white',
fg='black',
text=infoBar,
font=(fontPattern[0], 10),
)
# 定义 信息显示版
log('信息显示版设置完成')
_buttonBar = tk.Frame(
__root,
bd=2,
)
# 定义 快捷按钮面板. 注意这里是以一个Frame为容器而不是一个Button列表后面的版面也以Frame容器居多
setButtonBar(buttons)
_wordviewBar.pack(side='top', fill='x')
_buttonBar.pack(side='top', fill='x')
_infoBar.pack(side='bottom', fill='x')
def setButtonBar(
buttonList: list = [],
defaultMissingTexturePath: str = './resources/uimage/missing_texture.png',
separatorButtonTexturePath: str = './resources/uimage/separator_line.png',
) -> None:
'''设置快捷按钮面板
:param buttonList : list
快捷按钮列表每个元素为一个字典字典的键为按钮名称值为一个元组元组中第一项为按钮的图标第二项为按钮的回调函数
'''
# 图标应该如下
# 新建 打开 保存 |
global _buttonBarList
_buttonBarList = []
'''按钮对象列表,注意软件调用的时候千万别动!'''
separatorimg = tk.PhotoImage(file=separatorButtonTexturePath)
for buttons in buttonList:
# 循环每个按钮组
for name, args in buttons.items():
# 循环每个按钮
try:
img = tk.PhotoImage(file=args[0])
except:
log('载入图片失败,使用默认图片','WARNING')
if debug:
raise FileNotFoundError(f'图片{args[0]}不存在')
img = tk.PhotoImage(file=defaultMissingTexturePath)
button = tk.Button(
_buttonBar,
text=name,
command=args[1],
image=img,
bd=2,
compound='center',
font=(fontPattern[0], 10),
)
button.pack(side='left', padx=5, pady=5)
_buttonBarList.append(button)
# 添加按钮
tk.Label(_buttonBar, image=separatorimg).pack(
side='left', padx=5, pady=5
)
def setWordView( text: str) -> None:
'''重新设置言·论版的文字'''
_wordviewBar['text'] = text
def setInfoBar( text: str) -> None:
'''重新设置信息显示版的文字'''
_infoBar['text'] = text
# ========================================================= # =========================================================
# 预置函数部分 # 预置函数部分
@ -345,7 +374,7 @@ def authorWindowStarter(
tk.Label(authorWindow, text=_('F音创'), font=('', 35)).pack() tk.Label(authorWindow, text=_('F音创'), font=('', 35)).pack()
tk.Label( tk.Label(
authorWindow, authorWindow,
text='{} {}'.format(version.version[1] + version.version[0]), text='{} {}'.format(version.version[1] , version.version[0]),
font=('', 15), font=('', 15),
).pack() ).pack()
# pack 的side可以赋值为LEFT RTGHT TOP BOTTOM # pack 的side可以赋值为LEFT RTGHT TOP BOTTOM
@ -397,7 +426,7 @@ def authorWindowStarter(
class ProgressBar: class ProgressBar:
def __init__( def __init__(
self,
root: tk.Tk = tk.Tk(), root: tk.Tk = tk.Tk(),
style: tuple = (DEFAULTBLUE, BLACK, WHITE), style: tuple = (DEFAULTBLUE, BLACK, WHITE),
type: bool = False, type: bool = False,
@ -415,7 +444,7 @@ class ProgressBar:
显示的附加信息 显示的附加信息
:param debug : bool :param debug : bool
是否输出日志到控制台''' 是否输出日志到控制台'''
self.root = root root = root
# TODO # TODO
@ -426,4 +455,4 @@ if __name__ == '__mian__':
import os import os
os.chdir('../') os.chdir('../')
disp.authorMenu() authorWindowStarter()

@ -90,48 +90,4 @@ class report:
os.remove("./Temps&Logs.zip") os.remove("./Temps&Logs.zip")
class version: from msctLib.buildIN import version
libraries = (
'mido', 'amulet', 'amulet-core', 'amulet-nbt', 'piano_transcription_inference', 'pypinyin',
'pyinstaller', 'py7zr','websockets', 'torch', 'requests', 'zhdate'
)
"""当前所需库"""
version = ('0.1.6', 'Delta',)
"""当前版本"""
def __init__(self) -> None:
self.libraries = version.libraries
"""当前所需库"""
self.version = version.version
"""当前版本"""
def installLibraries(self,index:str = 'https://pypi.tuna.tsinghua.edu.cn/simple'):
"""安装全部开发用库"""
from sys import platform
import os
if platform == 'win32':
import shutil
try:
shutil.rmtree(os.getenv('APPDATA') + '\\Musicreater\\')
except FileNotFoundError:
pass
for i in self.libraries:
print("安装库:" + i)
os.system(f"python -m pip install {i} -i {index}")
elif platform == 'linux':
os.system("sudo apt-get install python3-pip")
os.system("sudo apt-get install python3-tk")
os.system("sudo apt-get install python3-tkinter")
for i in self.libraries:
print("安装库:" + i)
os.system(f"sudo python3 -m pip install {i} -i {index}")
def __call__(self):
'''直接安装库,顺便返回一下当前版本'''
self.installLibraries()
return self.version