mirror of
https://github.com/TriM-Organization/Musicreater.git
synced 2026-04-17 14:22:42 +00:00
1.9 KiB
1.9 KiB
任务清单
待办事项
-
乐曲文件格式设计 目前想到的是:
- 使用
.MCT作为项目文件的后缀,然后考虑一下格式是否和之前的 MusicSequence 兼容,如果兼容的话可以照旧用.MSQ,如不的话,可以试试想一个新的后缀名作为数据文件后缀 - 要求数据文件支持完全流式读入
- 使用
-
音轨静音处理 当前没有处理
-
优化音轨的存储方式 当前是用列表,且每一次变动元素都要重新排序,这样消耗太大了,需要优化,改用最小堆形式(heapq)
-
移植 v2 功能到内置插件 目前 v2 的功能有很多,都要移植到 v3。
- 导入 Midi 文件到全曲
- 导入 Midi 文件到指定轨道
- 导出到延迟播放器的结构文件(MCSTRUCTURE、BDX)
- 导出到延迟播放器的附加包
- 导出到积分板播放器的以上两种形式
- 导出到中继器播放器的以上两种形式
- 在 WebSocket 播放器中播放
- 导出到支持神羽资源包的以上 7 种形式
- 对于 Midi 歌词的实验性功能
- 对于 Java 版本适配的实验性功能
- 对于听感优化的实验性功能(插值、偏移)
-
测试参数曲线的功能
-
支持导出音符盒构成的音乐
-
支持导出成 schematic 结构
讨论
-
是否应该在插件注册表 PluginRegistry 中采用
Dict[插件名, 插件对象]的形式存储插件? 当前不采用这种方式是认为可以兼容一些极端场景下用户将一堆同名插件放在一起的情况。但是就算是插件放在一起,我们也可以有选择地读入注册表,比如依照版本号只读取最高版本的插件,并不需要全部存储在插件注册表中。所以其实用字典来存储是有利的?吗? -
服务插件到底该怎么写?总不能留着一个 PluginType.SERVICE 的插件一直空在那里吧……