From f441a3c49f8b5cedee3e4def6fbb448ef40eb9cb Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期三, 10 六月 2020 14:46:58 +0800
Subject: [PATCH] Crabtree-ON 2020-06-10 基于最新HDL ON 优化问题,Crabtree-ONAPP部分功能同步修改优化调整 1. 增加大图片大文件上传处理. 2.远程连接交互提示,由原来的Loading修改成顶部Tip提示。 3.灯光全开、全关和场景控制多线程发送,和HDLON同样加锁处理。 4.Android ,判断移动网络失败,网络监测修复方法修改,后台前台切换优化。

---
 Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs |   56 +++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 33 insertions(+), 23 deletions(-)

diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs
index e5f41b7..bb904ee 100644
--- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs
+++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToSocket.cs
@@ -246,6 +246,7 @@
             });
         }
 
+        private readonly object SendLocker = new object ();
         /// <summary>
         /// 鎺у埗鎵�鏈夌殑鐏�
         /// </summary>
@@ -275,34 +276,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);

--
Gitblit v1.8.0