From f500e14c0a994487070380c50c85e0929cbc8e63 Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期二, 05 一月 2021 10:48:04 +0800 Subject: [PATCH] 2021-01-05 1.更新 --- Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs | 197 ++++++++++++++++++++++++++---------------------- 1 files changed, 106 insertions(+), 91 deletions(-) diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs index 714c35c..ad804e0 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs @@ -65,11 +65,13 @@ if (btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Voltage") { btn.Text = energy.ToString () + " W"; } - } else if (updataType == 11) { - if (btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Electric") { - btn.Text = ((double)(Convert.ToDouble (energy) / 10)).ToString () + " kw.h"; - } } + ////2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //else if (updataType == 11) { + // if (btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Electric") { + // btn.Text = ((double)(Convert.ToDouble (energy) / 10)).ToString () + " kw.h"; + // } + //} } } } @@ -92,7 +94,7 @@ if (light.Type == DeviceType.LightDimming || light.Type == DeviceType.LightMixDimming || light.Type == DeviceType.LightDALI) { if ((light as LightDimming).CurrentBrightness > 0) brighingCount++; - } else if (light.Type == DeviceType.LightSwitch || light.Type == DeviceType.LightMixSwitch) + } else if (light.Type == DeviceType.LightSwitch || light.Type == DeviceType.LightMixSwitch || light.Type == DeviceType.LightEnergySwitch) if ((light as LightSwitch).CurrentBrightness == 100) brighingCount++; if (light.Type == DeviceType.LightRGB) @@ -230,6 +232,8 @@ }); //Utlis.WriteLine ("U1"); } + + private readonly object SendLocker = new object (); bool showTip = true; /// <summary> /// 鎺у埗鎵�鏈夌殑鐏� @@ -262,78 +266,87 @@ if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightRGB || common.Type == DeviceType.LightEnergySwitch || common.Type == DeviceType.LightMixDimming || common.Type == DeviceType.LightMixSwitch || common.Type == DeviceType.LightDALI) { - new System.Threading.Thread (() => { - mSendCount++; + new System.Threading.Thread (() => { + try { + lock (SendLocker) { + mSendCount++; + } + //mSendCount++; - if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI) { - var light = (LightDimming)common; - if (b == 100) { - if (light.LastOpenBrightness == 0) { - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); - } else - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow }); - } else - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); - } else if (common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightEnergySwitch) { - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, ((LightSwitch)common).DelayTimeHeight, ((LightSwitch)common).DelayTimeLow }); - } else if (common.Type == DeviceType.LightRGB) { - var light = (LightLogic)common; - byte b2 = b; - if (b2 == 100) { - if (light.LastOpenBrightness != 0) { - b2 = light.LastOpenBrightness; - } - } - returnBytes = Control.ControlBytesSendHasReturn (Command.SetLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] { + if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI) { + var light = (LightDimming)common; + if (b == 100) { + if (light.LastOpenBrightness == 0) { + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); + } else + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + } else + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); + } else if (common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightEnergySwitch) { + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, ((LightSwitch)common).DelayTimeHeight, ((LightSwitch)common).DelayTimeLow }); + } else if (common.Type == DeviceType.LightRGB) { + var light = (LightLogic)common; + byte b2 = b; + if (b2 == 100) { + if (light.LastOpenBrightness != 0) { + b2 = light.LastOpenBrightness; + } + } + returnBytes = Control.ControlBytesSendHasReturn (Command.SetLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b2, 254, light.CustomDelayTimeOpen,light.CustomDelayTimeClose, 3,light.RStatus,light.GStatus,light.BStatus,0,0}); - } else if (common.Type == DeviceType.LightMixDimming) { - var light = (LightMixDimming)common; - if (b == 100) { - if (light.LastOpenBrightness == 0) { - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); - } else - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow }); - } else - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); - } else if (common.Type == DeviceType.LightMixSwitch) { - var light = (LightMixSwitch)common; - returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); - } else { - returnBytes = new byte [] { 0x00 }; - } - if (showTip) { - if (returnBytes == null) { - Application.RunOnMainThread (() => { + } else if (common.Type == DeviceType.LightMixDimming) { + var light = (LightMixDimming)common; + if (b == 100) { + if (light.LastOpenBrightness == 0) { + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); + } else + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + } else + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); + } else if (common.Type == DeviceType.LightMixSwitch) { + var light = (LightMixSwitch)common; + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow }); + } else { + returnBytes = new byte [] { 0x00 }; + } + if (showTip) { + if (returnBytes == null) { + Application.RunOnMainThread (() => { - var btnTip = new Button () { - Height = Application.GetRealHeight (140), - Text = common.Name + ErrorCode.ControlFailure, - BackgroundColor = 0xFFD7D7D7, - }; - MainPage.MainFrameLayout.AddChidren (btnTip); - btnTip.MouseUpEventHandler += (sender, e) => { - btnTip.RemoveFromParent (); - //MainPage.MainFrameLayout.Remove (btnTip); - //showTip = false; - }; + var btnTip = new Button () { + Height = Application.GetRealHeight (140), + Text = common.Name + ErrorCode.ControlFailure, + BackgroundColor = 0xFFD7D7D7, + }; + MainPage.MainFrameLayout.AddChidren (btnTip); + btnTip.MouseUpEventHandler += (sender, e) => { + btnTip.RemoveFromParent (); + //MainPage.MainFrameLayout.Remove (btnTip); + //showTip = false; + }; - System.Threading.Tasks.Task.Run (() => { - System.Threading.Thread.Sleep (3000); - Application.RunOnMainThread (() => { - btnTip.RemoveFromParent (); - //MainPage.MainFrameLayout.Remove (btnTip); - }); - }); + System.Threading.Tasks.Task.Run (() => { + System.Threading.Thread.Sleep (3000); + Application.RunOnMainThread (() => { + btnTip.RemoveFromParent (); + //MainPage.MainFrameLayout.Remove (btnTip); + }); + }); - }); - } - } + }); + } + } - mSendCount--; - }) { IsBackground = true }.Start(); + //mSendCount--; + } catch { } finally { + lock (SendLocker) { + mSendCount--; + } + } + }) { IsBackground = true }.Start (); //绛夊緟100ms鍐嶅彂閫佺浜屼釜璁惧鏁版嵁 System.Threading.Thread.Sleep (100); @@ -503,8 +516,8 @@ roomView.AddChidren (btnNumber); Button btnLightIcon = new Button () { - Width = Application.GetRealWidth (100), - Height = Application.GetRealHeight (80), + Width = Application.GetMinRealAverage (100), + Height = Application.GetMinRealAverage (80), Gravity = Gravity.CenterVertical, UnSelectedImagePath = "Item/RH_Lights.png", SelectedImagePath = "Item/RH_LightsSelected.png", @@ -564,8 +577,8 @@ Button downSelectedButton = new Button () { X = Application.GetRealWidth (550), - Height = Application.GetRealHeight (50), - Width = Application.GetRealWidth (55), + Height = Application.GetMinRealAverage (50), + Width = Application.GetMinRealAverage (55), UnSelectedImagePath = "Item/Down.png", SelectedImagePath = "Item/DownSelected.png", Gravity = Gravity.CenterVertical, @@ -685,21 +698,21 @@ }; lightView.AddChidren (btnEnergy); EnergtLightList.Add (common); - - if (common.Type == DeviceType.LightEnergySwitch) { - Button btnElectric = new Button () { - Width = Application.GetRealWidth (200), - Height = Application.GetRealHeight (35), - X = Application.GetRealWidth (320), - Y = tempSwitch.Bottom, - TextAlignment = TextAlignment.CenterRight, - TextColor = SkinStyle.Current.TextColor1, - SelectedTextColor = SkinStyle.Current.TextColor1, - Tag = common.Type.ToString () + "_Electric", - Text = "0 kw.h" - }; - lightView.AddChidren (btnElectric); - } + //2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //if (common.Type == DeviceType.LightEnergySwitch) { + // Button btnElectric = new Button () { + // Width = Application.GetRealWidth (200), + // Height = Application.GetRealHeight (35), + // X = Application.GetRealWidth (320), + // Y = tempSwitch.Bottom, + // TextAlignment = TextAlignment.CenterRight, + // TextColor = SkinStyle.Current.TextColor1, + // SelectedTextColor = SkinStyle.Current.TextColor1, + // Tag = common.Type.ToString () + "_Electric", + // Text = "0 kw.h" + // }; + // lightView.AddChidren (btnElectric); + //} } tempSwitch.MouseUpEventHandler += (sender3, e3) => { @@ -716,7 +729,8 @@ if (common.Type == DeviceType.LightEnergySwitch) { new System.Threading.Thread (() => { Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 10, light.LoopID }, SendCount.Zero); - Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 11, light.LoopID }, SendCount.Zero); + //2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 11, light.LoopID }, SendCount.Zero); }) { IsBackground = true }.Start (); } }; @@ -987,9 +1001,10 @@ for (int i = 0; i < EnergtLightList.Count; i++) { var c = EnergtLightList [i]; Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 10, c.LoopID }, SendCount.Zero); - //if (c.Type == DeviceType.LightEnergySwitch) { - Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero); - //} + ////if (c.Type == DeviceType.LightEnergySwitch) { + ////2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero); + ////} System.Threading.Thread.Sleep (200); } System.Threading.Thread.Sleep (10000); -- Gitblit v1.8.0