本文利用C# 调用Windows自带的Windows Media Player 打造一款属于自己的音乐播放器,以供学习分享使用,如有不足之处,还请指正。
概述
Windows Media Player是微软公司出品的一款免费的播放器,属于Microsoft Windows的一个组件,通常简称"WMP",支持通过插件增强功能。版本Windows Media Player 12 随 Windows 7及以上提供。可以播放MP3,WMA,WAV等音频文件。本文音乐播放器,主要是MP3文件。
涉及知识点
- 加载COM组件Windows Media Player控件到Winform窗体中。
- AxWindowsMediaPlayer控件的常见用法
- BackgroundWorker 在单独的线程上执行操作。异步操作界面上的内容。
- IrisSkin 皮肤控件,主要利用SkinEngine来美化界面,达到风格统一的效果。
设计思路
- 通过AxWindowsMediaPlayer实现音乐的播放。
- 通过PictureBox实现歌曲背景图的显示。
- 通过BackgroundWorker 实现背景图的切换更新,以及歌词的实时显示。
- 通过Label显示歌词,以及播放时间。
- 通过DataGridView实现歌曲列表。
- 通过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:23”
13 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:24”
25 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的属性方法,也可以参考豆丁文档。
源码下载链接