From a09b0a281e9038cb137a40aec37c868654704dec Mon Sep 17 00:00:00 2001 From: 陈嘉乐 <cjl@hdlchina.com.cn> Date: 星期二, 09 六月 2020 17:33:35 +0800 Subject: [PATCH] 2020-06-09-3 --- HDL_ON/UI/Music/A31PlayMusicPage.cs | 182 +++++++++++++++++++++++++++++++++------------ 1 files changed, 134 insertions(+), 48 deletions(-) diff --git a/HDL_ON/UI/Music/A31PlayMusicPage.cs b/HDL_ON/UI/Music/A31PlayMusicPage.cs index b6ef8f9..4c7c132 100644 --- a/HDL_ON/UI/Music/A31PlayMusicPage.cs +++ b/HDL_ON/UI/Music/A31PlayMusicPage.cs @@ -14,14 +14,41 @@ public override void RemoveFromParent() { base.RemoveFromParent(); - timerThread?.Abort(); Volume.VolumeChange = null; + if (timerThread != null) + { + try + { + if (timerThread.IsAlive) + { + timerThread.Abort(); + } + } + catch { } + } + if (VolumeThread != null) + { + try + { + if (VolumeThread.IsAlive) + { + VolumeThread.Abort(); + } + } + catch { } + } + } View.PlayView playView = new View.PlayView(); + + int startVolume = 0;//涔嬪墠鐨勯煶閲� + int endVolume = 0;//鐜板湪鐨勯煶閲� public void Show() { ///1绉掑畾鏃舵洿鏂扮姸鎬� timerUpdateStatus(); + ///0.5绉掔洃鍚煶閲忕姸鎬� + VolumeUpdateSend(); #region ---鐣岄潰甯冨眬--- this.BackgroundColor = Color.ViewColor; var topView = new TopView(); @@ -51,6 +78,35 @@ playView.viewFrameLayout(middLayout); #endregion + + ///鍒囨崲鎾斁妯″紡鐐瑰嚮浜嬩欢; + playView.playOrderBtn.MouseUpEventHandler += (sender, e) => + { + string msg = Language.StringByID(StringId.switchTo); + switch (A31MusicModel.Current.A31PlayStatus.loop) + { + //0鍒楄〃寰幆锛�1鍗曟洸寰幆锛�2闅忔満鎾斁; + case "0": + A31MusicModel.Current.A31PlayStatus.loop = "1"; + playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/single.png"; + msg += Language.StringByID(StringId.singleMode); + break; + + case "1": + A31MusicModel.Current.A31PlayStatus.loop = "2"; + playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/random.png"; + msg += Language.StringByID(StringId.randomMode); + break; + case "2": + A31MusicModel.Current.A31PlayStatus.loop = "0"; + playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/list.png"; + msg += Language.StringByID(StringId.listMode); + break; + } + new PublicAssmebly().TipMsgAutoClose(msg, false,1000); + string url = "http://" + A31MusicModel.Current.IPAddress + "/httpapi.asp?command=setPlayerCmd:" + "loopmode:" + A31MusicModel.Current.A31PlayStatus.loop; + SendMethod.SendCommand(url); + }; ///娣诲姞鍠滅埍鐐瑰嚮浜嬩欢; playView.loveBtn.MouseUpEventHandler += (sender, e) => { @@ -104,40 +160,7 @@ } A31MusicModel.Save(); - - ////淇濆瓨 - //string saveRoomUIName = "A31_" + A31MusicModel.Current.IPAddress; - //Shared.IO.FileUtils.WriteFileByBytes(saveRoomUIName, - //Shared.SimpleControl.CommonPage.MyEncodingUTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(A31MusicModel.Current))); }; - ///鍒囨崲鎾斁妯″紡鐐瑰嚮浜嬩欢; - playView.playOrderBtn.MouseUpEventHandler += (sender, e) => - { - string msg = Language.StringByID(StringId.switchTo); - switch (A31MusicModel.Current.A31PlayStatus.loop) - { - //0鍒楄〃寰幆锛�1鍗曟洸寰幆锛�2闅忔満鎾斁; - case "0": - A31MusicModel.Current.A31PlayStatus.loop = "1"; - playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/single.png"; - msg += Language.StringByID(StringId.singleMode); - break; - - case "1": - A31MusicModel.Current.A31PlayStatus.loop = "2"; - playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/random.png"; - msg += Language.StringByID(StringId.randomMode); - break; - case "2": - A31MusicModel.Current.A31PlayStatus.loop = "0"; - playView.playOrderBtn.UnSelectedImagePath = "MusicIcon/list.png"; - msg += Language.StringByID(StringId.listMode); - break; - } - new PublicAssmebly().TipMsgAutoClose(msg, false); - string url = "http://" + A31MusicModel.Current.IPAddress + "/httpapi.asp?command=setPlayerCmd:" + "loopmode:" + A31MusicModel.Current.A31PlayStatus.loop; - SendMethod.SendCommand(url); - }; ///鎴戠殑鍒楄〃鐐瑰嚮浜嬩欢 playView.playlistBtn.MouseUpEventHandler += (sender, e) => { @@ -234,11 +257,20 @@ ///绉婚櫎鐣岄潰 EventHandler<MouseEventArgs> removeFromParentView = (sen, e1) => { - if (updateSelectedMusicThread != null && updateSelectedMusicThread.IsAlive) + + if (updateSelectedMusicThread != null) { - updateSelectedMusicThread.Abort(); - ///鍏抽棴绾跨▼ + try + { + if (updateSelectedMusicThread.IsAlive) + { + updateSelectedMusicThread.Abort(); + ///鍏抽棴绾跨▼ + } + } + catch { } } + popFra.RemoveFromParent(); }; backIextBtn.MouseUpEventHandler += removeFromParentView; @@ -313,12 +345,32 @@ }); }; + ///闊抽噺鍥炬爣鐐瑰嚮浜嬩欢 + playView.volIconBtn.MouseUpEventHandler += (sender, e) => + { + if (A31MusicModel.Current.ServerClientType == 1 && A31MusicModel.Current.Slave.slave_list.Count != 0) + { ///涓绘挱鏀惧櫒 + //new View.DialogView { }.PlayerVolumeView(A31MusicModel.Current); + + var volumeView = new View.DialogView { }; + volumeView.PlayerVolumeView(A31MusicModel.Current); + volumeView.UpdateVolume(); + + } + }; ///闊抽噺杩涘害鏉$偣鍑讳簨浠� + //int startVolume =0;//涔嬪墠鐨勯煶閲� + //int endVolume = 0; EventHandler<int> progressClick = (sender, e) => { playView.volValueBtn.Text = playView.volSeekBar.Progress + "%"; - SendMethod.ControlVolume(playView.volSeekBar.Progress, A31MusicModel.Current); - A31MusicModel.Current.A31PlayStatus.vol = playView.volSeekBar.Progress.ToString(); + endVolume = e; + //if (startVolume != e) + //{ + // startVolume = e; + // SendMethod.ControlVolume(e, A31MusicModel.Current); + // A31MusicModel.Current.A31PlayStatus.vol = e.ToString(); + //} }; playView.volSeekBar.OnProgressChangedEvent += progressClick; playView.volSeekBar.OnStopTrackingTouchEvent += progressClick; @@ -331,7 +383,7 @@ playView.prevBtn.MouseUpEventHandler += (sender, e) => { playView.prevBtn.IsSelected = false; - }; + }; ///鏆傚仠/鎾斁鐐瑰嚮浜嬩欢 playView.playBtn.MouseDownEventHandler += (sender, e) => { @@ -366,10 +418,38 @@ return; } playView.volSeekBar.Progress = volume; - SendMethod.ControlVolume(playView.volSeekBar.Progress, A31MusicModel.Current); - A31MusicModel.Current.A31PlayStatus.vol = playView.volSeekBar.Progress.ToString(); + + if (startVolume != volume) + { + startVolume = volume; + SendMethod.ControlVolume(volume, A31MusicModel.Current); + A31MusicModel.Current.A31PlayStatus.vol = volume.ToString(); + } + }; + } + System.Threading.Thread VolumeThread; + /// <summary> + /// 闊抽噺鍙戦�� + /// </summary> + void VolumeUpdateSend() + { + VolumeThread = new System.Threading.Thread((obj) => + { + while (true) + { + if (startVolume != endVolume) + { + startVolume = endVolume; + SendMethod.ControlVolume(endVolume, A31MusicModel.Current); + A31MusicModel.Current.A31PlayStatus.vol = endVolume.ToString(); + } + System.Threading.Thread.Sleep(300); + } + }) + { IsBackground = true }; + VolumeThread.Start(); } System.Threading.Thread timerThread; /// <summary> @@ -472,9 +552,8 @@ //鏇存柊鎾斁鍣ㄩ煶閲忕粰绯荤粺闊抽噺 Volume.MusicVolume = playView.volSeekBar.Progress; //褰撳墠鎾斁闊充箰鏃堕棿 - int playSecond = int.Parse(A31MusicModel.Current.A31PlayStatus.curpos) / 1000;// + (int)(DateTime.Now - A31MusicModel.Current.LastDateTime).TotalSeconds; - //currentMusiceA31.musicPalyTime = (playSecond*10).ToString(); - //鍒嗛挓 + int playSecond = int.Parse(A31MusicModel.Current.A31PlayStatus.curpos) / 1000 + (int)(DateTime.Now - A31MusicModel.Current.LastDateTime).TotalSeconds; + int playMusicMinute = playSecond / 60; //绉掗挓 int playMusicSecond = playSecond % 60; @@ -764,10 +843,17 @@ ///鐐瑰嚮鎾斁浜嬩欢 clickBtn.MouseUpEventHandler += (sender, e) => { - if (updateSelectedMusicThread != null && updateSelectedMusicThread.IsAlive) + if (updateSelectedMusicThread != null) { - updateSelectedMusicThread.Abort(); - ///鍏抽棴绾跨▼ + try + { + if (updateSelectedMusicThread.IsAlive) + { + updateSelectedMusicThread.Abort(); + ///鍏抽棴绾跨▼ + } + } + catch { } } System.Threading.Tasks.Task.Run(() => { -- Gitblit v1.8.0