C# 一款属于自己的音乐播放器

时间:2024-02-18 16:27:36

本文利用C# 调用Windows自带的Windows Media Player 打造一款属于自己的音乐播放器,以供学习分享使用,如有不足之处,还请指正。

概述

Windows Media Player是微软公司出品的一款免费的播放器,属于Microsoft Windows的一个组件,通常简称"WMP",支持通过插件增强功能。版本Windows Media Player 12 随 Windows 7及以上提供。可以播放MP3,WMA,WAV等音频文件。本文音乐播放器,主要是MP3文件。

涉及知识点

  1. 加载COM组件Windows Media Player控件到Winform窗体中。
  2. AxWindowsMediaPlayer控件的常见用法
  3. BackgroundWorker 在单独的线程上执行操作。异步操作界面上的内容。
  4. IrisSkin 皮肤控件,主要利用SkinEngine来美化界面,达到风格统一的效果。

设计思路

  1. 通过AxWindowsMediaPlayer实现音乐的播放。
  2. 通过PictureBox实现歌曲背景图的显示。
  3. 通过BackgroundWorker 实现背景图的切换更新,以及歌词的实时显示。
  4. 通过Label显示歌词,以及播放时间。
  5. 通过DataGridView实现歌曲列表。
  6. 通过IrisSkin来美化界面。

添加Windows Media Player组件

工具--》选择工具箱项--》COM组件--》Windows Media Player,如下图所示:

音乐播放器效果图

音乐播放器效果图如下图所示

核心代码

加载皮肤

 1   /// <summary>
 2         /// 初始化皮肤
 3         /// </summary>
 4         private void InitInfo()
 5         {
 6             this.skinEngine = new SkinEngine();
 7             this.skinEngine.SkinFile = AppDomain.CurrentDomain.BaseDirectory + @"Skins\mp10.ssk";
 8             this.skinEngine.DisableTag = 9999;
 9             ReadSkinFile();
10         }
View Code

切换背景图

 1  /// <summary>
 2         /// 背景图切换
 3         /// </summary>
 4         /// <param name="sender"></param>
 5         /// <param name="e"></param>
 6         private void BgWorker1_DoWork(object sender, DoWorkEventArgs e)
 7         {
 8             while (isRunning) {
 9                 if (bgUrls != null && bgUrls.Length > 0) {
10                     this.curIndex = (this.curIndex % bgUrls.Length);
11                     this.pbImage.Image = Image.FromStream(HttpWebRequest.Create(bgUrls[this.curIndex]).GetResponse().GetResponseStream());
12                     this.pbImage.SizeMode = PictureBoxSizeMode.StretchImage;
13                     this.curIndex++;
14                     //
15                     this.lblTime.Invoke(new Action(() =>
16                     {
17                         this.lblTime.Text = string.Format("{0}/{1}", this.axWindowsMediaPlayer1.Ctlcontrols.currentPositionString, this.axWindowsMediaPlayer1.currentMedia.durationString);
18                         //this.lblTime.ForeColor = Color.White;
19                     }));
20                     
21                 }
22                 Thread.Sleep(2000);
23             }
24         }
View Code

AxWindowsMediaPlayer相关属性方法

 1 [基本属性]   
 2 URL:String; 指定媒体位置,本机或网络地址 
 3 uiMode:String; 播放器界面模式,可为Full, Mini, None, Invisible 
 4 playState:integer; 播放状态,1=停止,2=暂停,3=播放,6=正在缓冲,9=正在连接,10=准备就绪 
 5 enableContextMenu:Boolean; 启用/禁用右键菜单 
 6 fullScreen:boolean; 是否全屏显示 
 7 //播放器基本控制 
 8 Ctlcontrols.play; 播放 
 9 Ctlcontrols.pause; 暂停 
10 Ctlcontrols.stop; 停止 
11 Ctlcontrols.currentPosition:double; 当前进度 
12 Ctlcontrols.currentPositionString:string; 当前进度,字符串格式。如“00:2313 Ctlcontrols.fastForward; 快进 
14 Ctlcontrols.fastReverse; 快退 
15 Ctlcontrols.next; 下一曲 
16 Ctlcontrols.previous; 上一曲 
17 [settings] wmp.settings //播放器基本设置 
18 settings.volume:integer; 音量,0-100 
19 settings.autoStart:Boolean; 是否自动播放 
20 settings.mute:Boolean; 是否静音 
21 settings.playCount:integer; 播放次数 
22 [currentMedia] wmp.currentMedia //当前媒体属性 
23 currentMedia.duration:double; 媒体总长度 
24 currentMedia.durationString:string; 媒体总长度,字符串格式。如“03:2425 currentMedia.getItemInfo(const string); 获取当前媒体信息"Title"=媒体标题,"Author"=艺术家,"Copyright"=版权信息,"Description"=媒体内容描述, "Duration"=持续时间(秒),"FileSize"=文件大小,"FileType"=文件类型,"sourceURL"=原始地址 
26 currentMedia.setItemInfo(const string); 通过属性名设置媒体信息 
27 currentMedia.name:string; 同 currentMedia.getItemInfo("Title") 
28 [currentPlaylist] wmp.currentPlaylist //当前播放列表属性 
29 currentPlaylist.count:integer; 当前播放列表所包含媒体数 
30 currentPlaylist.Item[integer]; 获取或设置指定项目媒体信息,其子属性同wmp.currentMedia 
31 axWindowsMediaPlayer1.currentMedia.sourceURL; //获取正在播放的媒体文件的路径
32 axWindowsMediaPlayer1.currentMedia.name;          //获取正在播放的媒体文件的名称
33 axWindowsMediaPlayer1.Ctlcontrols.Play          播放 
34 axWindowsMediaPlayer1.Ctlcontrols.Stop          停止 
35 axWindowsMediaPlayer1.Ctlcontrols.Pause          暂停 
36 axWindowsMediaPlayer1.Ctlcontrols.PlayCount        文件播放次数 
37 axWindowsMediaPlayer1.Ctlcontrols.AutoRewind       是否循环播放 
38 axWindowsMediaPlayer1.Ctlcontrols.Balance         声道 
39 axWindowsMediaPlayer1.Ctlcontrols.Volume         音量 
40 axWindowsMediaPlayer1.Ctlcontrols.Mute          静音 
41 axWindowsMediaPlayer1.Ctlcontrols.EnableContextMenu    是否允许在控件上点击鼠标右键时弹出快捷菜单 
42 axWindowsMediaPlayer1.Ctlcontrols.AnimationAtStart    是否在播放前先播放动画 
43 axWindowsMediaPlayer1.Ctlcontrols.ShowControls      是否显示控件工具栏 
44 axWindowsMediaPlayer1.Ctlcontrols.ShowAudioControls    是否显示声音控制按钮 
45 axWindowsMediaPlayer1.Ctlcontrols.ShowDisplay       是否显示数据文件的相关信息 
46 axWindowsMediaPlayer1.Ctlcontrols.ShowGotoBar       是否显示Goto栏 
47 axWindowsMediaPlayer1.Ctlcontrols.ShowPositionControls  是否显示位置调节按钮 
48 axWindowsMediaPlayer1.Ctlcontrols.ShowStatusBar      是否显示状态栏 
49 axWindowsMediaPlayer1.Ctlcontrols.ShowTracker       是否显示进度条 
50 axWindowsMediaPlayer1.Ctlcontrols.FastForward       快进 
51 axWindowsMediaPlayer1.Ctlcontrols.FastReverse       快退 
52 axWindowsMediaPlayer1.Ctlcontrols.Rate          快进/快退速率 
53 axWindowsMediaPlayer1.AllowChangeDisplaySize 是否允许*设置播放图象大小 
54 axWindowsMediaPlayer1.DisplaySize       设置播放图象大小 
55     1-MpDefaultSize         原始大小 
56     2-MpHalfSize           原始大小的一半 
57     3-MpDoubleSize          原始大小的两倍 
58     4-MpFullScreen          全屏 
59     5-MpOneSixteenthScreen      屏幕大小的1/16 
60     6-MpOneFourthScreen       屏幕大小的1/4 
61     7-MpOneHalfScreen        屏幕大小的1/2 
62 axWindowsMediaPlayer1.ClickToPlay       是否允许单击播放窗口启动Media Player
View Code

备注

关于AxWindowsMediaPlayer的属性方法,也可以参考豆丁文档。

源码下载链接