本来在做项目,看到酷我音乐盒的歌词显示挺有趣的,模仿做了一个不完整的。
(只有滚动显示,没有节奏显示)。
原理:
(1)定义一个派生自CStatic类的CKaraokeLyricCtrl类(歌词控件),自绘制风格
;
(2)准备一个背景位图(保存在CKaraokeLyricCtrl::m_dcBK中);
(3)设置两个计数器(ID分别为1和2),启动自绘制,1用来显示节奏(未实现,只
有框架),2用来滚动歌词;
(4)自绘制函数中,将绘制的滚动歌词和背景位图混合,然后输出到屏幕上。滚动
歌词的绘制使用GDI+的Graphics::DrawString函数,歌词文本的大小、位置、字体和
透明度均自动计算和变化,模仿酷我音乐盒的形式。
以上功能均封闭实现在CKaraokeLyricCtrl类中。该类可以直接使用(见下边的使用步骤)。
使用步骤:
(1)CKaraokeLyric::InitInstance中启动GDI+;
(2)在CKaraokeLyricView::OnInitialUpdate中,创建歌词控件
(CKaraokeLyricCtrl类),其大小和CKaraokeLyricView视图相同,即覆盖了后者;
(3)在菜单项响应中,使用CKaraokeLyricCtrl::ReadLyric读取歌词文件,再使用
CKaraokeLyricCtrl::Start即可启动歌词的滚动显示
未实现部分:(歌词的节拍显示)
虽然没有实现,但思路大致是:在后台先用另外一种颜色绘制当前突出显示的歌词(即字体最大的一行歌词),根据歌曲节奏,将还未唱出部分全部涂黑,然后和屏幕上的当前行突出歌词进行混合。
|