From 6fa9d69da922c8049f5acfcbb9ce9fd26811024c Mon Sep 17 00:00:00 2001 From: xm <1271024303@qq.com> Date: 星期四, 16 四月 2020 17:10:57 +0800 Subject: [PATCH] 请合并代码 --- ZigbeeApp/Shared/Phone/MainPage/Controls/DeviceCard/Base/DeviceCardCommon.cs | 426 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 426 insertions(+), 0 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/MainPage/Controls/DeviceCard/Base/DeviceCardCommon.cs b/ZigbeeApp/Shared/Phone/MainPage/Controls/DeviceCard/Base/DeviceCardCommon.cs new file mode 100755 index 0000000..e40e221 --- /dev/null +++ b/ZigbeeApp/Shared/Phone/MainPage/Controls/DeviceCard/Base/DeviceCardCommon.cs @@ -0,0 +1,426 @@ +锘縰sing System; +using System.Collections.Generic; +using System.Text; +using ZigBee.Device; +using Shared.Phone.UserCenter; + +namespace Shared.Phone.MainPage.Controls +{ + /// <summary> + /// 涓婚〉鐨勮澶囧崱鐗囨帶浠跺簳灞傚叡閫�(瀹藉害:458 + 14 * 2 楂樺害:305 + 43) + /// </summary> + public class DeviceCardCommon : FrameLayoutControl + { + #region 鈻� 鍙橀噺澹版槑___________________________ + + /// <summary> + /// 璁惧瀵硅薄 + /// </summary> + public CommonDevice device = null; + /// <summary> + /// 鍗$墖闇�瑕佽绉婚櫎鐨勪簨浠� + /// </summary> + public Action CardNeedRemoveEvent = null; + /// <summary> + /// 鑳屾櫙鍥剧墖鎺т欢 + /// </summary> + private PicViewControl btnBackGroud = null; + /// <summary> + /// 璁惧鍚嶇О鎺т欢 + /// </summary> + private NormalViewControl btnDeviceName = null; + /// <summary> + /// 璁惧鐨勮儗鏅渾鍦堝浘鎺т欢 + /// </summary> + private FrameLayout fraDeviceRound = null; + /// <summary> + /// 璁惧鍥炬爣鎺т欢 + /// </summary> + private IconViewControl btnDeviceIcon = null; + /// <summary> + /// 鐘舵�佹枃鏈帶浠� + /// </summary> + private NormalViewControl btnStatu = null; + /// <summary> + /// 寮�鍏虫帶浠� + /// </summary> + private PicViewControl btnSwitch = null; + /// <summary> + /// 鏀堕泦鎺т欢 + /// </summary> + private IconViewControl btnCollect = null; + /// <summary> + /// 鏄惁鑾峰彇缃戝叧鍙嶉鐨勭粨鏋� 0:娌℃湁鑾峰彇寰楀埌 1:宸茬粡鑾峰彇寰楀埌 + /// </summary> + private int ResponeResult = 0; + /// <summary> + /// 鍒ゆ柇鏄惁鏈夊紑鍏冲姛鑳� + /// </summary> + private bool isHadOpenSwitch = true; + + #endregion + + #region 鈻� 鍒濆鍖朹____________________________ + + /// <summary> + /// 涓婚〉鐨勮澶囧崱鐗囨帶浠跺簳灞傚叡閫�(瀹藉害:458 + 14 * 2 楂樺害:305 + 43) + /// </summary> + public DeviceCardCommon() + { + //鍥剧墖鐪熷疄瀹藉害+鍥剧墖鑷韩宸﹀彸绌虹櫧 + this.Width = HdlControlLogic.Current.GetPictrueRealSize(458 + 14 * 2); + //鍥剧墖楂樺害+闃村奖 + this.Height = HdlControlLogic.Current.GetPictrueRealSize(305 + 43); + //鍙栨秷鐐瑰嚮鐗规晥 + this.UseClickStatu = false; + } + + /// <summary> + /// 鍒濆鍖栨帶浠� + /// </summary> + /// <param name="i_device">鎸囧畾璁惧</param> + public virtual void InitControl(CommonDevice i_device) + { + this.device = i_device; + //鑳屾櫙鍥剧墖 + this.btnBackGroud = new PicViewControl(this.Width, this.Height, false); + btnBackGroud.UnSelectedImagePath = "Item/FunctionCardView.png"; + btnBackGroud.SelectedImagePath = "Item/FunctionCardViewSelected.png"; + btnBackGroud.Gravity = Gravity.CenterHorizontal; + this.AddChidren(btnBackGroud, ChidrenBindMode.BindEventOnly); + + //璁惧鍚嶇О鎺т欢 + this.btnDeviceName = new NormalViewControl(320, 63, true); + btnDeviceName.X = HdlControlLogic.Current.GetPictrueRealSize(40); + btnDeviceName.Y = HdlControlLogic.Current.GetPictrueRealSize(17); + btnDeviceName.TextSize = 16; + btnDeviceName.TextColor = UserCenterColor.Current.TextGrayColor1; + btnDeviceName.SelectedTextColor = UserCenterColor.Current.White; + btnDeviceName.Text = Common.LocalDevice.Current.GetDeviceEpointName(i_device); + this.AddChidren(btnDeviceName, ChidrenBindMode.BindEventOnly); + + //鏀堕泦鎺т欢 + this.btnCollect = new IconViewControl(107); + btnCollect.X = HdlControlLogic.Current.GetPictrueRealSize(350); + btnCollect.Y = HdlControlLogic.Current.GetPictrueRealSize(12); + btnCollect.UnSelectedImagePath = "Item/Collection1.png"; + btnCollect.SelectedImagePath = "Item/CollectionSelected1.png"; + this.AddChidren(btnCollect, ChidrenBindMode.NotBind); + btnCollect.IsSelected = HdlRoomLogic.Current.IsCollectInRoom(i_device); + btnCollect.ButtonClickEvent += (sender, e) => + { + //鐘舵�佸彇鍙� + btnCollect.IsSelected = !btnCollect.IsSelected; + if (btnCollect.IsSelected == false) + { + //鍙栨秷鏀惰棌 + HdlRoomLogic.Current.DeleteLoveDevice(i_device); + if (HdlRoomLogic.Current.CurrentRoom.IsLove == true) + { + //濡傛灉褰撳墠鎴块棿鏄垜鐨勫枩鐖辩殑璇�,鍥炶皟鍗$墖琚垹闄ょ殑浜嬩欢 + this.CardNeedRemoveEvent?.Invoke(); + } + } + else + { + //娣诲姞鏀惰棌 + HdlRoomLogic.Current.AddLoveDevice(i_device); + } + }; + + //璁惧鐨勮儗鏅渾鍦堝浘 + this.fraDeviceRound = new FrameLayout(); + fraDeviceRound.Width = HdlControlLogic.Current.GetPictrueRealSize(124); + fraDeviceRound.Height = HdlControlLogic.Current.GetPictrueRealSize(124); + fraDeviceRound.Radius = (uint)HdlControlLogic.Current.GetPictrueRealSize(124) / 2; + fraDeviceRound.X = HdlControlLogic.Current.GetPictrueRealSize(44); + fraDeviceRound.Y = HdlControlLogic.Current.GetPictrueRealSize(101); + fraDeviceRound.BackgroundColor = Common.ZigbeeColor.Current.GXCForFunctionUnSelectedBackgroundColor; + this.AddChidren(fraDeviceRound, ChidrenBindMode.BindEventOnly); + + //璁惧鍥炬爣鎺т欢 + this.btnDeviceIcon = new IconViewControl(86); + btnDeviceIcon.Gravity = Gravity.Center; + fraDeviceRound.AddChidren(btnDeviceIcon); + this.ChangedChidrenBindMode(fraDeviceRound, ChidrenBindMode.BindEventOnly); + + //鐘舵�佹枃鏈帶浠� + this.btnStatu = new NormalViewControl(HdlControlLogic.Current.GetPictrueRealSize(280), HdlControlLogic.Current.GetPictrueRealSize(63), false); + btnStatu.X = HdlControlLogic.Current.GetPictrueRealSize(46); + btnStatu.Y = HdlControlLogic.Current.GetPictrueRealSize(236); + btnStatu.TextColor = UserCenterColor.Current.TextColor1; + btnStatu.SelectedTextColor = Common.ZigbeeColor.Current.GXCTextSelectedColor; + btnStatu.IsBold = true; + this.AddChidren(btnStatu, ChidrenBindMode.BindEventOnly); + + //寮�鍏虫帶浠�(涓嶅姞鍏ョ埗鎺т欢涓�) + this.btnSwitch = new PicViewControl(109, 104); + btnSwitch.X = HdlControlLogic.Current.GetPictrueRealSize(325); + btnSwitch.Y = HdlControlLogic.Current.GetPictrueRealSize(202); + btnSwitch.UnSelectedImagePath = "Item/Switch1.png"; + btnSwitch.SelectedImagePath = "Item/SwitchSelected1.png"; + + //鍒锋柊淇℃伅 + this.RefreshControlInfo(i_device); + } + + #endregion + + #region 鈻� 娣诲姞寮�鍏虫帶浠禵______________________ + + /// <summary> + /// 娣诲姞寮�鍏虫帶浠� + /// </summary> + /// <returns></returns> + public PicViewControl AddSwitchControl() + { + this.AddChidren(this.btnSwitch, ChidrenBindMode.NotBind); + return btnSwitch; + } + + #endregion + + #region 鈻� 鍒锋柊鎺т欢鐘舵�乢______________________ + + /// <summary> + /// 鍒锋柊鎺т欢鐘舵�� + /// </summary> + /// <param name="i_device">璁惧瀵硅薄,涓嶆槸鎺ㄩ�佺殑閭d釜</param> + public void RefreshControlInfo(CommonDevice i_device) + { + bool collect = HdlRoomLogic.Current.IsCollectInRoom(i_device); + if (btnCollect.IsSelected != collect) + { + btnCollect.IsSelected = collect; + } + //璁惧鍥炬爣涔熷埛鏂� + Common.LocalDevice.Current.SetDeviceIconToControl2(btnDeviceIcon, i_device); + //妫�娴嬭澶囨槸鍚︽槸鎵撳紑鐘舵�� + bool isOpen = this.CheckIsOpenStatu(i_device); + if (this.isHadOpenSwitch == true && i_device.HadReadDeviceStatu == false) + { + //濡傛灉杩欎釜鍗$墖鏈夊紑鍏冲姛鑳�,骞朵笖缃戝叧杩樻病鏈夊洖澶嶄箣鍓�,榛樿鏄叧闂姸鎬� + //绛夊緟缃戝叧鍥炲鍚庝細閲嶆柊鍒锋柊,涓嶇劧涓�鐩存槸鍏抽棴鐘舵�� + isOpen = false; + } + this.SetCardOpenStatu(isOpen); + } + + /// <summary> + /// 璁剧疆鍗$墖鐘舵�� + /// </summary> + /// <param name="isOpen"></param> + public void SetCardOpenStatu(bool isOpen) + { + //璁惧鐘舵�佸繀椤诲埛鏂� + this.btnStatu.Text = HdlDeviceOtherLogic.Current.GetDeviceStatu(this.device); + + if (this.btnBackGroud.IsSelected == isOpen) + { + //鐘舵�佷竴鏍�,鍒欎笉闇�瑕佸鐞� + return; + } + //鑳屾櫙鍥剧墖 + this.btnBackGroud.IsSelected = isOpen; + //璁惧鍚嶇О鎺т欢 + this.btnDeviceName.IsSelected = isOpen; + this.btnDeviceName.IsBold = isOpen; + //璁惧鐨勮儗鏅渾鍦堝浘 + if (isOpen == true) + { + fraDeviceRound.BackgroundColor = Common.ZigbeeColor.Current.GXCForFunctionBackgroundColor; + } + else + { + fraDeviceRound.BackgroundColor = Common.ZigbeeColor.Current.GXCForFunctionUnSelectedBackgroundColor; + } + //璁惧鍥炬爣鎺т欢 + this.btnDeviceIcon.IsSelected = isOpen; + //鐘舵�佹枃鏈帶浠� + this.btnStatu.IsSelected = isOpen; + //寮�鍏虫帶浠� + if (btnSwitch != null) + { + this.btnSwitch.IsSelected = isOpen; + } + } + + /// <summary> + /// 璁剧疆鍗$墖鐨勫湪绾跨姸鎬� + /// </summary> + /// <param name="isOnline">鍦ㄧ嚎</param> + public void SetCardOnlineStatu(bool isOnline) + { + if (this.isHadOpenSwitch == true) + { + //濡傛灉杩欎釜璁惧鏈夊紑鍏冲姛鑳�,鍒欏湪绾跨姸鎬佷笉浼氭敼鍙樼姸鎬� + return; + } + this.SetCardOpenStatu(isOnline); + } + + /// <summary> + /// 璁剧疆璁惧鐨勭姸鎬佹枃鏈� + /// </summary> + /// <param name="i_Text">鐘舵�佹枃鏈�</param> + public void SetDeviceStatuText(string i_Text) + { + this.btnStatu.Text = i_Text; + } + + #endregion + + #region 鈻� 鍙戦�佽幏鍙栫姸鎬佸懡浠__________________ + + /// <summary> + /// 鍙戦�佽幏鍙栫姸鎬佸懡浠� + /// </summary> + public virtual void SendStatuComand() + { + return; + } + + #endregion + + #region 鈻� 妫�娴嬭澶囨墦寮�鐘舵�乢__________________ + + /// <summary> + /// 妫�娴嬭澶囨槸鍚︽槸鎵撳紑鐘舵�� + /// </summary> + /// <param name="i_device"></param> + /// <returns></returns> + public virtual bool CheckIsOpenStatu(CommonDevice i_device) + { + //濡傛灉杩欎釜鍑芥暟琚噸鍐欑殑璇�,鍒欎唬琛ㄨ繖涓澶囨湁寮�鍏冲姛鑳� + this.isHadOpenSwitch = false; + //榛樿鐢ㄥ湪绾跨姸鎬佹潵鍒ゆ柇 + return i_device.IsOnline == 1; + } + + + #endregion + + #region 鈻� 娣卞害鍗$墖淇℃伅鐨勮繑鍥炰簨浠禵____________ + + /// <summary> + /// 娣卞害鍗$墖淇℃伅鐨勮繑鍥炰簨浠�(搴曞眰涓撶敤) + /// </summary> + /// <param name="device">璁惧</param> + /// <param name="room">鎴块棿</param> + public void CardDetailInfoBackEvent(CommonDevice device, Common.Room room) + { + if (HdlRoomLogic.Current.CurrentRoom.IsLove == true) + { + //濡傛灉鏄富椤靛彇娑堟悳钘忕殑璇�,鍥炶皟鍗$墖琚垹闄ょ殑鍑芥暟 + if (HdlRoomLogic.Current.IsCollectInRoom(device) == false) + { + this.CardNeedRemoveEvent?.Invoke(); + return; + } + } + else + { + //濡傛灉杩欎釜璁惧鏀瑰彉浜嗘埧闂寸殑璇�,鍥炶皟鍗$墖琚垹闄ょ殑鍑芥暟 + var nowRoom = HdlRoomLogic.Current.GetRoomByDevice(device); + if (nowRoom == null || nowRoom.Id != HdlRoomLogic.Current.CurrentRoom.Id) + { + this.CardNeedRemoveEvent?.Invoke(); + return; + } + } + //濡傛灉瀹冭繕鍦ㄨ繖涓埧闂寸殑璇�,鍒锋柊鍗$墖淇℃伅 + this.RefreshControlInfo(device); + } + + #endregion + + #region 鈻� 鏄惁鑾峰彇缃戝叧鍙嶉鐨勭粨鏋淿____________ + + /// <summary> + /// <para>妫�娴嬫槸鍚﹁幏鍙栫綉鍏冲弽棣堢殑缁撴灉,濡傛灉缃戝叧娌℃湁鍥炲,鍒欎細寮瑰嚭娑堟伅</para> + /// <para>鑾峰彇鍒板洖澶嶇粨鏋滀箣鍚�,璁板緱璋冪敤SetHadGetResponeResultStatu()鍑芥暟璁剧疆鐘舵��</para> + /// </summary> + /// <param name="oldOpenStatu">璁惧鐩墠鐨勫紑鍏崇姸鎬�</param> + public void StartCheckResponeResult(bool oldOpenStatu) + { + this.ResponeResult = 0; + //寮�鍏虫寜閽笉鑳藉啀鐐瑰嚮 + if (btnSwitch != null) { this.btnSwitch.CanClick = false; } + + HdlThreadLogic.Current.RunThread(() => + { + int waitime = 30; + while (waitime > 0) + { + System.Threading.Thread.Sleep(100); + if (this.ResponeResult == 1) + { + //宸茬粡鑾峰彇寰楀埌鏁版嵁 + break; + } + waitime--; + } + if (waitime <= 0) + { + //娌℃湁鑾峰彇寰楀埌缁撴灉 + HdlThreadLogic.Current.RunMain(() => + { + var msgContr = new ShowMsgControl(ShowMsgType.Tip, Language.StringByID(R.MyInternationalizationString.FAIL)); + msgContr.Show(); + //鍙樻洿鍥炲師鏉ョ殑鐘舵�� + this.SetCardOpenStatu(oldOpenStatu); + }); + } + //寮�鍏虫寜閽笉鑳藉啀鐐瑰嚮 + if (btnSwitch != null) { this.btnSwitch.CanClick = true; } + }); + } + + /// <summary> + /// 璁剧疆宸茬粡鑾峰彇鍒扮綉鍏崇殑鍙嶉缁撴灉 + /// </summary> + public void SetHadGetResponeResultStatu() + { + this.ResponeResult = 1; + } + + #endregion + + #region 鈻� 涓�鑸柟娉昣__________________________ + + /// <summary> + /// 妫�娴嬭兘鍚﹀彂閫佽幏鍙栫姸鎬佸懡浠� + /// </summary> + /// <returns></returns> + public bool CheckCanSendStatuComand() + { + if (this.device.HadReadDeviceStatu == false) + { + //杩樻病鏈夎鍙栬繃鏁版嵁 + return true; + } + if ((DateTime.Now - this.device.LastDateTime).TotalMinutes >= 10) + { + //10鍒嗛挓鍚庡彲浠ュ啀娆¤幏鍙� + return true; + } + return false; + } + + #endregion + + #region 鈻� 鎺т欢鎽ф瘉___________________________ + + /// <summary> + /// 鎺т欢鎽ф瘉 + /// </summary> + public override void RemoveFromParent() + { + this.CardNeedRemoveEvent = null; + + base.RemoveFromParent(); + } + + #endregion + } +} -- Gitblit v1.8.0