From fcde8ea5ceb4c208f9a6e7a972666d0045850e3f Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期五, 26 三月 2021 17:36:05 +0800 Subject: [PATCH] 2021-03-26 1.更新 --- Crabtree/SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs | 4 Crabtree/SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs | 161 ++++++++++++++++++++++++++++++++++++++++ Crabtree/SmartHome/HDL/Common/Constant.cs | 5 + Crabtree/.vs/SmartHome/xs/UserPrefs.xml | 33 ++++++-- 4 files changed, 192 insertions(+), 11 deletions(-) diff --git a/Crabtree/.vs/SmartHome/xs/UserPrefs.xml b/Crabtree/.vs/SmartHome/xs/UserPrefs.xml index f96c20d..218f043 100644 --- a/Crabtree/.vs/SmartHome/xs/UserPrefs.xml +++ b/Crabtree/.vs/SmartHome/xs/UserPrefs.xml @@ -1,31 +1,48 @@ 锘�<Properties StartupConfiguration="{1D83BF28-BA88-4152-BA41-D7EFE90A5437}|Default"> <MonoDevelop.Ide.ItemProperties.ON.Droid PreferredExecutionTarget="Android.Android_Accelerated_Oreo" /> - <MonoDevelop.Ide.Workbench ActiveDocument="SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs"> + <MonoDevelop.Ide.Workbench ActiveDocument="SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs"> <Files> - <File FileName="SmartHome/UI/SimpleControl/Phone/Scene/UserDeviceToScene.cs" Line="22" Column="19" /> - <File FileName="SmartHome/UI/SimpleControl/Phone/Schedule/AddSchedule.cs" Line="52" Column="33" /> - <File FileName="SmartHome/HDL/Operation/ResponseEntity/Timer.cs" Line="45" Column="23" /> + <File FileName="SmartHome/HDL/Common/Constant.cs" Line="60" Column="31" /> + <File FileName="SmartHome/HDL/Common/HttpUtil/HttpServerRequest.cs" Line="716" Column="10" /> <File FileName="SmartHome/UI/SimpleControl/Phone/Scene/SceneMethod.cs" Line="1" Column="1" /> - <File FileName="SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs" Line="58" Column="33" /> + <File FileName="SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs" Line="344" Column="33" /> </Files> <Pads> <Pad Id="ProjectPad"> <State name="__root__"> <Node name="SmartHome" expanded="True"> <Node name="Shared" expanded="True"> + <Node name="DLL" expanded="True" /> <Node name="HDL" expanded="True"> + <Node name="Common" expanded="True"> + <Node name="HttpUtil" expanded="True" /> + </Node> <Node name="Operation" expanded="True"> <Node name="ResponseEntity" expanded="True" /> </Node> </Node> + <Node name="IO" expanded="True" /> + <Node name="Net" expanded="True" /> <Node name="UI" expanded="True"> <Node name="SimpleControl" expanded="True"> <Node name="Phone" expanded="True"> + <Node name="FoolHeat" expanded="True" /> + <Node name="FresAir" expanded="True" /> + <Node name="Guide" expanded="True" /> <Node name="Light" expanded="True" /> - <Node name="Scene" expanded="True"> - <Node name="UserAddSceneDevice.cs" selected="True" /> + <Node name="Register" expanded="True" /> + <Node name="Room" expanded="True" /> + <Node name="Scene" expanded="True" /> + <Node name="Schedule" expanded="True"> + <Node name="UserSchedule.cs" selected="True" /> </Node> - <Node name="Schedule" expanded="True" /> + <Node name="Security" expanded="True" /> + <Node name="Sensor" expanded="True" /> + <Node name="System" expanded="True" /> + <Node name="TV" expanded="True" /> + <Node name="UniversalDevice" expanded="True" /> + <Node name="User" expanded="True" /> + <Node name="Warning" expanded="True" /> </Node> </Node> </Node> diff --git a/Crabtree/SmartHome/HDL/Common/Constant.cs b/Crabtree/SmartHome/HDL/Common/Constant.cs index 33bc993..5b69e04 100644 --- a/Crabtree/SmartHome/HDL/Common/Constant.cs +++ b/Crabtree/SmartHome/HDL/Common/Constant.cs @@ -7,7 +7,10 @@ /// </summary> public class Constant { - + /// <summary> + /// + /// </summary> + public const string Equipment = "Equipment"; /// <summary> /// 瑁佸壀鍥剧墖鐨勯珮澶у皬 diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs index c725d7f..2d2121b 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Scene/UserAddSceneDevice.cs @@ -145,6 +145,13 @@ if (null == common) { continue; } + + var newName = CheckIfNameChanged (deviceFilePath, common.Type.ToString(), common.Name); + if (!string.IsNullOrEmpty (newName)) { + Utlis.WriteLine (common.Name + " 鍦烘櫙璁惧鏂板娉細" + newName); + common.Name = newName; + } + string iconPath = ""; if (common.Type == DeviceType.UniversalDevice) { @@ -2536,5 +2543,159 @@ } } } + + + + /// <summary> + /// 2021-03-26 + /// 妫�娴嬪垽鏂娉ㄥ悕鏄惁淇敼杩囷紝淇敼杩囧垯鏇存柊涓�娆� + /// 淇娴嬭瘯鍙嶉BUG锛堣澶囧娉ㄤ慨鏀瑰悗锛屽満鏅噷闈㈢殑璁惧澶囨敞娌℃湁鍚屾锛岄渶鍒犻櫎鍘熸潵璁惧閲嶆柊娣诲姞锛屽娉ㄦ墠鏇存柊銆傦級 + /// </summary> + /// <param name="deviceFilePath"></param> + /// <param name="deviceType"></param> + /// <param name="deviceName"></param> + string CheckIfNameChanged (string deviceFilePath, string deviceType, string deviceName) + { + try { + string [] str = deviceFilePath.Split (Constant.Equipment); + if (str == null || str.Length != 2) return ""; + //1.鎵惧嚭鏈湴鐪熷疄鐨勮澶� + string trueDeviceFilePath = Constant.Equipment + str [1]; + Common common = Newtonsoft.Json.JsonConvert.DeserializeObject<Common> (CommonPage.MyEncodingUTF8.GetString (IO.FileUtils.ReadFile (trueDeviceFilePath))); + if (null == common) { + return ""; + } + //2.鏈湴瀛樺湪鐪熷疄璁惧锛屽垽鏂娉ㄦ槸鍚︿竴鑷� + if (deviceName.Equals (common.Name) || deviceName == common.Name) return ""; + //3.涓嶄竴鑷存洿鏂板娉ㄤ繚瀛樺埌鏈湴 + string newName = common.Name; + //4.杩欓噷娉ㄦ剰锛氳浆鎹㈡垚褰撳墠璁惧绫诲瀷鐨勫璞★紝涓嶈兘杞崲鎴怌ommon锛屼笉鐒朵繚瀛樺悗浼氫涪澶辫缃殑鎺у埗鐘舵�佸�兼暟鎹�� + if (deviceType == DeviceType.LightSwitch.ToString () || deviceType == DeviceType.LightEnergySocket.ToString () || deviceType == DeviceType.LightEnergySwitch.ToString () || deviceType == DeviceType.LightSwitchSocket.ToString ()) { + LightSwitch lightSwitch = Newtonsoft.Json.JsonConvert.DeserializeObject<LightSwitch> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (null == lightSwitch) { + return ""; + } + lightSwitch.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (lightSwitch))); + + } else if (deviceType == DeviceType.LightMixSwitch.ToString ()) { + LightMixSwitch lightSwitch = Newtonsoft.Json.JsonConvert.DeserializeObject<LightMixSwitch> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (null == lightSwitch) { + return ""; + } + lightSwitch.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (lightSwitch))); + + } else if (deviceType == DeviceType.LightDimming.ToString ()) { + LightDimming lightDimming = Newtonsoft.Json.JsonConvert.DeserializeObject<LightDimming> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (null == lightDimming) { + return ""; + } + lightDimming.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (lightDimming))); + + + } else if (deviceType == DeviceType.LightMixDimming.ToString ()) { + LightMixDimming lightDimming = Newtonsoft.Json.JsonConvert.DeserializeObject<LightMixDimming> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (null == lightDimming) { + return ""; + } + lightDimming.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (lightDimming))); + + + } else if (deviceType == DeviceType.LightRGB.ToString ()) { + LightLogic lightRGB = Newtonsoft.Json.JsonConvert.DeserializeObject<LightLogic> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (null == lightRGB) { + return ""; + } + + lightRGB.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (lightRGB))); + + } else if (deviceType == DeviceType.CurtainModel.ToString () || deviceType == DeviceType.CurtainTrietex.ToString () || deviceType == DeviceType.CurtainRoller.ToString ()) { + if (deviceType == DeviceType.CurtainModel.ToString ()) { + #region CurtainModelView + CurtainModel curtainmodel = Newtonsoft.Json.JsonConvert.DeserializeObject<CurtainModel> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (curtainmodel == null) { + return ""; + } + curtainmodel.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (curtainmodel))); + + #endregion + } else if (deviceType == DeviceType.CurtainTrietex.ToString ()) { + #region CurtainTrietexlView + CurtainTrietex curtaintretex = Newtonsoft.Json.JsonConvert.DeserializeObject<CurtainTrietex> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (curtaintretex == null) { + return ""; + } + curtaintretex.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (curtaintretex))); + + #endregion + } else if (deviceType == DeviceType.CurtainRoller.ToString ()) { + #region CurtainRollerlView + CurtainRoller curtainroller = Newtonsoft.Json.JsonConvert.DeserializeObject<CurtainRoller> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (curtainroller == null) { + return ""; + }; + curtainroller.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (curtainroller))); + + + } else { + return ""; + } + #endregion + } else if (deviceType == DeviceType.HVAC.ToString () || deviceType == DeviceType.ACInfrared.ToString () || deviceType == DeviceType.ACPanel.ToString ()) { + AC ac = Newtonsoft.Json.JsonConvert.DeserializeObject<AC> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (ac == null) { + return ""; + } + ac.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (ac))); + + } else if (deviceType == DeviceType.FoolHeat.ToString () || deviceType == DeviceType.FoolHeatPanel.ToString ()) { + FoolHeat fh = Newtonsoft.Json.JsonConvert.DeserializeObject<FoolHeat> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (fh == null) + return ""; + + fh.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (fh))); + + } else if (deviceType == DeviceType.DryContact.ToString ()) { + + } else if (deviceType == DeviceType.MusicModel.ToString ()) { + + } else if (deviceType == DeviceType.FanModule.ToString ()) { + #region FanModuleView + FanModule fanModule = Newtonsoft.Json.JsonConvert.DeserializeObject<FanModule> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (fanModule == null) { + return ""; + } + fanModule.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (fanModule))); + + #endregion + } else if (deviceType == DeviceType.UniversalDevice.ToString ()) { + #region UniversalDevice + UniversalDevice udDevice = Newtonsoft.Json.JsonConvert.DeserializeObject<UniversalDevice> (System.Text.Encoding.UTF8.GetString (IO.FileUtils.ReadFile (deviceFilePath))); + if (udDevice == null) { + return ""; + } + udDevice.Name = newName; + IO.FileUtils.WriteFileByBytes (deviceFilePath, CommonPage.MyEncodingUTF8.GetBytes (Newtonsoft.Json.JsonConvert.SerializeObject (udDevice))); + #endregion + } else { + return ""; + } + + + return newName; + } catch { + return ""; + } + } } } \ No newline at end of file diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs index b898334..218722e 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Schedule/UserSchedule.cs @@ -362,10 +362,10 @@ Timer timer = new Timer (); var jay = jArray [a]; timer.id = jay ["id"].ToString (); - timer.timerName =jay ["timerName"].ToString (); + timer.timerName = jay ["timerName"].ToString (); timer.userId = jay ["userId"].ToString (); timer.isEnable = Boolean.Parse (jay ["isEnable"].ToString ()); - timer.executeUtcTime =SmartHome.Method.GetLocalUtcTime(jay ["executeUtcTime"].ToString ()); + timer.executeUtcTime = SmartHome.Method.GetLocalUtcTime(jay ["executeUtcTime"].ToString ()); timer.timerType = (TimerType)System.Enum.Parse (typeof (TimerType), jay ["timerType"].ToString ()); var whichDayJson = jay ["whichDay"].ToString (); var whichDayAry = Newtonsoft.Json.Linq.JArray.Parse (whichDayJson); -- Gitblit v1.8.0