Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs
@@ -67,11 +67,13 @@
                                            if (btn.Tag.ToString () == DeviceType.LightEnergySocket.ToString () + "_Voltage" || btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Voltage") {
                                                btn.Text = energy.ToString () + " W";
                                            }
                                        } else if (updataType == 11) {
                                            if (btn.Tag.ToString () == DeviceType.LightEnergySocket.ToString () + "_Electric" || 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.LightEnergySocket.ToString () + "_Electric" || btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Electric") {
                                        //        btn.Text = ((double)(Convert.ToDouble (energy) / 10)).ToString () + " kw.h";
                                        //    }
                                        //}
                                    }
                                }
                            }
@@ -237,7 +239,7 @@
                        }
                    }
                } catch (Exception ex) {
                    Console.WriteLine (ex.Message);
                    Utlis.WriteLine (ex.Message);
                } finally {
                    Application.RunOnMainThread (() => {
                        MainPage.Loading.Hide ();
@@ -246,6 +248,7 @@
            });
        }
        private readonly object SendLocker = new object ();
        /// <summary>
        /// 控制所有的灯
        /// </summary>
@@ -275,34 +278,43 @@
                            byte [] returnBytes = null;
                            if (common.Type == DeviceType.LightEnergySocket) {
                                new System.Threading.Thread (() => {
                                    mSendCount++;
                                    returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, 0, 0 });
                                    if (showTip) {
                                        if (returnBytes == null) {
                                            Application.RunOnMainThread (() => {
                                    try {
                                        lock (SendLocker) {
                                            mSendCount++;
                                        }
                                        //mSendCount++;
                                        returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, 0, 0 });
                                        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 ();
                                                };
                                                System.Threading.Tasks.Task.Run (() => {
                                                    System.Threading.Thread.Sleep (3000);
                                                    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 ();
                                                    });
                                                });
                                                    };
                                            });
                                                    System.Threading.Tasks.Task.Run (() => {
                                                        System.Threading.Thread.Sleep (3000);
                                                        Application.RunOnMainThread (() => {
                                                            btnTip.RemoveFromParent ();
                                                        });
                                                    });
                                                });
                                            }
                                        }
                                        //mSendCount--;
                                    } catch { } finally {
                                        lock (SendLocker) {
                                            mSendCount--;
                                        }
                                    }
                                    mSendCount--;
                                }) { IsBackground = true}.Start();
                                }) { IsBackground = true }.Start ();
                                //等待100ms再发送第二个设备数据
                                System.Threading.Thread.Sleep (100);
@@ -316,7 +328,7 @@
                        System.Threading.Thread.Sleep (100);
                    }
                } catch (Exception ex) {
                    Console.WriteLine (ex.Message);
                    Utlis.WriteLine (ex.Message);
                } finally {
                    Application.RunOnMainThread (() => {
                        MainPage.Loading.Hide ();
@@ -472,21 +484,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,
                                TextColor = SkinStyle.Current.TextColor1,
                                SelectedTextColor = SkinStyle.Current.TextColor1,
                                TextAlignment = TextAlignment.CenterRight,
                                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,
                        //        TextColor = SkinStyle.Current.TextColor1,
                        //        SelectedTextColor = SkinStyle.Current.TextColor1,
                        //        TextAlignment = TextAlignment.CenterRight,
                        //        Tag = common.Type.ToString () + "_Electric",
                        //        Text = "0 kw.h"
                        //    };
                        //    lightView.AddChidren (btnElectric);
                        ////}
                        Button btnEnergyNull = new Button () {
                            Y = Application.GetRealHeight (127),
@@ -503,7 +515,8 @@
                while (readEnergy) {
                    foreach (var c in EnergtLightList) {
                        Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 10, c.LoopID }, SendCount.Zero);
                        Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero);
                        //2020-07-01 客户提出隐藏kwh
                        //Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero);
                        System.Threading.Thread.Sleep (200);
                    }
                    Thread.Sleep (10000);
@@ -559,7 +572,7 @@
        {
            if (isCheckIsReadingAll) {
                if (IsReadingAll && !isRead) {
                    Console.WriteLine ("IsLightReadingAll 读取中");
                    Utlis.WriteLine ("IsLightReadingAll 读取中");
                    return;
                }
            }