From e747e6d8524e3146bb48dc304a713f309966b1c6 Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期二, 19 五月 2020 13:10:03 +0800
Subject: [PATCH] 新版本

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/Curtain/AutoOpenDirectionAndLimitSettionForm.cs |   79 ++++++++++++++++++++-------------------
 1 files changed, 41 insertions(+), 38 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Curtain/AutoOpenDirectionAndLimitSettionForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Curtain/AutoOpenDirectionAndLimitSettionForm.cs
index de7b257..2bc736f 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Curtain/AutoOpenDirectionAndLimitSettionForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Curtain/AutoOpenDirectionAndLimitSettionForm.cs
@@ -177,10 +177,10 @@
 
                 var form = new BottomItemSelectForm();
                 form.AddForm(Language.StringByID(R.MyInternationalizationString.uDirectionSelect), listText, nowSelectNo);
-                form.FinishSelectEvent += async (index) =>
+                form.FinishSelectEvent += (index) =>
                 {
                     //鍙樻洿鏂瑰悜
-                    var result = await HdlDeviceCurtainLogic.Current.SetCurtainDirection(curtainDevice, index == 0 ? false : true);
+                    var result = HdlDeviceCurtainLogic.Current.SetCurtainDirection(curtainDevice, index == 0 ? false : true);
                     if (result == false)
                     {
                         return;
@@ -336,7 +336,8 @@
             frameBack.AddChidren(btnSave);
             btnSave.ButtonClickEvent += (sender, e) =>
             {
-                if (this.receiveOpenlimit == true)
+                //2020.05.17:杩藉姞铏氭嫙浣忓畢鍙互鐩存帴鐐瑰嚮
+                if (this.receiveOpenlimit == true || Common.Config.Instance.Home.IsVirtually == true)
                 {
                     //纭寮�闄愪綅鐐�
                     this.SaveOpenLimit();
@@ -356,27 +357,28 @@
                 //鏁版嵁鍙樻洿,鐧惧垎姣�
                 curtainData.OpenLimitPersent = value;
             };
+            //铏氭嫙浣忓畢涓嶉渶瑕佺洃鍚�
+            if (Common.Config.Instance.Home.IsVirtually == true)
+            {
+                return;
+            }
 
             HdlThreadLogic.Current.RunThread(async () =>
             {
-                //澶勭悊涓�
-                bool checking = false;
                 while (openSeekBar.Parent != null)
                 {
                     int nowValue = curtainData.OpenLimitPersent;
-                    if (oldProValue == nowValue || checking == true)
+                    if (oldProValue == nowValue)
                     {
                         //鍊间笉绛夋墠澶勭悊
                         await Task.Delay(500);
                         continue;
                     }
                     oldProValue = nowValue;
-                    checking = true;
 
                     //灏嗙獥甯樿皟鏁村埌鎸囧畾鐧惧垎姣�
                     this.sendDiv = 1;
                     curtainDevice.WcdGoToTiltValue(nowValue);
-                    checking = false;
                 }
             });
         }
@@ -388,15 +390,14 @@
         {
             //纭褰撳墠浣嶇疆涓哄紑闄愪綅?
             string msg = Language.StringByID(R.MyInternationalizationString.uCommitCurtainOpenLimitMsg);
-            this.ShowMassage(ShowMsgType.Confirm, msg, async () =>
+            this.ShowMassage(ShowMsgType.Confirm, msg, () =>
             {
                 decimal openValue = ((decimal)curtainData.OpenLimitPersent / 100) * curtainData.CurtainLength;
                 decimal closeValue = ((decimal)curtainData.CloseLimitPersent / 100) * curtainData.CurtainLength;
                 if (openValue < 0) { openValue = 0; }
                 if (closeValue < 0) { closeValue = curtainData.CurtainLength; }
                 //鎵ц纭鍙婅鐩栦笂闄愪綅鐐�
-                var result = await HdlDeviceCurtainLogic.Current.CommitCurtainLimitPoint(curtainDevice, Rollershade.CurtainPrivateInstalledLimi.UpLimit,
-                    (int)openValue, (int)closeValue);
+                var result = HdlDeviceCurtainLogic.Current.SetAutoOpenCurtainLimitPoint(curtainDevice, (int)openValue, (int)closeValue, curtainData.CurtainLength);
                 if (result == true)
                 {
                     this.receiveOpenlimit = false;
@@ -508,7 +509,8 @@
             frameBack.AddChidren(btnSave);
             btnSave.ButtonClickEvent += (sender, e) =>
             {
-                if (this.receiveCloseLimit == true)
+                //2020.05.17:杩藉姞铏氭嫙浣忓畢鍙互鐩存帴鐐瑰嚮
+                if (this.receiveCloseLimit == true || Common.Config.Instance.Home.IsVirtually == true)
                 {
                     //淇濆瓨鍚堥檺浣嶇偣
                     this.SaveCloseLimit();
@@ -528,27 +530,28 @@
                 //鏁版嵁鍙樻洿,鐧惧垎姣�
                 curtainData.CloseLimitPersent = value;
             };
+            //铏氭嫙浣忓畢涓嶉渶瑕佺洃鍚�
+            if (Common.Config.Instance.Home.IsVirtually == true)
+            {
+                return;
+            }
 
             HdlThreadLogic.Current.RunThread(async () =>
             {
-                //澶勭悊涓�
-                bool checking = false;
                 while (closeSeekBar.Parent != null)
                 {
                     int nowValue = curtainData.CloseLimitPersent;
-                    if (oldProValue == nowValue || checking == true)
+                    if (oldProValue == nowValue)
                     {
                         //鍊间笉绛夋墠澶勭悊
                         await Task.Delay(500);
                         continue;
                     }
-                    checking = true;
                     oldProValue = nowValue;
 
                     //灏嗙獥甯樿皟鏁村埌鎸囧畾鐧惧垎姣�
                     this.sendDiv = 2;
                     curtainDevice.WcdGoToTiltValue(nowValue);
-                    checking = false;
                 }
             });
         }
@@ -560,15 +563,14 @@
         {
             //纭褰撳墠浣嶇疆涓哄悎闄愪綅?
             string msg = Language.StringByID(R.MyInternationalizationString.uCommitCurtainCloseLimitMsg);
-            this.ShowMassage(ShowMsgType.Confirm, msg, async () =>
+            this.ShowMassage(ShowMsgType.Confirm, msg, () =>
             {
                 decimal openValue = ((decimal)curtainData.OpenLimitPersent / 100) * curtainData.CurtainLength;
                 decimal closeValue = ((decimal)curtainData.CloseLimitPersent / 100) * curtainData.CurtainLength;
                 if (openValue < 0) { openValue = 0; }
                 if (closeValue < 0) { closeValue = curtainData.CurtainLength; }
                 //鎵ц纭鍙婅鐩栦笂闄愪綅鐐�
-                var result = await HdlDeviceCurtainLogic.Current.CommitCurtainLimitPoint(curtainDevice, Rollershade.CurtainPrivateInstalledLimi.DownLimit,
-                    (int)openValue, (int)closeValue);
+                var result = HdlDeviceCurtainLogic.Current.SetAutoOpenCurtainLimitPoint(curtainDevice, (int)openValue, (int)closeValue, curtainData.CurtainLength);
 
                 if (result == true)
                 {
@@ -594,6 +596,11 @@
             rowReset.AddBottomLine();
             rowReset.ButtonClickEvent += (sender, e) =>
             {
+                //濡傛灉褰撳墠鏄櫄鎷熶綇瀹�
+                if (Common.Config.Instance.Home.IsVirtually == true)
+                {
+                    return;
+                }
                 //閲嶇疆鐢垫満灏嗗垵濮嬪寲{0}鏂瑰悜涓庨檺浣嶈缃紝纭缁х画锛�
                 string msg = Language.StringByID(R.MyInternationalizationString.uResetElectricalMachineryMsg);
                 msg = msg.Replace("{0}", "\r\n");
@@ -651,13 +658,24 @@
         /// <returns></returns>
         private bool InitCurtainDefultData()
         {
-            //寮�鍚繘搴︽潯
-            this.ShowProgressBar();
-
             this.curtainData = new CurtainData();
             this.receiveOpenlimit = false;
             this.receiveCloseLimit = false;
             this.sendDiv = 0;
+
+            //濡傛灉褰撳墠鏄櫄鎷熶綇瀹�
+            if (Common.Config.Instance.Home.IsVirtually == true)
+            {
+                var data = ModelData.DeviceModelDataLogic.Current.GetCurtainLimitPoint(curtainDevice);
+                curtainData.Direction = data.Direction;
+                curtainData.CurtainLength = data.curtainLength;
+                curtainData.OpenLimitValue = data.upLimit;
+                curtainData.CloseLimitValue = data.downLimit;
+                return true;
+            }
+
+            //寮�鍚繘搴︽潯
+            this.ShowProgressBar();
 
             int receiptDataCount = 0;
             string mainkeys = LocalDevice.Current.GetDeviceMainKeys(curtainDevice);
@@ -728,21 +746,6 @@
             }
             //绉婚櫎鐩戝惉
             HdlGatewayReceiveLogic.Current.RemoveEvent("CurtainDeviceAttribute");
-
-            //澶囦唤绐楀笜鏁版嵁
-            if (this.backupCurtainData == true && curtainData.CurtainLength > 0)
-            {
-                this.backupCurtainData = false;
-                HdlThreadLogic.Current.RunThread(async () =>
-                {
-                    //鏂瑰悜澶囦唤
-                    await HdlDeviceCurtainLogic.Current.BackupCurtainDirection(curtainDevice, curtainData.Direction);
-                    //闄愪綅澶囦唤
-                    int uplimit = (int)(curtainData.OpenLimitValue / (curtainData.CurtainLength * 1.0) * 100);
-                    int downlimit = (int)(curtainData.CloseLimitValue / (curtainData.CurtainLength * 1.0) * 100);
-                    await HdlDeviceCurtainLogic.Current.BackupCurtainLimitPoint(curtainDevice, uplimit, downlimit);
-                });
-            }
 
             return true;
         }

--
Gitblit v1.8.0