之前做好了CMusicListItemUI控件,昨天晚上经过修改后现在已经把一些bug修复,可以正常工作了。所以开始开发播放列表CMusicListUI控件。
但是今天早上经过我分析后,发现我目前继承自CListUI的CMusicListUI控件,我虽然给他添加了可以设置分组的功能,并且能正常工作,但是再和酷狗的播放列表比起来发现缺点就比较多了,下面我先对比一下酷狗和我做的CMusicListUI控件。
/////////////////////////////////////////////////////////////对比开始//////////////////////////////////////////////////////////////////
酷狗:
1、可以明显看到,酷狗的分组与其中的列表项的外观和功能有较大差别,分组项的左边距偏移为0,而旗下的所有列表项都相对于分组有大约10像素的偏移
2、 分组的右键菜单与列表项的右击菜单明显不一样,如下
3、 分组项目的显示内容与列表项的显示内容差别很大,这个很容易看出来,而我已经把列表项控件(也就是CMusicListItemUI控件)特殊化做成固定的外观了。
/////////////////////////////////////////////////////////////对比结束//////////////////////////////////////////////////////////////////
分析过后,不管从功能作用,还是从外观上,都有充分理由再做一个分组控件来专门管理分组,而我先前做得CMusicListUI控件也从功能上满足不了播放列表控件的功能。
所以我需要对整个播放列表控件 CMusicListUI和列表项控件CMusicListItemUI的代码进行重新的构架编写。从duilib库的先有的类来看,其实CTreeViewUI控件和CTreeNodeUI控件于我的要求最相近,而且他已经完成了许多代码,所以我打算让CMusicListUI控件继承CTreeViewUI,让CMusicListItemUI控件继承CTreeNodeUI控件,另外针对分组再做一个控件。把代码重构完成后,整个播放列表控件的60%功能应该就实现了,剩下的40%的细节和菜单处理的功能留给以后再做。
重构的任务估计1天到2天可以完成,继续更新中~~
到今天中午,在休整代码后,做出个分组的样例,但这只是固定分组功能,是提前写好在xml文件中的,还没有加入动态增加分组的功能。