博客
关于我
音乐播放器---歌词显示逻辑篇
阅读量:126 次
发布时间:2019-02-26

本文共 2438 字,大约阅读时间需要 8 分钟。

  1. 打开对话框,选中歌曲,将歌曲名添加到listBox框中

 

2.通过切割歌曲的路径,可以找到相同路径下歌词的文件(.lrc)

以下代码是1和2的整体代码

private void btnOpen_Click(object sender, EventArgs e)    //打开按钮的功能        {            //通过这个类我们打开文件            OpenFileDialog ofd = new OpenFileDialog();            //可以多选            ofd.Multiselect = true;            //设置选择什么样的文件            ofd.Title = "请选择音乐文件";            //设置初始的目录            ofd.InitialDirectory = @"C:\Users\李晨璐\Music";            //设置显示文件的类型            ofd.Filter = "(*.mp3)|*.mp3";            //如果点了对话框的确定按钮            if(ofd.ShowDialog()==System.Windows.Forms.DialogResult.OK)            {                //获取选中的所有的歌曲的路径                string[] fileNames = ofd.FileNames;                for(int i=0;i

  3. 将歌词文件中的内容进行切割成以下的格式

 

private List
FormatLrc() //切割歌词,歌词排序 { //定义一个集合用来存处理好的歌词 List
list = new List
(); //遍历存未切割好的歌词 for (int i = 0; i < listSongLrc.Count; i++) { //把每一句歌词都要切割 string[] lrc =listSongLrc[i].Split(new char[] { '[',']' }, StringSplitOptions.RemoveEmptyEntries); //判断切割好的内容的长度是否大于1看看这个时间后面是否有歌词 if(lrc.Length>1) { //如果大于1证明有时间也有歌词 for (int j = 0; j < lrc.Length-1; j++) { //把歌词和时间全部存到这个集合中去,不排除有好几段时间,分割好了, list.Add(lrc[j] + "|" + lrc[lrc.Length - 1]); } } }

4.根据“|”左边的时间和当前音乐播放时间判断,可以算出一句歌词需要在哪个时间段播放,在显示出相应的歌词,就可以了(“|”右边)

private void timer1_Tick(object sender, EventArgs e)    //音乐播放时间,名称,显示歌词        {            //判断歌名是否为空            if (axWindowsMediaPlayer1.currentMedia != null)            {                //显示音乐播放时间                labTime.Text = axWindowsMediaPlayer1.Ctlcontrols.currentPositionString;                //显示音乐播放名称                labMusicName.Text = axWindowsMediaPlayer1.currentMedia.name;                //显示歌词                //上一句歌词播放时间 当前歌曲播放时间  下一句歌词播放的时间                //(有歌词)                if (listSongLrc.Count>0&&axWindowsMediaPlayer1.currentMedia!=null)                {                    //获得当前歌曲播放的时间                    string time = axWindowsMediaPlayer1.Ctlcontrols.currentPositionString;                    //遍历歌词                    for (int i = 0; i < listSongLrc.Count-1; i++)                    {                        //上一句歌词播放时间

以上就是基本的逻辑和代码展示

转载地址:http://hhtf.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>