From 502d4ff743c1645adb469ab89c24826c4ec38f28 Mon Sep 17 00:00:00 2001
From: 陈嘉乐 <cjl@hdlchina.com.cn>
Date: 星期五, 05 二月 2021 15:40:47 +0800
Subject: [PATCH] 2021-2-5-2

---
 Crabtree/SmartHome/HDL/Common/HDLLinkUtlis.cs | 2504 +++++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 2,150 insertions(+), 354 deletions(-)

diff --git a/Crabtree/SmartHome/HDL/Common/HDLLinkUtlis.cs b/Crabtree/SmartHome/HDL/Common/HDLLinkUtlis.cs
index fd49cfb..c55a07d 100644
--- a/Crabtree/SmartHome/HDL/Common/HDLLinkUtlis.cs
+++ b/Crabtree/SmartHome/HDL/Common/HDLLinkUtlis.cs
@@ -1,372 +1,2168 @@
-锘�//using System;
-//using System.Collections.Generic;
-//using Shared;
+锘縰sing System;
+using System.Collections.Generic;
+using Shared;
+using Shared.IO;
 
-//namespace SmartHome
-//{
-//    /// <summary>
-//    /// HDLLink鍗忚 宸ュ叿绫�
-//    /// </summary>
-//    public class HDLLinkUtlis
-//    {
-//        #region 鈻� Current___________________________
-//        /// <summary>
-//        /// 閫氱敤鏂规硶
-//        /// </summary>
-//        private static HDLLinkUtlis m_Current = null;
-//        /// <summary>
-//        /// 閫氱敤鏂规硶
-//        /// </summary>
-//        public static HDLLinkUtlis Current {
-//            get {
-//                if (m_Current == null) {
-//                    m_Current = new HDLLinkUtlis ();
-//                }
-//                return m_Current;
-//            }
-//        }
-//        #endregion
-
-//        /// <summary>
-//        /// 灏嗗湪绾胯澶囪浆鎹㈡垚sid + 灞炴�у垪琛�
-//        /// </summary>
-//        /// <param name="onlineDevices"></param>
-//        /// <returns></returns>
-//        public List<Sid> ConvertToSidListToIotCloud (string sOid, Common onlineDevice)
-//        {
-//            List<Sid> tmpResult = new List<Sid> ();
-//            try {
-//                if (onlineDevice.bytSimpleParam == null || onlineDevice.bytSimpleParam.Length == 0) {
-//                    string sSimpleList = DeviceTypeList.GetSimpleFunctionListFromPublicModeGroup (onlineDevice.DeviceType);
-//                    #region
-//                    string [] ArayStr = sSimpleList.Trim ().Split (new char [] { ' ' });
-//                    List<byte> ArayTmp = new List<byte> ();
-//                    for (int i = 0; i < ArayStr.Length; i++) {
-//                        if (ArayStr [i] != null && ArayStr [i] != "" && ArayStr [i].Trim () != "") {
-//                            ArayTmp.Add (Convert.ToByte (ArayStr [i], 16));
-//                        }
-//                    }
-//                    onlineDevice.bytSimpleParam = ArayTmp.ToArray ();
-//                    #endregion
-//                }
-//                if (onlineDevice.bytSimpleParam != null && onlineDevice.bytSimpleParam.Length > 0) {
-//                    for (int intI = 0; intI < onlineDevice.bytSimpleParam.Length / 3; intI++) {
-//                        Byte BigType = onlineDevice.bytSimpleParam [0 + intI * 3];
-//                        Byte SmallType = onlineDevice.bytSimpleParam [1 + intI * 3];
-//                        int Count = onlineDevice.bytSimpleParam [2 + intI * 3];
-//                        if (Count > 0) {
-//                            for (int j = 1; j <= Count; j++) {
-//                                Sid tmpSid = new Sid ();
-//                                tmpSid.sid = HDLSysPF.FormingNewSid (onlineDevice.DeviceType, sOid, j, false, BigType, SmallType);
-//                                tmpSid.oid = sOid;
-
-//                                try {
-//                                    tmpSid.name = onlineDevice.myEasyDesignChannelRemark [intI] [j - 1];
-//                                } catch (Exception ex) {
-//                                    tmpSid.name = "";
-//                                }
-//                                if (tmpSid.name == null || tmpSid.name == "" || tmpSid.name == "Unread") {
-//                                    tmpSid.name = onlineDevice.Remark + CsConst.mstrINIDefault.IniReadValue ("public", "00000", "") + " " + j.Tostring ();
-//                                    if (onlineDevice.Remark == "") {
-//                                        tmpSid.name = onlineDevice.strDescription + CsConst.mstrINIDefault.IniReadValue ("public", "00000", "") + " " + j.Tostring ();
-//                                    }
-//                                }
-//                                GateWay.sidObject tmp = HDLSysPF.UpdateSidAttributesToDeviceList (onlineDevice, tmpSid.name, sOid, j, BigType, SmallType, true);
-//                                tmpSid.attributes = tmp.attributes;//UpdateSidAttributesToDeviceList(onlineDevice.DeviceType, sOid, j, BigType, SmallType, ref spk);
-//                                tmpSid.spk = tmp.spk;
-//                                tmpResult.Add (tmpSid);
-//                            }
-//                        }
-//                    }
-//                }
-//                return tmpResult;
-//            } catch (Exception) {
-//                return tmpResult;
-//                //throw;
-//            }
-//        }
-
-//        /// <summary>
-//        /// 
-//        /// </summary>
-//        /// <param name="homeId"></param>
-//        /// <param name="onlineDevices"></param>
-//        /// <param name="gatewayId"></param>
-//        /// <param name="currentProject"></param>
-//        public void ConvertOidListToIotStruct (string homeId, List<Common> onlineDevices, string gatewayId, ref IotCloud currentProject)
-//        {
-//            try {
-//                //step 1 ;鎶撴崲绫诲瀷
-//                Sids functionList = currentProject.functions;
-//                List<Sid> tmpFunction = new List<Sid> ();
-
-//                //step 2 杞崲绫诲瀷
-//                Oids tmp = ConvertToOidListToIotCloud (onlineDevices, ref tmpFunction);
-//                if (currentProject.modules == null || currentProject.modules.devices == null || currentProject.modules.devices.Count == 0) currentProject.modules = tmp;
-//                else {
-//                    foreach (Oid tmpModule in tmp.devices) {
-//                        Oid tmpFind = currentProject.modules.devices.Find (P => P.mac.Equals (tmpModule.mac));
-//                        if (tmpFind == null) currentProject.modules.devices.Add (tmpModule);
-//                    }
-//                }
-//                tmp.homeId = homeId;
-
-//                //涓婁紶鍔熻兘鍒楄〃
-//                #region
-//                //if (functionList == null)
-//                //{
-//                functionList = new Sids ();
-//                functionList.devices = new List<Sid> ();
-//                functionList.devices = tmpFunction;
-//                //}
-//                functionList.homeId = homeId;
-//                functionList.gatewayId = gatewayId;
-//                currentProject.modules = tmp;
-//                currentProject.functions = functionList;
-//                #endregion
-
-//            } catch (Exception ex) {
-//                //MessageBox.Show (ex.Tostring ());
-//                //throw;
-//            }
-//        }
-
-//        /// <summary>
-//        /// 
-//        /// </summary>
-//        /// <param name="homeId"></param>
-//        /// <param name="onlineDevices"></param>
-//        /// <param name="gatewayId"></param>
-//        /// <param name="currentProject"></param>
-//        public void ConvertOidListToIotStruct (string homeId, List<Common> onlineDevices, string gatewayId, ref IotCloud currentProject)
-//        {
-//            try {
-//                //step 1 杞崲绫诲瀷
-//                Sids functionList = currentProject.functions;
-//                List<Sid> tmpFunction = new List<Sid> ();
-
-//                //step 2 杞崲绫诲瀷
-//                Oids tmp = ConvertToOidListToIotCloud (onlineDevices, ref tmpFunction);
-//                if (currentProject.modules == null || currentProject.modules.devices == null || currentProject.modules.devices.Count == 0) currentProject.modules = tmp;
-//                else {
-//                    foreach (Oid tmpModule in tmp.devices) {
-//                        Oid tmpFind = currentProject.modules.devices.Find (P => P.mac.Equals (tmpModule.mac));
-//                        if (tmpFind == null) currentProject.modules.devices.Add (tmpModule);
-//                    }
-//                }
-//                tmp.homeId = homeId;
-
-//                //涓婁紶鍔熻兘鍒楄〃
-//                #region
-//                //if (functionList == null)
-//                //{
-//                functionList = new Sids ();
-//                functionList.devices = new List<Sid> ();
-//                functionList.devices = tmpFunction;
-//                //}
-//                functionList.homeId = homeId;
-//                functionList.gatewayId = gatewayId;
-//                currentProject.modules = tmp;
-//                currentProject.functions = functionList;
-//                #endregion
-
-//            } catch (Exception ex) {
-//                //MessageBox.Show (ex.Tostring ());
-//                //throw;
-//            }
-//        }
-
-//        /// <summary>
-//        /// 鐢熸垚璁惧Oid
-//        /// </summary>
-//        /// <param name="iDeviceType"></param>
-//        /// <returns></returns>
-//        public string FormingNewOid (int iDeviceType)
-//        {
-//            string sOid = "";
-//            try {
-//                string sOidBeginsWith = "000101";//鍘傚晢 + 閫氳鏂瑰紡
-
-//                long sTimeSp = HDLSysPF.ConvertDateTimeLong ();
-//                string sTimeSpan = "";
-//                GateWay.ConvertIntToByteArray (sTimeSp, ref sTimeSpan);
-
-//                if (sTimeSpan.Length != 8) return sOid;
-//                HDLUDP.TimeBetwnNext (10);
-//                sOid = sOidBeginsWith + sTimeSpan;
-//                if (iDeviceType == 00
-//                    || DimmerDeviceTypeList.HDLDimmerDeviceTypeList.Contains (iDeviceType)
-//                 || DMXDeviceTypeList.HDLDMXDeviceTypeList.Contains (iDeviceType))//璋冨厜鍣� 20200730绫�
-//                {
-//                    sOid += "01";
-//                } else if (RelayDeviceTypeList.HDLRelayDeviceTypeList.Contains (iDeviceType))//缁х數鍣ㄧ被
-//                  {
-//                    sOid += "02";
-//                } else if (CurtainDeviceType.HDLCurtainModuleDeviceType.Contains (iDeviceType))//閬槼绫伙紙绐楀笜锛�
-//                  {
-//                    sOid += "03";
-//                } else if (HVACModuleDeviceTypeList.HDLHVACModuleDeviceTypeLists.Contains (iDeviceType) || FloorheatingDeviceTypeList.HDLFloorHeatingDeviceType.Contains (iDeviceType))//鎭掓俯鍣紙绌鸿皟锛�
-//                  {
-//                    sOid += "12";
-//                } else if (AudioDeviceTypeList.AudioBoxDeviceTypeList.Contains (iDeviceType)) {
-//                    sOid += "10";
-//                } else if (Eightin1DeviceTypeList.HDL8in1DeviceType.Contains (iDeviceType)
-//                      || Sevenin1DeviceTypeList.HDL7in1DeviceType.Contains (iDeviceType)
-//                      || Twelvein1DeviceTypeList.HDL12in1DeviceType.Contains (iDeviceType))//浼犳劅鍣ㄧ被
-//                  {
-//                    sOid += "04";
-//                } else {
-//                    sOid += "07"; //缃戝叧浜у搧
-//                }
+namespace Shared
+{
+    /// <summary>
+    /// HDLLink鍗忚 宸ュ叿绫�
+    /// </summary>
+    public class HDLLinkUtlis
+    {
+        #region 鈻� Current___________________________
+        /// <summary>
+        /// 閫氱敤鏂规硶
+        /// </summary>
+        private static HDLLinkUtlis m_Current = null;
+        /// <summary>
+        /// 閫氱敤鏂规硶
+        /// </summary>
+        public static HDLLinkUtlis Current {
+            get {
+                if (m_Current == null) {
+                    m_Current = new HDLLinkUtlis ();
+                }
+                return m_Current;
+            }
+        }
+        #endregion
 
 
-//                return sOid;
-//            } catch {
-//                return sOid;
-//            }
-//        }
+       
 
-//        /// <summary>
-//        /// 鐢熸垚鍔熻兘璁惧Sid
-//        /// </summary>
-//        /// <param name="iDeviceType"></param>
-//        /// <param name="sOid"></param>
-//        /// <param name="iChnId"></param>
-//        /// <param name="isUseE548ReturnBigSmallType"></param>
-//        /// <param name="BigType"></param>
-//        /// <param name="SmallType"></param>
-//        /// <returns></returns>
-//        public string FormingNewSid (int iDeviceType, string sOid, int iChnId, bool isUseE548ReturnBigSmallType, byte BigType, byte SmallType)
-//        {
-//            if (sOid == null || sOid == "") return "";
-//            try {
-//                string sSid = "";
-//                if (DimmerDeviceTypeList.HDLDimmerDeviceTypeList.Contains (iDeviceType)) {
-//                    if (DimmerDeviceTypeList.DALIDimmerDeviceTypeLists.Contains (iDeviceType)) {
-//                        BigType = 1;
-//                        SmallType = 7;
-//                        sSid += "0203";
-//                    } else {
-//                        sSid += "0202";
-//                    }
-//                } else if (RelayDeviceTypeList.HDLRelayDeviceTypeList.Contains (iDeviceType)) {
-//                    sSid += "0201";
-//                } else if (CurtainDeviceType.HDLCurtainModuleDeviceType.Contains (iDeviceType)) {
+        /// <summary>
+        /// 
+        /// </summary>
+        /// <returns></returns>
+        public bool UploadOidAndSidList ()
+        {
+            var res = false;
+            try {
+                IotCloud currentProject = new IotCloud ();
+                var list = GetAllDeviceList ();
+                ConvertOidListToIotStruct (UserConfig.Instance.CurrentRegion.Id, UserConfig.Instance.HomeGateway.gatewayId, list, ref currentProject);
+                Utlis.WriteLine ("list: " + list.Count + "currentProject : " + currentProject.functions.devices.Count);
 
-//                    if (CurtainDeviceType.NormalMotorCurtainDeviceType.Contains (iDeviceType) || (iDeviceType == 9700)) //鎵�鏈夊紑鍚堝笜 //0 2020 05 24鍒涙槑寮�鍚堝笜
-//                    {
-//                        sSid += "0303";
-//                    } else if (CurtainDeviceType.RollerCurtainDeviceType.Contains (iDeviceType)
-//                      || (iDeviceType == 9701))//鎵�鏈� 鍗峰笜鎺у埗鍣� 
-//                      {
-//                        sSid += "0304";
-//                    } else {
-//                        sSid += "0301";
-//                    }
-//                } else if (HVACModuleDeviceTypeList.HDLHVACModuleDeviceTypeLists.Contains (iDeviceType)) {
-//                    sSid += "0401";
-//                } else if (Eightin1DeviceTypeList.HDL8in1DeviceType.Contains (iDeviceType)
-//                      || Sevenin1DeviceTypeList.HDL7in1DeviceType.Contains (iDeviceType)
-//                      || HaikeSensorDeviceTypeList.HaikeSensorDeviceType.Contains (iDeviceType)
-//                      || Twelvein1DeviceTypeList.HDL12in1DeviceType.Contains (iDeviceType)
-//                      || Rs232DeviceTypeList.HDLRs232DeviceType.Contains (iDeviceType)) {
-//                    if (BigType == 19 && SmallType == 0) {
-//                        sSid += "1301";
-//                    } else if (BigType == 5 && SmallType == 0) {
-//                        sSid += "0519";
-//                    } else {
-//                        sSid += BigType.Tostring ("X2") + SmallType.Tostring ("X2");
-//                    }
-//                } else if (FloorheatingDeviceTypeList.HDLFloorHeatingDeviceType.Contains (iDeviceType)) {
-//                    sSid += "0402";
-//                } else if (DMXDeviceTypeList.HDLDMXDeviceTypeList.Contains (iDeviceType)) {
-//                    sSid += "0204";
-//                } else if (DimmerDeviceTypeList.DALIDimmerDeviceTypeLists.Contains (iDeviceType)) {
-//                    sSid += "0203";
-//                } else if (AudioDeviceTypeList.AudioBoxDeviceTypeList.Contains (iDeviceType)) {
-//                    sSid += "0901";
-//                }
-//                string sTmpWithE548 = sSid;
-//                sSid = sOid + sSid + iChnId.Tostring ("X4");
-//                if (isUseE548ReturnBigSmallType) {
-//                    sSid += BigType.Tostring ("X2") + SmallType.Tostring ("X2");
-//                } else {
-//                    sSid += sTmpWithE548;
-//                }
+                var revertObj = HttpServerRequest.Current.UploadDeviceOidList (currentProject.modules);
+                if(revertObj.Code == StateCode.SUCCESS) {
+                    var revertObj2 = HttpServerRequest.Current.UploadDeviceSidList (currentProject.functions);
+                    if (revertObj2.Code == StateCode.SUCCESS) {
+                        res = true;
+                    } else {
+                        IMessageCommon.Current.ShowErrorInfoAlter (revertObj2.Code);
+                    }
+                } else {
+                    IMessageCommon.Current.ShowErrorInfoAlter (revertObj.Code);
+                }
+            } catch {
 
-//                return sSid;
-//            } catch {
-//                return "";
-//            }
-//        }
+            }
+            return res;
+        }
 
-//    }
+        /// <summary>
+        /// 
+        /// </summary>
+        /// <returns></returns>
+        public List<Common> GetAllDeviceList ()
+        {
+            List<Common> TargetList = new List<Common> ();
+
+            //鎵惧嚭闇�瑕佹樉绀虹殑璁惧
+            var filesList = FileUtils.ReadFiles ().FindAll ((obj) => {
+                string [] str = obj.Split ('_');
+                return obj.StartsWith ("Equipment_") && str.Length == 5;
+            });
+            var localEquipments = filesList.FindAll ((obj) => {
+                string typeString = obj.Split ('_') [1];
+                return (
+                #region light
+                    typeString.ToString () == DeviceType.LightCCT.ToString () ||
+                typeString.ToString () == DeviceType.LightRGB.ToString () ||
+                typeString.ToString () == DeviceType.LightDALI.ToString () ||
+                typeString.ToString () == DeviceType.LightRGBW.ToString () ||
+                typeString.ToString () == DeviceType.LightLogic.ToString () ||
+                typeString.ToString () == DeviceType.LightSwitch.ToString () ||
+                typeString.ToString () == DeviceType.LightDimming.ToString () ||
+                typeString.ToString () == DeviceType.LightMixSwitch.ToString () ||
+                typeString.ToString () == DeviceType.LightRGBandCCT.ToString () ||
+                typeString.ToString () == DeviceType.LightMixDimming.ToString () ||
+                typeString.ToString () == DeviceType.LightEnergySwitch.ToString () ||
+                typeString.ToString () == DeviceType.LightEnergySocket.ToString () ||
+                typeString.ToString () == DeviceType.LightSwitchSocket.ToString ()
+                || typeString.ToString () == DeviceType.DMX48.ToString ()
+                #endregion
+                #region light
+                    || typeString.ToString () == DeviceType.SensorCH4.ToString () ||
+                typeString.ToString () == DeviceType.SensorCO2.ToString () ||
+                typeString.ToString () == DeviceType.SensorLPG.ToString () ||
+                typeString.ToString () == DeviceType.SensorCOH2.ToString () ||
+                typeString.ToString () == DeviceType.SensorPM25.ToString () ||
+                typeString.ToString () == DeviceType.SensorTVOC.ToString () ||
+                typeString.ToString () == DeviceType.SensorPower.ToString () ||
+                typeString.ToString () == DeviceType.SensorSmoke.ToString () ||
+                typeString.ToString () == DeviceType.SensorWater.ToString () ||
+                typeString.ToString () == DeviceType.SensorWeight.ToString () ||
+                typeString.ToString () == DeviceType.SensorCurrent.ToString () ||
+                typeString.ToString () == DeviceType.SensorVoltage.ToString ()
+                || typeString.ToString () == DeviceType.SensorRainfall.ToString ()
+                || typeString.ToString () == DeviceType.SensorVelocity.ToString ()
+                || typeString.ToString () == DeviceType.SensorMenciAndwindowMagnetic.ToString ()
+                || typeString.ToString () == DeviceType.SensorMobileDetection.ToString ()
+                || typeString.ToString () == DeviceType.SensorLiquidPressure.ToString ()
+                || typeString.ToString () == DeviceType.SensorVibration.ToString ()
+                || typeString.ToString () == DeviceType.SensorLiquidFlow.ToString ()
+                || typeString.ToString () == DeviceType.SensorLiquidDepth.ToString ()
+                || typeString.ToString () == DeviceType.SensorTemperature.ToString ()
+                || typeString.ToString () == DeviceType.SensorHeightLength.ToString ()
+                || typeString.ToString () == DeviceType.SensorIllumination.ToString ()
+                || typeString.ToString () == DeviceType.SensorWindPressure.ToString ()
+                || typeString.ToString () == DeviceType.SensorHumidity.ToString ()
+                #endregion
+                #region curtain
+                    || typeString.ToString () == DeviceType.CurtainModel.ToString ()
+                || typeString.ToString () == DeviceType.CurtainRoller.ToString ()
+                || typeString.ToString () == DeviceType.CurtainTrietex.ToString ()
+                #endregion
+                #region ac
+                    || typeString.ToString () == DeviceType.ACPanel.ToString ()
+                || typeString.ToString () == DeviceType.ACDevice.ToString ()
+                || typeString.ToString () == DeviceType.ACInfrared.ToString ()
+                || typeString.ToString () == DeviceType.ACCoolmaster.ToString ()
+                || typeString.ToString () == DeviceType.CustomAC.ToString ()
+                || typeString.ToString () == DeviceType.HVAC.ToString ()
+                #endregion
+                #region foolheat
+                    || typeString.ToString () == DeviceType.FoolHeat.ToString ()
+                || typeString.ToString () == DeviceType.FoolHeatPanel.ToString ()
+                #endregion
+                #region 
+                    || typeString.ToString () == DeviceType.InfraredMode.ToString ()
+                || typeString.ToString () == DeviceType.DoorLock.ToString ()
+                || typeString.ToString () == DeviceType.FanModule.ToString ()
+                || typeString.ToString () == DeviceType.FreshAir.ToString ()
+                || typeString.ToString () == DeviceType.InfraredTV.ToString ()
+                || typeString.ToString () == DeviceType.UniversalDevice.ToString ()
+                || typeString.ToString () == DeviceType.MusicModel.ToString ()
+                || typeString.ToString () == DeviceType.SecurityModule.ToString ()
+                || typeString.ToString () == DeviceType.LogicModule.ToString ()
+                || typeString.ToString () == DeviceType.SecurityPanel.ToString ()
+                #endregion
+                    );
+            });
+
+            foreach (string deviceFilePath in localEquipments) {
+                try {
+                    string [] str = deviceFilePath.Split ('_');
+
+                    var commonBytes = FileUtils.ReadFile (deviceFilePath);
+                    if (commonBytes.Length == 0) {
+                        Utlis.WriteLine ("length loss");
+                        continue;
+                    }
+                    if (commonBytes.Length == 1) {
+                        Utlis.WriteLine ("length loss 1");
+                        continue;
+                    }
+
+                    Common commonDevice = Newtonsoft.Json.JsonConvert.DeserializeObject<Common> (System.Text.Encoding.UTF8.GetString (commonBytes));
+
+                    if (commonDevice == null) {
+                        continue;
+                    }
+
+                    TargetList.Add (commonDevice);
+                } catch {
+
+                }
+            }
+            return TargetList;
+        }
 
 
-//    [Serializable]
-//    public class Sids : BaseCloudFeedback
-//    {
-//        public string homeId { get; set; }
-//        public string gatewayId { get; set; }
-//        public List<Sid> devices { get; set; }
-//    }
+        /// <summary>
+        /// 灏嗗湪绾胯澶囪浆鎹㈡垚sid + 灞炴�у垪琛�
+        /// </summary>
+        /// <param name="moduleCommon">妯″潡璁惧</param>
+        /// <returns></returns>
+        public List<Sid> ConvertToSidListToIotCloud (string sOid, Common loopCommon)
+        {
+            List<Sid> sidList = new List<Sid> ();
+            try {
+                Sid tmpSid = new Sid ();
+                tmpSid.sid = FormingNewSid (sOid, loopCommon);
+                tmpSid.oid = sOid;
+                tmpSid.name = loopCommon.Name;
 
-//    [Serializable]
-//    public class BaseCloudFeedback
-//    {
-//        public int code { get; set; }
-//        public string timestamp { get; set; }
-//        public bool isSuccess { get; set; }
-//        public string message { get; set; }
-//    }
+                SidObject tmp = UpdateSidAttributesToDeviceList (loopCommon, sOid);
+                tmpSid.attributes = tmp.attributes;
+                //UpdateSidAttributesToDeviceList(onlineDevice.DeviceType, sOid, j, BigType, SmallType, ref spk);
+                tmpSid.spk = tmp.spk;
+                sidList.Add (tmpSid);
+
+                return sidList;
+            } catch (Exception) {
+                return sidList;
+            }
+        }
+
+        /// <summary>
+        /// 澶勭悊鏈湴鏁版嵁锛岃浆鎹㈢敓鎴怬id鍜孲id鍒楄〃
+        /// </summary>
+        /// <param name="homeId"></param>
+        /// <param name="onlineDevices"></param>
+        /// <param name="gatewayId"></param>
+        /// <param name="currentProject"></param>
+        public void ConvertOidListToIotStruct (string homeId, string gatewayId, List<Common> loopCommonList, ref IotCloud currentProject)
+        {
+            try {
+                //step 1 杞崲绫诲瀷
+                Sids functionList = new Sids();
+                List<Sid> tmpFunction = new List<Sid> ();
+
+                //step 2 杞崲鐢熸垚Oids鍒楄〃鍜宻id 璁惧鍒楄〃
+                Oids mOidList = ConvertToOidListToIotCloud (loopCommonList, ref tmpFunction);
+                mOidList.homeId = homeId;
+
+                //step 3
+                functionList.devices = new List<Sid> ();
+                functionList.homeId = homeId;
+                functionList.gatewayId = gatewayId;
+                if (tmpFunction != null) {
+                    functionList.devices = tmpFunction;
+                }
+              
+                currentProject.modules = mOidList;
+                currentProject.functions = functionList;
+
+            } catch (Exception ex) {
+                //MessageBox.Show (ex.Tostring ());
+                //throw;
+            }
+        }
+
+        /// <summary>
+        /// 杞崲绫诲瀷鍦ㄧ嚎璁惧鍒楄〃杞琌ID鍒楄〃 鍙湪涓婁紶鎴栬�呬笅杞芥椂浣跨敤
+        /// </summary>
+        /// <param name="onlineDevices"></param>
+        /// <returns></returns>
+        public Oids ConvertToOidListToIotCloud (List<Common> loopCommonListlolooloopl, ref List<Sid> functionLists)
+        {
+            Oids mOidsList = new Oids ();
+            try {
+                mOidsList.devices = new List<Oid> ();
+                //HDLSysPF.IniDeviceChannelRemark (); //鏁寸悊鍏ㄩ儴璁惧澶囨敞鍒扮紦瀛樺垪琛�
+                foreach (Common tmp in loopCommonListlolooloopl) {
+                    //1.deviceType鏍囪瘑 浜戠鏄痠nt绫诲瀷 
+                    var deviceType = ((int)tmp.Type);
+                    //2.addresses鏍囪瘑 瀛愮綉鍙枫�佽澶囧彿 
+                    var addresses = string.Format ("{0}{1}", tmp.SubnetID.ToString ("X2"), tmp.DeviceID.ToString ("X2"));
+                    //3.鍒ゆ柇褰撳墠鍥炶矾璁惧涔嬪墠鏄惁鐢熸垚杩囩浉鍚屾ā鍧楃殑oid锛屽瓨鍦ㄥ垯鍙栦箣鍓嶇殑oid 娌℃湁鍒欏垱寤烘柊澧炴柊鐨刼id
+                    var deviceOid = mOidsList.devices.Find (o => o.deviceType == deviceType && o.addresses == addresses);
+                    if (deviceOid == null) {
+                        //3.1娌℃湁鍒欏垱寤烘柊澧炴柊鐨刼id
+                        Oid tmpOid = new Oid ();
+                        tmpOid.protocolType = "bus";
+                        tmpOid.device_name = tmp.Type.ToString ();
+                        tmpOid.oid = FormingNewOid (tmp.Type);
+                        tmpOid.addresses = addresses;
+                        tmpOid.device_model = tmp.Type.ToString ();
+                        tmpOid.fw_version = "";
+                        tmpOid.deviceType = deviceType;
+                        tmpOid.hw_info = "";
+                        tmpOid.mac = tmp.MAC;
+                        mOidsList.devices.Add (tmpOid);
+
+                        functionLists.AddRange (ConvertToSidListToIotCloud (tmpOid.oid, tmp));
+
+                        Utlis.WriteLine ("鏂扮殑妯″潡锛屾柊鐨勭殑OID锛�" + tmpOid.addresses + " deviceType:" + tmpOid.deviceType);
+                    } else {
+                        //3.2瀛樺湪鍒欏彇涔嬪墠鐨刼id 
+                        functionLists.AddRange (ConvertToSidListToIotCloud (deviceOid.oid, tmp));
+                        Utlis.WriteLine ("鐩稿悓鐨勬ā鍧楋紝鍙栦箣鍓嶇殑OID锛�" + deviceOid.addresses + " deviceType:" + deviceOid.deviceType);
+                    }
+
+                }
+                return mOidsList;
+            } catch (Exception ex) {
+                return mOidsList;
+            }
+        }
+
+        ///// <summary>
+        ///// 
+        ///// </summary>
+        ///// <param name="homeId"></param>
+        ///// <param name="onlineDevices"></param>
+        ///// <param name="gatewayId"></param>
+        ///// <param name="currentProject"></param>
+        //public void ConvertOidListToIotStruct (string homeId, List<Common> onlineDevices, string gatewayId, ref IotCloud currentProject)
+        //{
+        //    try {
+        //        //step 1 杞崲绫诲瀷
+        //        Sids functionList = currentProject.functions;
+        //        List<Sid> tmpFunction = new List<Sid> ();
+
+        //        //step 2 杞崲绫诲瀷
+        //        Oids tmp = ConvertToOidListToIotCloud (onlineDevices, ref tmpFunction);
+        //        if (currentProject.modules == null || currentProject.modules.devices == null || currentProject.modules.devices.Count == 0) currentProject.modules = tmp;
+
+        //        else {
+        //            foreach (Oid tmpModule in tmp.devices) {
+        //                Oid tmpFind = currentProject.modules.devices.Find (P => P.mac.Equals (tmpModule.mac));
+        //                if (tmpFind == null) currentProject.modules.devices.Add (tmpModule);
+        //            }
+        //        }
+        //        tmp.homeId = homeId;
+
+        //        //涓婁紶鍔熻兘鍒楄〃
+        //        #region
+        //        //if (functionList == null)
+        //        //{
+        //        functionList = new Sids ();
+        //        functionList.devices = new List<Sid> ();
+        //        functionList.devices = tmpFunction;
+        //        //}
+        //        functionList.homeId = homeId;
+        //        functionList.gatewayId = gatewayId;
+        //        currentProject.modules = tmp;
+        //        currentProject.functions = functionList;
+        //        #endregion
+
+        //    } catch (Exception ex) {
+        //        //MessageBox.Show (ex.Tostring ());
+        //        //throw;
+        //    }
+        //}
+
+        /// <summary>
+        /// 鐢熸垚璁惧Oid
+        /// </summary>
+        /// <param name="iDeviceType"></param>
+        /// <returns></returns>
+        public string FormingNewOid (DeviceType deviceType)
+        {
+            string sOid = "";
+            try {
+                //1.鐢熸垚 鍘傚晢 + 閫氳鏂瑰紡 
+                string sOidBeginsWith = "000101";//鍘傚晢 + 閫氳鏂瑰紡
+                //2.鐢熸垚浜у搧鏃堕棿鎴�
+                long sTimeSp = ConvertDateTimeLong (); //浠�2020骞�1鏈�1鏃ョ畻鍑虹殑鏃堕棿鎴�0.1s涓哄崟浣�
+                string sTimeSpan = "";
+                ConvertIntToByteArray (sTimeSp, ref sTimeSpan);
+                if (sTimeSpan.Length != 8) return sOid;
+                //寤惰繜10ms
+
+                //3.鐢熸垚浜у搧绫诲埆
+                var productType = GetProductType (deviceType);
+                sOid = sOidBeginsWith + sTimeSpan + productType;
+
+                return sOid;
+            } catch {
+                return sOid;
+            }
+        }
+
+        /// <summary>
+        /// 鑾峰彇浜у搧绫诲埆
+        /// 浜у搧绫诲埆鐩墠娌℃湁瑙勮寖鐨勬枃妗�,娌℃湁纭畾鐨勬爣鍑�
+        /// 鏆傛椂鍜宐uspro杞欢瑙勫垯涓�鑷�
+        ///
+        ///鏂囨。瑙勫垯锛屼絾鏄笉鏄纭殑鐗堟湰
+        //浜у搧绫诲埆 1byte
+        //缂栧彿   鎻忚堪
+        //01	璋冨厜鍣�
+        //02	缁х數鍣�
+        //03	骞叉帴鐐规ā鍧�
+        //04	浼犳劅鍣�
+        //05	闈㈡澘
+        //06	RCU
+        //07	缃戝叧
+        //08	绾㈠鍙戝皠
+        //09	Android灞�
+        //10	鍦烘櫙
+        //11	闊充箰鎾斁鍣�
+        //12	232/485杞崲鍣�
+        //21	鑷姩鍖�
+        //22	瀹夐槻闃插尯
+        //14	绐楀笜妯″潡
+        //15	HVAC
+        //16	鍦扮儹妯″潡
+        /// </summary>
+        /// <param name="deviceType"></param>
+        /// <returns></returns>
+        public string GetProductType (DeviceType deviceType)
+        {
+            string productType = "";
+            switch (deviceType) {
+            case DeviceType.LightDimming:
+            case DeviceType.LightCCT:
+            case DeviceType.LightDALI:
+            case DeviceType.LightRGB:
+            case DeviceType.LightRGBW:
+            case DeviceType.LightLogic:
+            case DeviceType.LightRGBandCCT:
+            case DeviceType.DMX48:
+                productType = "01";//01	璋冨厜鍣�
+                break;
+            case DeviceType.LightSwitch:
+            case DeviceType.LightEnergySwitch:
+            case DeviceType.LightEnergySocket:
+            case DeviceType.LightSwitchSocket:
+            case DeviceType.LightMixSwitch:
+                productType = "02";//02 缁х數鍣ㄧ被
+                break;
+            case DeviceType.CurtainModel:
+            case DeviceType.CurtainRoller:
+            case DeviceType.CurtainTrietex:
+                productType = "03";//03	閬槼绫伙紙绐楀笜锛�
+                break;
+            case DeviceType.SensorWindSpeed:
+                productType = "04";//04	浼犳劅鍣級
+                break;
+            case DeviceType.OnePortWirelessFR:
+            case DeviceType.OnePortBus:
+            case DeviceType.RCU:
+            case DeviceType.SuperWireless:
+            case DeviceType.OnePortMqttFR:
+                productType = "07";//07	缃戝叧绫�
+                break;
+            case DeviceType.ACPanel:
+            case DeviceType.ACDevice:
+            case DeviceType.ACInfrared:
+            case DeviceType.ACCoolmaster:
+            case DeviceType.CustomAC:
+            case DeviceType.HVAC:
+            case DeviceType.FoolHeat:
+            case DeviceType.FoolHeatPanel:
+                productType = "12";//12 鎭掓俯鍣紙绌鸿皟銆佸湴鐑級
+                break;
+            case DeviceType.MusicModel:
+            case DeviceType.MusicPanel:
+            case DeviceType.MusicA31:
+                productType = "0B";
+                break;
+            default:
+                productType = "00";
+                break;
+            }
+
+            return productType;
+        }
 
 
-//    [Serializable]
-//    public class Oids : BaseCloudFeedback
-//    {
-//        public string homeId { get; set; }
-//        public string gatewayId { get; set; }
-//        public List<Oid> devices { get; set; }
-//    }
 
-//    [Serializable]
-//    public class Oid
-//    {
-//        public string protocolType { get; set; }
-//        public string device_name { get; set; }
-//        public string oid { get; set; }
-//        public string addresses { get; set; }
-//        public string device_model { get; set; }
+        /// <summary>
+        /// 鑾峰彇鐢熸垚鐗╃悊妯″瀷鍙傛暟
+        /// 2021-01-22 鐩墠鐗╂ā杩樹笉瀹屽杽
+        /// </summary>
+        /// <param name="deviceType"></param>
+        /// <returns></returns>
+        public string GetPhysicalModelType (DeviceType deviceType)
+        {
+            string productType = "";
+            switch (deviceType) {
+            case DeviceType.LightEnergySwitch:
+                productType = "0101";
+                break;
+            case DeviceType.LightEnergySocket:
+            case DeviceType.LightSwitchSocket:
+                productType = "0102";
+                break;
+            case DeviceType.LightSwitch:
+            case DeviceType.LightMixSwitch:
+                productType = "0201";
+                break;
+            case DeviceType.LightDimming:
+                productType = "0202";
+                break;
+            case DeviceType.LightCCT:
+            case DeviceType.LightDALI:
+                productType = "0203";
+                break;
+            case DeviceType.LightRGB:
+            case DeviceType.LightRGBW:
+            case DeviceType.LightLogic:
+            case DeviceType.LightRGBandCCT:
+            case DeviceType.DMX48:
+                productType = "0204";
+                break;
+            //绐楀笜
+            case DeviceType.CurtainModel:
+                productType = "0301";
+                break;
+            case DeviceType.CurtainTrietex:
+                productType = "0303";
+                break;
+            case DeviceType.CurtainRoller:
+                productType = "0304";
+                break;
+            case DeviceType.ACPanel:
+            case DeviceType.ACDevice:
+            case DeviceType.ACInfrared:
+            case DeviceType.ACCoolmaster:
+            case DeviceType.CustomAC:
+            case DeviceType.HVAC:
+                productType = "0701";
+                break;
+            case DeviceType.FoolHeat:
+            case DeviceType.FoolHeatPanel:
+                productType = "0801";
+                break;
+            case DeviceType.MusicModel:
+            case DeviceType.MusicPanel:
+            case DeviceType.MusicA31:
+                productType = "0901";
+                break;
+            case DeviceType.FanModule:
+                productType = "1001";
+                break;
+            default:
+                productType = ((int)deviceType).ToString ("X4");
+                break;
+            }
 
-//        public string fw_version { get; set; }
-//        public string hw_info { get; set; }
-//        public string mac { get; set; }
-//        public string deviceType { get; set; }
-//    }
+            return productType;
+        }
 
-//    [Serializable]
-//    public class Sid
-//    {
-//        public string sid { get; set; }
-//        public string name { get; set; }
-//        public string[] uids { get; set; }
-//        public string spk { get; set; }
-
-//        public string oid { get; set; }  //璁惧妯″潡鍦板潃
-//        public string omodel { get; set; }    //鍨嬪彿
-//        public List<Function> attributes { get; set; } //灞炴�у垪琛�
-//    }
+                    
 
 
-//    [Serializable]
-//    public class Function
-//    {
-//        //public string name { get; set; }
-//        public string key { get; set; }
-//        public List<string> value { get; set; }
-//        public int max { get; set; }
-//        public int min { get; set; }
-//        public string data_type { get; set; }
-//    }
+        /// <summary>
+        /// 鐢熸垚鍔熻兘璁惧Sid
+        /// </summary>
+        /// <param name="iDeviceType"></param>
+        /// <param name="sOid"></param>
+        /// <param name="iChnId"></param>
+        /// <param name="isUseE548ReturnBigSmallType"></param>
+        /// <param name="BigType"></param>
+        /// <param name="SmallType"></param>
+        /// <returns></returns>
+        public string FormingNewSid (string sOid, Common loopCommon)
+        {
+            if (sOid == null || sOid == "") return "";
+            try {
+                //鐗╂ā鍨嬬被+閫氶亾鍙�+澶у皬绫诲埆
+                string sSid = "";
+                //1.鐗╂ā鍨嬬被
+                string mPhysicalModelType = GetPhysicalModelType (loopCommon.Type);
+                //2.閫氶亾鍙�
+                string loopIDStr = loopCommon.LoopID.ToString ("X4");
+                //3.澶у皬绫诲埆
+                string bigMinStr = loopCommon.BigClass.ToString ("X2") + loopCommon.MinClass.ToString ("X2");
+                //4.鎷兼帴
+                sSid = sOid + mPhysicalModelType + loopIDStr + bigMinStr;
+                return sSid;
+            } catch {
+                return "";
+            }
+        }
 
-//}
+
+        /// <summary>
+        /// 鐢熸垚SPK灞炴��
+        /// </summary>
+        /// <param name="loopCommon"></param>
+        /// <param name="iChnRemark"></param>
+        /// <param name="sOid"></param>
+        /// <param name="iChnId"></param>
+        /// <param name="BigType"></param>
+        /// <param name="SmallType"></param>
+        /// <param name="isUseE548ReturnBigSmallType"></param>
+        /// <returns></returns>
+        public SidObject UpdateSidAttributesToDeviceList (Common loopCommon, string sOid)
+        {
+            SidObject tmp = new SidObject ();
+            try {
+                string sSid = FormingNewSid (sOid, loopCommon);
+                tmp.oid = sOid;
+                tmp.sid = sSid;
+                tmp.name = loopCommon.Name;
+                tmp.attributes = new List<FunctionSid> ();
+                tmp.omodel = loopCommon.Type.ToString ();
+                //缁х數鍣ㄥ紑鍏崇被
+                if (loopCommon.Type == DeviceType.LightSwitch
+                    || loopCommon.Type == DeviceType.LightEnergySwitch
+                    || loopCommon.Type == DeviceType.LightEnergySocket
+                    || loopCommon.Type == DeviceType.LightSwitchSocket
+                    || loopCommon.Type == DeviceType.LightMixSwitch) {
+                    tmp.spk = "light.switch";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+                } else if (loopCommon.Type == DeviceType.LightDimming
+                    || loopCommon.Type == DeviceType.LightCCT
+                    || loopCommon.Type == DeviceType.LightDALI) {
+                    //璋冨厜绫�
+                    tmp.spk = "light.dimming";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+
+                    #region brightness
+                    FunctionSid tempFunction1 = new FunctionSid ();
+                    tempFunction1.key = "brightness";
+                    tempFunction1.data_type = "integer";
+                    tempFunction1.value = new List<string> ();
+
+                    tempFunction1.max = 100;
+                    tempFunction1.min = 0;
+                    tmp.attributes.Add (tempFunction1);
+                    #endregion
+
+                    #region fade_time
+                    FunctionSid tempFunction3 = new FunctionSid ();
+                    tempFunction3.key = "fade_time";
+                    tempFunction3.data_type = "integer";
+                    tempFunction3.value = new List<string> ();
+                    //tempFunction1.value.Add("percent");
+                    //for (int iPercent = 0; iPercent <= 100; iPercent++)
+                    //{
+                    //    tempFunction1.value.Add(iPercent.ToString());
+                    //}
+                    tempFunction3.max = 100;
+                    tempFunction3.min = 0;
+                    tmp.attributes.Add (tempFunction3);
+                    #endregion
+
+                    if (loopCommon.Type == DeviceType.LightCCT || loopCommon.Type == DeviceType.LightDALI)//鑹叉俯绫诲埆
+                    {
+                        tmp.spk = "light.cct";
+                        #region cct
+                        FunctionSid tempFunction2 = new FunctionSid ();
+                        tempFunction2.key = "cct";
+                        tempFunction2.data_type = "integer";
+                        tempFunction2.value = new List<string> ();
+                        //tempFunction2.value.Add("warm light ");
+                        //tempFunction2.value.Add("cold light ");
+                        tempFunction2.max = 65535;
+                        tempFunction2.min = 0;
+                        tmp.attributes.Add (tempFunction2);
+                        #endregion
+                    }
+                } else if (loopCommon.Type == DeviceType.LightRGB
+                    || loopCommon.Type == DeviceType.LightRGBW
+                    || loopCommon.Type == DeviceType.LightLogic
+                    || loopCommon.Type == DeviceType.LightRGBandCCT
+                    || loopCommon.Type == DeviceType.DMX48) {
+
+                    tmp.spk = "light.rgb";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+
+                    #region brightness
+                    FunctionSid tempFunction2 = new FunctionSid ();
+                    tempFunction2.key = "brightness";
+                    tempFunction2.data_type = "integer";
+                    tempFunction2.value = new List<string> ();
+                    tempFunction2.max = 100;
+                    tempFunction2.min = 0;
+                    tmp.attributes.Add (tempFunction2);
+                    #endregion
+
+
+
+                    if (loopCommon.Type == DeviceType.LightRGBW) {
+                        tmp.spk = "light.rgbw";
+                        #region color
+                        FunctionSid tempFunction3 = new FunctionSid ();
+                        tempFunction3.key = "rgb";
+                        tempFunction3.data_type = "integer";
+                        tempFunction3.value = new List<string> ();
+                        //tempFunction2.value.Add("red");
+                        //tempFunction2.value.Add("green");
+                        //tempFunction2.value.Add("blue");
+                        tempFunction3.max = 255;
+                        tempFunction3.min = 0;
+                        tmp.attributes.Add (tempFunction3);
+                        #endregion
+                    } else {
+                        #region color
+                        FunctionSid tempFunction3 = new FunctionSid ();
+                        tempFunction3.key = "rgb";
+                        tempFunction3.data_type = "integer";
+                        tempFunction3.value = new List<string> ();
+                        tempFunction3.min = 0;
+                        tmp.attributes.Add (tempFunction3);
+                        #endregion
+
+                    }
+
+                    if (loopCommon.Type == DeviceType.LightRGBandCCT) {
+                        #region CCT
+                        FunctionSid tempFunctionCCT = new FunctionSid ();
+                        tempFunctionCCT.key = "cct";
+                        tempFunctionCCT.data_type = "integer";
+                        tempFunctionCCT.value = new List<string> ();
+                        //tempFunction2.value.Add("red");
+                        //tempFunction2.value.Add("green");
+                        //tempFunction2.value.Add("blue");
+                        tempFunctionCCT.max = 65535;
+                        tempFunctionCCT.min = 0;
+                        tmp.attributes.Add (tempFunctionCCT);
+                        #endregion
+                    }
+
+                } else if (loopCommon.Type == DeviceType.CurtainModel || loopCommon.Type == DeviceType.CurtainRoller || loopCommon.Type == DeviceType.CurtainTrietex) {
+                    tmp.spk = "curtain.switch";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.value.Add ("stop");
+                    tempFunction.max = 2;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+                    if (loopCommon.Type == DeviceType.CurtainRoller || loopCommon.Type == DeviceType.CurtainTrietex)//鎵�鏈夊嵎甯樻帶鍒跺櫒 
+                    {
+                        tmp.spk = "curtain.trietex";
+                        #region openlevel
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "percent";
+                        tempFunction1.data_type = "integer";
+                        tempFunction1.value = new List<string> ();
+                        //tempFunction1.value.Add("percent");
+                        tempFunction1.max = 100;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    }
+                } else if (loopCommon.Type == DeviceType.ACPanel
+                   || loopCommon.Type == DeviceType.ACDevice
+                   || loopCommon.Type == DeviceType.ACInfrared
+                   || loopCommon.Type == DeviceType.ACCoolmaster
+                   || loopCommon.Type == DeviceType.CustomAC
+                   || loopCommon.Type == DeviceType.HVAC) {
+
+                    //绌鸿皟绫�
+                    tmp.spk = "ac.standard";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+
+                    #region mode
+                    FunctionSid tempFunction1 = new FunctionSid ();
+                    tempFunction1.key = "mode";
+                    tempFunction1.data_type = "integer";
+                    tempFunction1.value = new List<string> ();
+                    tempFunction1.value.Add ("cool");
+                    tempFunction1.value.Add ("heat");
+                    tempFunction1.value.Add ("fan");
+                    tempFunction1.value.Add ("auto");
+                    tempFunction1.value.Add ("dry");
+
+                    tempFunction1.max = 4;
+                    tempFunction1.min = 0;
+                    tmp.attributes.Add (tempFunction1);
+                    #endregion
+
+                    #region fan
+                    FunctionSid tempFunction2 = new FunctionSid ();
+                    tempFunction2.key = "fan";
+                    tempFunction2.data_type = "integer";
+                    tempFunction2.value = new List<string> ();
+                    tempFunction2.value.Add ("high");
+                    tempFunction2.value.Add ("medium");
+                    tempFunction2.value.Add ("low");
+                    tempFunction2.value.Add ("auto");
+                    tempFunction2.max = 3;
+                    tempFunction2.min = 0;
+                    tmp.attributes.Add (tempFunction2);
+                    #endregion
+
+                    #region temp
+                    FunctionSid tempFunction3 = new FunctionSid ();
+                    tempFunction3.key = "set_temp";
+                    //2020 08 11  hvac 娓╁害鎺у埗 1掳-> int 0.5掳->float
+                    //if (HVACModuleDeviceTypeList.HDLHVACwithAcControlHighPrecision.Contains(DevOnLineTmp.DeviceType))
+                    //{
+                    //20201224 璁剧疆娓╁害鏁版嵁绫诲瀷缁熶竴float 浼熷崡鍚庣画ai+鏁版嵁绫诲瀷缃戝叧澶勭悊
+                    tempFunction3.data_type = "float";
+                    //}
+                    //else
+                    //{
+                    //    tempFunction3.data_type = "integer";
+                    //}
+                    tempFunction3.value = new List<string> ();
+                    tempFunction3.max = 30;
+                    tempFunction3.min = 16;
+                    tmp.attributes.Add (tempFunction3);
+                    #endregion
+
+                    #region temp_step
+                    FunctionSid tempFunction5 = new FunctionSid ();
+                    tempFunction5.key = "set_temp_step";
+                    tempFunction5.data_type = "string";
+                    tempFunction5.value = new List<string> ();
+                    tempFunction5.value.Add ("up");
+                    tempFunction5.value.Add ("down");
+                    tempFunction5.max = 1;
+                    tempFunction5.min = 0;
+                    tmp.attributes.Add (tempFunction5);
+                    #endregion
+
+                    #region room_temp
+                    FunctionSid tempFunction6 = new FunctionSid ();
+                    tempFunction6.key = "room_temp";
+                    tempFunction6.data_type = "float";
+                    tempFunction6.value = new List<string> ();
+                    tempFunction6.max = 50;
+                    tempFunction6.min = -50;
+                    tmp.attributes.Add (tempFunction6);
+                    #endregion
+
+                    #region swing
+                    FunctionSid tempFunction4 = new FunctionSid ();
+                    tempFunction4.key = "swing";
+                    tempFunction4.data_type = "string";
+                    tempFunction4.value = new List<string> ();
+                    tempFunction4.value.Add ("up_down");
+                    //tempFunction4.value.Add("down");
+                    tempFunction4.value.Add ("left_right");
+                    //tempFunction4.value.Add("right");
+                    tempFunction4.value.Add ("stop");
+                    tempFunction4.max = 3;
+                    tempFunction4.min = 0;
+                    tmp.attributes.Add (tempFunction4);
+                    #endregion
+
+                    #region lock
+
+
+                    #endregion
+                } else if (loopCommon.Type == DeviceType.FoolHeat
+                    || loopCommon.Type == DeviceType.FoolHeatPanel) {
+                    tmp.spk = "floorHeat.standard";
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+
+                    #region mode
+                    FunctionSid tempFunction1 = new FunctionSid ();
+                    tempFunction1.key = "mode";
+                    tempFunction1.data_type = "string";
+                    tempFunction1.value = new List<string> ();
+                    tempFunction1.value.Add ("day");
+                    tempFunction1.value.Add ("night");
+                    tempFunction1.value.Add ("away");
+                    tempFunction1.value.Add ("normal");
+                    tempFunction1.value.Add ("timer");
+                    tempFunction1.max = 4;
+                    tempFunction1.min = 0;
+                    tmp.attributes.Add (tempFunction1);
+                    #endregion
+
+                    #region temp
+                    FunctionSid tempFunction3 = new FunctionSid ();
+                    tempFunction3.key = "set_temp";
+                    tempFunction3.data_type = "float";
+                    tempFunction3.value = new List<string> ();
+                    //tempFunction3.value.Add("up");
+                    //tempFunction3.value.Add("down");
+                    //tempFunction3.value.Add("value");
+                    tempFunction3.max = 35;
+                    tempFunction3.min = 0;
+                    tmp.attributes.Add (tempFunction3);
+                    #endregion
+
+                    #region temp
+                    FunctionSid tempFunction4 = new FunctionSid ();
+                    tempFunction4.key = "set_temp_step";
+                    tempFunction4.data_type = "string";
+                    tempFunction4.value = new List<string> ();
+                    tempFunction4.value.Add ("up");
+                    tempFunction4.value.Add ("down");
+                    tempFunction4.max = 1;
+                    tempFunction4.min = 0;
+                    tmp.attributes.Add (tempFunction4);
+                    #endregion
+
+                    #region room_temp
+                    FunctionSid tempFunction5 = new FunctionSid ();
+                    tempFunction5.key = "room_temp";
+                    tempFunction5.data_type = "float";
+                    tempFunction5.value = new List<string> ();
+                    tempFunction5.max = 50;
+                    tempFunction5.min = -50;
+                    tmp.attributes.Add (tempFunction5);
+                    #endregion
+
+                    #region lock
+
+
+                    #endregion
+                } else if (loopCommon.Type == DeviceType.MusicA31
+                    || loopCommon.Type == DeviceType.MusicModel
+                    || loopCommon.Type == DeviceType.MusicPanel) {
+                    tmp.spk = "music.standard";
+                    // on_off  volume song_step  audio  list_channel  mode  song_num  special_song  volume_level
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("play");
+                    tempFunction.value.Add ("pause");
+
+                    //tempFunction.value.Add("play");
+                    //tempFunction.value.Add("stop");
+                    //tempFunction.value.Add("pause");
+                    //play stop pause
+                    tempFunction.max = 2;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+
+                    #region volume
+                    FunctionSid tempFunction1 = new FunctionSid ();
+                    tempFunction1.key = "volume";
+                    tempFunction1.data_type = "integer";
+                    tempFunction1.value = new List<string> ();
+                    //tempFunction1.value.Add("percent");
+                    tempFunction1.max = 100;
+                    tempFunction1.min = 0;
+                    tmp.attributes.Add (tempFunction1);
+                    #endregion
+
+                    #region volume_step
+                    FunctionSid tempFunction9 = new FunctionSid ();
+                    tempFunction9.key = "volume_step";
+                    tempFunction9.data_type = "string";
+                    tempFunction9.value = new List<string> ();
+                    tempFunction9.value.Add ("up");
+                    tempFunction9.value.Add ("down");
+                    tempFunction9.max = 1;
+                    tempFunction9.min = 0;
+                    tmp.attributes.Add (tempFunction9);
+                    #endregion
+
+
+                    #region volume_level
+                    FunctionSid tempFunction10 = new FunctionSid ();
+                    tempFunction10.key = "volume_level";
+                    tempFunction10.data_type = "integer";
+                    tempFunction10.value = new List<string> ();
+                    //tempFunction1.value.Add("percent");
+                    tempFunction10.max = 10;
+                    tempFunction10.min = 0;
+                    tmp.attributes.Add (tempFunction10);
+                    #endregion
+
+                    #region volume_level_step
+                    FunctionSid tempFunction11 = new FunctionSid ();
+                    tempFunction11.key = "volume_level_step";
+                    tempFunction11.data_type = "string";
+                    tempFunction11.value = new List<string> ();
+                    tempFunction11.value.Add ("up");
+                    tempFunction11.value.Add ("down");
+                    tempFunction11.max = 1;
+                    tempFunction11.min = 0;
+                    tmp.attributes.Add (tempFunction11);
+                    #endregion
+
+                    #region treble
+                    FunctionSid tempFunction14 = new FunctionSid ();
+                    tempFunction14.key = "treble";
+                    tempFunction14.data_type = "integer";
+                    tempFunction14.max = 10;
+                    tempFunction14.min = -10;
+                    tmp.attributes.Add (tempFunction14);
+                    #endregion
+
+                    #region treble_step
+                    FunctionSid tempFunction12 = new FunctionSid ();
+                    tempFunction12.key = "treble_step";
+                    tempFunction12.data_type = "string";
+                    tempFunction12.value = new List<string> ();
+                    tempFunction12.value.Add ("up");
+                    tempFunction12.value.Add ("down");
+                    tempFunction12.max = 1;
+                    tempFunction12.min = 0;
+                    tmp.attributes.Add (tempFunction12);
+                    #endregion
+
+
+                    #region bass
+                    FunctionSid tempFunction15 = new FunctionSid ();
+                    tempFunction15.key = "bass";
+                    tempFunction15.data_type = "integer";
+                    tempFunction15.max = 10;
+                    tempFunction15.min = -10;
+                    tmp.attributes.Add (tempFunction15);
+                    #endregion
+
+                    #region bass_step
+                    FunctionSid tempFunction13 = new FunctionSid ();
+                    tempFunction13.key = "bass_step";
+                    tempFunction13.data_type = "string";
+                    tempFunction13.value = new List<string> ();
+                    tempFunction13.value.Add ("up");
+                    tempFunction13.value.Add ("down");
+                    tempFunction13.max = 1;
+                    tempFunction13.min = 0;
+                    tmp.attributes.Add (tempFunction13);
+                    #endregion
+
+                    #region mode
+                    FunctionSid tempFunction5 = new FunctionSid ();
+                    tempFunction5.key = "mode";
+                    tempFunction5.data_type = "string";
+                    tempFunction5.value = new List<string> ();
+                    //singel/single_circle/order/all
+                    //single/single_cycle/order/list_cycle/random
+                    tempFunction5.value.Add ("single");
+                    tempFunction5.value.Add ("single_cycle");
+                    tempFunction5.value.Add ("order");
+                    tempFunction5.value.Add ("list_cycle");
+                    tempFunction5.value.Add ("random");
+                    tempFunction5.max = 3;
+                    tempFunction5.min = 0;
+                    tmp.attributes.Add (tempFunction5);
+                    #endregion
+
+                    #region source
+                    //1	= SD, 2 = External Input, 3 = FTP, 4 = Radio
+                    //sdcard/external_input/ftp/radio
+                    FunctionSid tempFunction3 = new FunctionSid ();
+                    tempFunction3.key = "source";
+                    tempFunction3.data_type = "string";
+                    tempFunction3.value = new List<string> ();
+                    tempFunction3.value.Add ("sdcard");
+                    tempFunction3.value.Add ("audio_in");
+                    tempFunction3.value.Add ("ftp");
+                    tempFunction3.value.Add ("radio");
+                    tempFunction3.value.Add ("bluetooth");
+                    tempFunction3.max = 3;
+                    tempFunction3.min = 0;
+                    tmp.attributes.Add (tempFunction3);
+                    #endregion
+
+                    #region song_step
+                    FunctionSid tempFunction2 = new FunctionSid ();
+                    tempFunction2.key = "song_step";
+                    tempFunction2.data_type = "string";
+                    tempFunction2.value = new List<string> ();
+                    tempFunction2.value.Add ("up");
+                    tempFunction2.value.Add ("down");
+                    tempFunction2.max = 1;
+                    tempFunction2.min = 0;
+                    tmp.attributes.Add (tempFunction2);
+                    #endregion
+
+                    #region bass
+                    FunctionSid tempFunction16 = new FunctionSid ();
+                    tempFunction16.key = "playlist_name";
+                    tempFunction16.data_type = "string";
+                    tmp.attributes.Add (tempFunction16);
+                    #endregion
+
+                    #region bass
+                    FunctionSid tempFunction17 = new FunctionSid ();
+                    tempFunction17.key = "song_name";
+                    tempFunction17.data_type = "string";
+                    tmp.attributes.Add (tempFunction17);
+                    #endregion
+
+                    #region bass
+                    FunctionSid tempFunction19 = new FunctionSid ();
+                    tempFunction19.key = "song_time";
+                    tempFunction19.data_type = "string";
+                    tmp.attributes.Add (tempFunction19);
+                    #endregion
+
+                    #region bass
+                    FunctionSid tempFunction20 = new FunctionSid ();
+                    tempFunction20.key = "playing_time";
+                    tempFunction20.data_type = "string";
+                    tmp.attributes.Add (tempFunction20);
+                    #endregion
+                } else if (loopCommon.BigClass == 5) {
+                    //浼犳劅鍣�
+                    if (loopCommon.Type == DeviceType.SensorMobileDetection) {
+                        tmp.spk = "sensor.pir";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+
+                        #region status
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "status";
+                        tempFunction1.data_type = "string";
+                        tempFunction1.value = new List<string> ();
+                        tempFunction1.value.Add ("true");
+                        tempFunction1.value.Add ("false");
+                        tempFunction1.max = 1;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+
+                        #region sensitivity
+                        FunctionSid tempFunction2 = new FunctionSid ();
+                        tempFunction2.key = "sensitivity";
+                        tempFunction2.data_type = "integer";
+                        tempFunction2.max = 100;
+                        tempFunction2.min = 0;
+                        tmp.attributes.Add (tempFunction2);
+                        #endregion
+                    }else if (loopCommon.Type == DeviceType.SensorTemperature) {
+                        tmp.spk = "sensor.temperature";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+
+                        #region temp
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";  //2020 12 22 
+                        tempFunction1.data_type = "float";
+                        tempFunction1.max = 50;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+
+                        #region type
+                        FunctionSid tempFunction2 = new FunctionSid ();
+                        tempFunction2.key = "type";
+                        tempFunction2.data_type = "string";
+                        tempFunction2.value = new List<string> ();
+                        tempFunction2.value.Add ("C");
+                        tempFunction2.value.Add ("F");
+                        tempFunction2.max = 1;
+                        tempFunction2.min = 0;
+                        tmp.attributes.Add (tempFunction2);
+                        #endregion
+
+                        //#region precision
+                        //Function tempFunction3 = new GateWay.Function();
+                        //tempFunction3.key = "precision";
+                        //tempFunction3.data_type = "string";
+                        //tempFunction3.value = new List<string>();
+                        //tempFunction3.value.Add("0.01");
+                        //tempFunction3.value.Add("0.1");
+                        //tempFunction3.value.Add("100");
+                        //tempFunction3.max = 2;
+                        //tempFunction3.min = 0;
+                        //tmp.attributes.Add(tempFunction3);
+                        //#endregion
+                    }else if (loopCommon.Type == DeviceType.SensorIllumination) {
+                        tmp.spk = "sensor.light";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+
+                        #region lux
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";  //2020 12 22 
+                        tempFunction1.data_type = "integer";
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+
+                        #region error_value
+                        FunctionSid tempFunction2 = new FunctionSid ();
+                        tempFunction2.key = "error_value";
+                        tempFunction2.data_type = "integer";
+                        tmp.attributes.Add (tempFunction2);
+                        #endregion
+
+                        #region precision
+                        FunctionSid tempFunction3 = new FunctionSid ();
+                        tempFunction3.key = "precision";
+                        tempFunction3.data_type = "string";
+                        tempFunction3.value = new List<string> ();
+                        tempFunction3.value.Add ("0.01");
+                        tempFunction3.value.Add ("0.1");
+                        tempFunction3.value.Add ("100");
+                        tempFunction3.max = 2;
+                        tempFunction3.min = 0;
+                        tmp.attributes.Add (tempFunction3);
+                        #endregion
+                    } else if (loopCommon.Type == DeviceType.SensorPM25) {
+                        tmp.spk = "sensor.pm25";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+
+                        #region value
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";
+                        tempFunction1.data_type = "integer";
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+
+                        #region error_value
+                        FunctionSid tempFunction2 = new FunctionSid ();
+                        tempFunction2.key = "error_value";
+                        tempFunction2.data_type = "integer";
+                        tmp.attributes.Add (tempFunction2);
+                        #endregion
+
+                        #region precision
+                        FunctionSid tempFunction3 = new FunctionSid ();
+                        tempFunction3.key = "precision";
+                        tempFunction3.data_type = "string";
+                        tempFunction3.value = new List<string> ();
+                        tempFunction3.value.Add ("0.01");
+                        tempFunction3.value.Add ("0.1");
+                        tempFunction3.value.Add ("100");
+                        tempFunction3.max = 2;
+                        tempFunction3.min = 0;
+                        tmp.attributes.Add (tempFunction3);
+                        #endregion
+                    }else if (loopCommon.Type == DeviceType.SensorHumidity) {
+                        tmp.spk = "sensor.humidity";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+                        #region value
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";
+                        tempFunction1.data_type = "float";
+                        tempFunction1.max = 10000;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    }else if (loopCommon.Type == DeviceType.SensorTVOC) {
+                        tmp.spk = "sensor.tvoc";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+                        #region value
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";
+                        tempFunction1.data_type = "integer";
+                        tempFunction1.max = 10000;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    }else if (loopCommon.Type == DeviceType.SensorCO2) {
+                        tmp.spk = "sensor.co2";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+                        #region value
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";
+                        tempFunction1.data_type = "integer";
+                        tempFunction1.max = 10000;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    }else if (loopCommon.Type == DeviceType.Sensor) {
+                        tmp.spk = "dryContact.standard";
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+
+                        #region status
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "status";
+                        tempFunction1.data_type = "string";
+                        tempFunction1.value = new List<string> ();
+                        tempFunction1.value.Add ("on");
+                        tempFunction1.value.Add ("off");
+                        tempFunction1.max = 1;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    } else {
+                        #region on_off
+                        FunctionSid tempFunction = new FunctionSid ();
+                        tempFunction.key = "enable";
+                        tempFunction.data_type = "string";
+                        tempFunction.value = new List<string> ();
+                        tempFunction.value.Add ("true");
+                        tempFunction.value.Add ("false");
+                        tempFunction.max = 1;
+                        tempFunction.min = 0;
+                        tmp.attributes.Add (tempFunction);
+                        #endregion
+                        #region value
+                        FunctionSid tempFunction1 = new FunctionSid ();
+                        tempFunction1.key = "value";
+                        tempFunction1.data_type = "integer";
+                        tempFunction1.max = 10000;
+                        tempFunction1.min = 0;
+                        tmp.attributes.Add (tempFunction1);
+                        #endregion
+                    }
+
+
+
+                } else {
+                    #region on_off
+                    FunctionSid tempFunction = new FunctionSid ();
+                    tempFunction.key = "on_off";
+                    tempFunction.data_type = "string";
+                    tempFunction.value = new List<string> ();
+                    tempFunction.value.Add ("on");
+                    tempFunction.value.Add ("off");
+                    tempFunction.max = 1;
+                    tempFunction.min = 0;
+                    tmp.attributes.Add (tempFunction);
+                    #endregion
+                }
+
+            } catch { }
+            return tmp;
+        }
+
+        //#region 鍒ゆ柇绫诲瀷
+        ///// <summary>
+        ///// 缁х數鍣ㄧ被鍒�
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLRelayDeviceType (DeviceType deviceType)
+        //{
+        //    return false;
+        //}
+
+        ///// <summary>
+        ///// 璋冨厜鍣ㄧ被鍒�
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLDimmerDeviceType (DeviceType deviceType)
+        //{
+        //    return false;
+        //}
+
+        ///// <summary>
+        ///// 閬槼绫诲埆锛堢獥甯樸�佸嵎甯樸�佸紑鍚堝笜锛�
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLCurtainDeviceType (DeviceType deviceType)
+        //{
+        //    return deviceType == DeviceType.CurtainModel
+        //            || deviceType == DeviceType.CurtainRoller
+        //            || deviceType == DeviceType.CurtainTrietex;
+        //}
+
+        ///// <summary>
+        ///// 浼犳劅鍣ㄧ被鍒�
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLSensorDeviceType (DeviceType deviceType)
+        //{
+        //    return false;
+        //}
+
+        ///// <summary>
+        ///// 缃戝叧绫诲埆
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLGatewayDeviceType (DeviceType deviceType)
+        //{
+        //    return false;
+        //}
+
+        ///// <summary>
+        ///// 绌鸿皟
+        ///// </summary>
+        ///// <param name="deviceType"></param>
+        ///// <returns></returns>
+        //public bool IsHDLACDeviceType (DeviceType deviceType)
+        //{
+        //    return false;
+        //}
+
+        //#endregion
+
+
+        #region 鐢熸垚4浣峛yte 鏃堕棿鎴�
+        private long LastTime = 0;
+        /// <summary>
+        /// DateTime鏃堕棿鏍煎紡杞崲涓�13浣嶅甫姣鐨刄nix鏃堕棿鎴�
+        /// </summary>
+        /// <param name="time"> DateTime鏃堕棿鏍煎紡</param>
+        /// <returns>Unix鏃堕棿鎴虫牸寮�</returns>
+        public long ConvertDateTimeLong ()
+        {
+            System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime (new System.DateTime (2020, 1, 1));
+            long l = (long)(Math.Round ((DateTime.Now - startTime).TotalSeconds, 1) * 10);
+            if (l <= LastTime) l = LastTime + 1;
+            LastTime = l;
+            return l;
+        }
+        /// <summary>
+        /// 
+        /// </summary>
+        /// <param name="m"></param>
+        /// <param name="strTmp"></param>
+        /// <returns></returns>
+        public bool ConvertIntToByteArray (long m, ref string strTmp)
+        {
+            strTmp = "00000000";
+            byte [] arry = new byte [4];
+            arry [0] = (byte)(m & 0xFF);
+            arry [1] = (byte)((m & 0xFF00) >> 8);
+            arry [2] = (byte)((m & 0xFF0000) >> 16);
+            arry [3] = (byte)((m & 0xFF000000) >> 24);
+            strTmp = arry [0].ToString ("X2") + arry [1].ToString ("X2") + arry [2].ToString ("X2") + arry [3].ToString ("X2");
+            return true;
+        }
+        #endregion
+
+    }
+
+    [Serializable]
+    public class BaseCloudFeedback
+    {
+        public int code { get; set; }
+        public string timestamp { get; set; }
+        public bool isSuccess { get; set; }
+        public string message { get; set; }
+    }
+
+    [Serializable]
+    public class Sids
+    {
+        public string homeId { get; set; }
+        public string gatewayId { get; set; }
+        public List<Sid> devices { get; set; }
+    }
+
+    [Serializable]
+    public class Oids
+    {
+        public string homeId { get; set; }
+        public string gatewayId { get; set; }
+        public List<Oid> devices { get; set; }
+    }
+
+    [Serializable]
+    public class Oid
+    {
+        public string protocolType { get; set; }
+        public string device_name { get; set; }
+        public string oid { get; set; }
+        public string addresses { get; set; }
+        public string device_model { get; set; }
+
+        public string fw_version { get; set; }
+        public string hw_info { get; set; }
+        public string mac { get; set; }
+        public int deviceType { get; set; }
+    }
+
+    [Serializable]
+    public class Sid
+    {
+        public string sid { get; set; }
+        public string name { get; set; }
+        public string [] uids { get; set; }
+        public string spk { get; set; }
+
+        public string oid { get; set; }  //璁惧妯″潡鍦板潃
+        public string omodel { get; set; }    //鍨嬪彿
+        public List<FunctionSid> attributes { get; set; } //灞炴�у垪琛�
+    }
+
+
+    [Serializable]
+    public class FunctionSid
+    {
+        //public string name { get; set; }
+        public string key { get; set; }
+        public List<string> value { get; set; }
+        public int max { get; set; }
+        public int min { get; set; }
+        public string data_type { get; set; }
+    }
+
+    [Serializable]
+    public class SidObject : Sid
+    {
+
+    }
+
+    [Serializable]
+    public class IotCloud
+    {
+        public Oids modules { get; set; } //璁惧鍒楄〃
+        public Sids functions { get; set; } //鍔熻兘鍒楄〃
+    }
+
+    /// <summary>
+    /// 璁惧鍒楄〃鍝嶅簲data鍙傛暟
+    /// </summary>
+    public class DevcieFunctionRes
+    {
+        public List<Function> list = new List<Function> ();
+
+        //public string totalCount = "0";
+
+        //public string totalPage = "0";
+
+        //public string pageNo = "0";
+
+        //public string pageSize = "0";
+
+    }
+
+    /// <summary>
+    /// 鍔熻兘绫昏兘婊¤冻鏁版嵁浣跨敤瑕佹眰锛屽瓙绫诲彧鏄负浜嗘柟渚夸娇鐢ㄥ睘鎬�
+    /// </summary>
+    public class Function
+    {
+        public Function ()
+        {
+        }
+
+        #region base info
+        /// <summary>
+        /// HDL缁熶竴鍗忚鏍煎紡锛�14bytes
+        /// 涓句緥锛� 鏉ユ簮   鍘傚晢浠g爜 閫氳鏂瑰紡  浜у搧鏃堕棿鎴�   浜у搧绫诲埆 鐗╂ā鍨嬬被  閫氶亾鍙�   澶у皬绫诲埆
+        ///       1byte	1byte	1byte	  4byte	    1byte	2byte   2byte   2byte
+        /// 鏉ユ簮锛�00	榛樿鍘熺敓鎬佺郴缁熸暟鎹� 銆�01	缃戝叧鎴栬�呭叾浠朅璁惧銆�02	璋冭瘯杞欢銆�03	APP搴旂敤绋嬪簭銆�04	绗笁鏂圭綉鍏虫垨鑰呭钩鍙�
+        /// 鍘傚晢浠g爜锛�01	HDL
+        /// 閫氳鏂瑰紡锛�01	HDL Bus銆�02	Zigbee銆�03 KNX銆�04 Z-Wave
+        /// 浜у搧鏃堕棿鎴筹細4bytes	浠�2020骞�1鏈�1鏃ョ畻鍑虹殑鏃堕棿鎴�0.1s涓哄崟浣� 
+        /// 浜у搧绫诲埆锛�01	璋冨厜鍣ㄣ��02 缁х數鍣ㄣ��03	骞叉帴鐐规ā鍧椼��04	浼犳劅鍣ㄣ��05 闈㈡澘
+        /// 鐗╂ā鍨嬬被鍨嬶細
+        ///     01	寮�鍏崇被锛�01 寮�鍏炽��02 鎻掑骇銆�03	
+        ///     02	鐓ф槑锛� 01 寮�鍏炽��02	璋冨厜銆�03	鑹叉俯銆�04	LED
+        ///     03	閬槼锛� 01	绐楀笜鐢垫満銆�02 鐧惧彾绐椼��03 寮�鍚堝笜銆�04 鍗峰笜
+        ///     04	鎭掓俯鍣細01 绌鸿皟銆�02 鍦版殩銆�03 姣涚粏绌鸿皟
+        ///     05	鏂伴		
+        ///     06	褰遍煶		
+        ///     07	闊充箰		
+        ///     08	鑳芥簮		
+        ///     09	瀹夐槻
+        /// 澶х被鍒�	1bytes	锛堥鐣欙級
+        /// 灏忕被鍒�	1byte	锛堥鐣欙級
+        /// </summary>
+        public string sid = "0301011234567801012301230123";
+        /// <summary>
+        /// 
+        /// </summary>
+        public string oid;
+        /// <summary>
+        /// 澶囨敞
+        /// </summary>
+        public string name;
+        /// <summary>
+        /// 璁惧ID
+        /// 浜戠璐熻矗鐢熸垚
+        /// </summary>
+        public string deviceId = "0";
+        /// <summary>
+        /// 璁惧spk
+        /// </summary>
+        public string spk = "";
+        /// <summary>
+        /// 
+        /// </summary>
+        string spk_Prefix;
+        /// <summary>
+        /// spk鍓嶇紑
+        /// 澶х被
+        /// 鍔熻兘绫诲埆
+        /// 濡傦細绌鸿皟绫汇�佺伅鍏夌被銆佺獥甯樼被
+        /// </summary>
+        public string Spk_Prefix {
+            get {
+                if (string.IsNullOrEmpty (spk_Prefix)) {
+                    spk_Prefix = spk.Split (".") [0];
+                }
+                return spk_Prefix;
+            }
+        }
+        string spk_Suffix;
+       
+        /// <summary>
+        /// A鍗忚鍔熻兘鐨勭壒鎬�
+        /// 濡傦細鏄疉C鍔熻兘锛氱壒鎬э細on_off,mode,fan,temperature
+        /// attri
+        /// </summary>
+        public List<FunctionAttributes> attributes = new List<FunctionAttributes> ();
+
+        /// <summary>
+        /// 鎴块棿ID鍒楄〃
+        /// 璇ュ姛鑳芥坊鍔犲埌鍒版埧闂村垪琛�
+        /// </summary>
+        public List<string> roomIds = new List<string> ();
+
+        /// <summary>
+        /// bus鍗忚鏁版嵁鏍煎紡
+        /// 浣跨敤A鍗忚鎺у埗鏃讹紝鏀瑰睘鎬т负绌�
+        /// </summary>
+        public BusData bus;
+        /// <summary>
+        /// 鏄惁鏀惰棌
+        /// </summary>
+        public bool collect = false;
+        /// <summary>
+        /// 鏄惁鍦ㄧ嚎
+        /// </summary>
+        public bool online = true;
+        /// <summary>
+        /// 浜戠鏁版嵁鍒涘缓鐨勬椂闂�
+        /// </summary>
+        public string createTime = "";
+        /// <summary>
+        /// 浜戠鏁版嵁淇敼鐨勬渶鍚庢椂闂�
+        /// </summary>
+        public string modifyTime = "";
+        /// <summary>
+        /// 鍒犻櫎鏍囪
+        /// 闇�瑕佸垹闄ゆ暟鎹椂锛屾爣璁颁负锛歵rue
+        /// 鐢变簯绔垹闄ゆ垚鍔熶箣鍚庯紝杩斿洖鏁版嵁鍐嶆竻闄ゆ湰鍦版暟鎹�
+        /// </summary>
+        public bool DeleteSign = false;
+
+        #endregion
+        /// <summary>
+        /// 寤舵椂
+        /// </summary>
+        public int delay = 0;
+        /// <summary>
+        /// 鏈�鍚庢帶鍒剁殑涓�娆$姸鎬�
+        /// </summary>
+        [Newtonsoft.Json.JsonIgnore]
+        public string lastState = "";
+
+        FunctionAttributes _trait_on_off;
+        [Newtonsoft.Json.JsonIgnore]
+        public FunctionAttributes trait_on_off {
+            get {
+                if (_trait_on_off == null) {
+                    _trait_on_off = attributes.Find ((obj) => obj.key == FunctionAttributeKey.OnOff);
+                    //鎵句笉鍒板睘鎬ч渶瑕佸0鏄庝竴涓紝闃叉鎶ラ敊闂��
+                    if (_trait_on_off == null) {
+                        _trait_on_off = new FunctionAttributes () {
+                            key = "on_off",
+                            value = new List<string> { "on", "off" },
+                            max = 1,
+                            min = 0,
+                        };
+                        _trait_on_off.curValue = "off";
+                    }
+                }
+                if (_trait_on_off.curValue.ToString () != "on" && _trait_on_off.curValue.ToString () != "off") {
+                    _trait_on_off.curValue = "off";
+                }
+                return _trait_on_off;
+            }
+            //set
+            //{
+            //    _trait_on_off = value;
+            //}
+        }
+
+        /// <summary>
+        /// 浣跨敤娆℃暟
+        /// </summary>
+        public double controlCounter = 0;
+        /// <summary>
+        /// 浣跨敤棰戠巼
+        /// </summary>
+        public double usageFrequency {
+            get {
+                return controlCounter / 7;
+            }
+        }
+        /// <summary>
+        /// 鍥哄畾鐨勫簭鍙�
+        /// </summary>
+        public int fixedSerialNumber = int.MaxValue;
+    }
+
+
+    /// <summary>
+    /// 鍔熻兘灞炴��
+    /// 灞炴�у瓧娈佃В鏋愶細attri :灞炴�у唴瀹癸紝value 灞炴�х殑鍊硷紝max 鏈�澶у�� min 鏈�灏忓��
+    /// </summary>
+    [System.Serializable]
+    public class FunctionAttributes
+    {
+        /// <summary>
+        /// 灞炴�ч敭鍚�
+        /// </summary>
+        public string key;
+        /// <summary>
+        /// 灞炴�х殑鍊煎垪琛�
+        /// </summary>
+        public List<string> value = new List<string> ();
+        /// <summary>
+        /// 鏈�澶у��
+        /// </summary>
+        public int max = 100;
+        /// <summary>
+        /// 鏈�灏忓��
+        /// </summary>
+        public int min = 0;
+        /// <summary>
+        /// 鏁版嵁绫诲瀷
+        /// </summary>
+        public string data_type = "";
+        /// <summary>
+        /// 褰撳墠鍊�
+        /// </summary>
+        public object curValue = new object ();
+
+    }
+
+
+    /// <summary>
+    /// 鍔熻兘灞炴�ч敭鍚嶅垪琛�
+    /// </summary>
+    public static class FunctionAttributeKey
+    {
+        /// <summary>
+        /// 寮�鍏�
+        /// </summary>
+        public const string OnOff = "on_off";
+        /// <summary>
+        /// 浜害
+        /// </summary>
+        public const string Brightness = "brightness";
+        /// <summary>
+        /// 棰滆壊
+        /// </summary>
+        public const string RGB = "rgb";
+        /// <summary>
+        /// 娓愬彉鏃堕棿
+        /// </summary>
+        public const string FadeTime = "fade_time";
+        /// <summary>
+        /// 妯″紡
+        /// </summary>
+        public const string Mode = "mode";
+        /// <summary>
+        /// 椋庨��
+        /// </summary>
+        public const string FanSpeed = "fan";
+        /// <summary>
+        /// 璁剧疆娓╁害
+        /// </summary>
+        public const string SetTemp = "set_temp";
+        /// <summary>
+        /// 寤舵椂
+        /// </summary>
+        public const string Delay = "delay";
+        /// <summary>
+        /// 鑹叉俯
+        /// </summary>
+        public const string CCT = "cct";
+        /// <summary>
+        /// 鐧惧垎姣�
+        /// </summary>
+        public const string Percent = "percent";
+        /// <summary>
+        /// 瀹ゅ唴娓╁害
+        /// </summary>
+        public const string IndoorTemp = "room_temp";
+        /// <summary>
+        /// value
+        /// </summary>
+        public const string Value = "value";
+    }
+
+    /// <summary>
+    /// 鍏煎鏃у崗璁帶鍒�
+    /// </summary>
+    public class BusData
+    {
+        public string addresses = "FFFF";
+        [Newtonsoft.Json.JsonIgnore]
+        public byte SubnetID {
+            get {
+                return Convert.ToByte (addresses.Substring (0, 2), 16);
+            }
+        }
+        [Newtonsoft.Json.JsonIgnore]
+        public byte DeviceID {
+            get {
+                return Convert.ToByte (addresses.Substring (2, 2), 16);
+            }
+        }
+        public byte LoopId {
+            get {
+                return Convert.ToByte (loopId, 16);
+            }
+        }
+
+        public string loopId;
+    }
+
+    public static class SPK
+    {
+        /// <summary>
+        /// 锛堝紑鍏崇伅锛�
+        /// </summary>
+        public const string LightSwitch = "light.switch";
+        /// <summary>
+        /// 锛堣皟鍏夌伅锛�
+        /// </summary>
+        public const string LightDimming = "light.dimming";
+        /// <summary>
+        /// 锛圧GB鐏級
+        /// </summary>
+        public const string LightRGB = "light.rgb";
+        /// <summary>
+        /// 锛圧GBW鐏級
+        /// </summary>
+        public const string LightRGBW = "light.rgbw";
+        /// <summary>
+        /// 锛圕CT鐏級
+        /// </summary>
+        public const string LightCCT = "light.cct";
+        /// <summary>
+        /// 锛堝紑鍏崇獥甯橈級
+        /// </summary>
+        public const string CurtainSwitch = "curtain.switch";
+        /// <summary>
+        /// 锛堝紑鍚堝笜锛�
+        /// </summary>
+        public const string CurtainTrietex = "curtain.trietex";
+        /// <summary>
+        /// 锛堢櫨鍙跺笜锛�
+        /// </summary>
+        public const string CurtainShades = "curtain.shades";
+        /// <summary>
+        /// 锛堝嵎甯橈級
+        /// </summary>
+        public const string CurtainRoller = "curtain.roller";
+        /// <summary>
+        /// 锛堢┖璋冿級
+        /// </summary>
+        public const string AcStandard = "ac.standard";
+        /// <summary>
+        /// 锛堝湴鐑級
+        /// </summary>
+        public const string FloorHeatStandard = "floorHeat.standard";
+        /// <summary>
+        /// 锛堟柊椋庯級
+        /// </summary>
+        public const string AirFreshStandard = "airFresh.standard";
+        /// <summary>
+        /// 锛堥煶涔愶級
+        /// </summary>
+        public const string MusicStandard = "music.standard";
+        /// <summary>
+        /// 锛堜寒搴︿紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorLight = "sensor.light";
+        /// <summary>
+        /// 锛堟俯搴︿紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorTemperature = "sensor.temperature";
+        /// <summary>
+        /// (绾㈠绉诲姩浼犳劅鍣�)
+        /// </summary>
+        public const string SensorPir = "sensor.pir";
+        /// <summary>
+        /// 锛堥棬绐椾紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorDoorWindow = "sensor.doorwindow";
+        /// <summary>
+        /// 锛圥M2.5浼犳劅鍣級
+        /// </summary>
+        public const string SensorPm25 = "sensor.pm25";
+        /// <summary>
+        /// co2浼犳劅鍣�
+        /// </summary>
+        public const string SensorCO2 = "sensor.co2";
+        /// <summary>
+        /// tvoc浼犳劅鍣�
+        /// </summary>
+        public const string SensorTVOC = "sensor.tvoc";
+        /// <summary>
+        /// 婀垮害浼犳劅鍣�
+        /// </summary>
+        public const string SensorHumidity = "sensor.humidity";
+        /// <summary>
+        /// 锛堝共鎺ョ偣锛�
+        /// </summary>
+        public const string DryContact = "dryContact.standard";
+        /// <summary>
+        /// 瀹剁數銆佹彃搴�
+        /// </summary>
+        public const string ElectricSocket = "electrical.socket";
+        /// <summary>
+        /// 瀹剁數銆佺數瑙�
+        /// </summary>
+        public const string ElectricTV = "electrical.tv";
+        /// <summary>
+        /// 瀹剁數銆侀鎵�
+        /// </summary>
+        public const string ElectricFan = "electrical.fan";
+
+    }
+
+
+    /// <summary>
+    /// 鍔熻兘绫诲埆
+    /// </summary>
+    public static class FunctionCategory
+    {
+        /// <summary>
+        ///锛堢伅锛�
+        /// </summary>
+        public const string Light = "light";
+        /// <summary>
+        /// 锛堢獥甯橈級
+        /// </summary>
+        public const string Curtain = "curtain";
+        /// <summary>
+        /// 锛堢┖璋冿級
+        /// </summary>
+        public const string AC = "ac";
+        /// <summary>
+        /// 锛堝湴鐑級
+        /// </summary>
+        public const string FloorHeat = "floorHeat";
+        /// <summary>
+        /// 锛堟柊椋庯級
+        /// </summary>
+        public const string AirFresh = "airFresh";
+        /// <summary>
+        /// 锛堥煶涔愶級
+        /// </summary>
+        public const string Music = "music";
+        /// <summary>
+        /// 锛堜紶鎰熷櫒锛�
+        /// </summary>
+        public const string Sensor = "sensor";
+        /// <summary>
+        /// 锛堝共鎺ョ偣锛�
+        /// </summary>
+        public const string DryContact = "dryContact";
+        /// <summary>
+        /// 瀹剁數
+        /// </summary>
+        public const string Electric = "electrical";
+
+        //Music = 0x09,
+    }
+
+
+    ///// <summary>
+    ///// 涓婁紶Oid鍒楄〃
+    ///// </summary>
+    //[Serializable]
+    //public class UploadOids
+    //{
+    //    public string homeId { get; set; } //浣忓畢ID
+    //    public Oids devices { get; set; } //璁惧鍒楄〃
+    //}
+
+    ///// <summary>
+    ///// 涓婁紶Sid鍒楄〃
+    ///// </summary>
+    //[Serializable]
+    //public class UploadSids
+    //{
+    //    public string homeId { get; set; } //浣忓畢ID
+    //    public string gatewayId { get; set; } //缃戝叧ID
+    //    public Sids devices { get; set; } //璁惧鍒楄〃
+    //}
+
+}
+
+
+//sid缁勬垚閮ㄥ垎锛�
+//sid
+//鏉ユ簮	鍘傚晢浠g爜	閫氳鏂瑰紡	浜у搧鏃堕棿鎴�	浜у搧绫诲埆	鐗╂ā鍨嬬被	閫氶亾鍙�	澶у皬绫诲埆
+//1byte	1byte	1byte	4byte	1byte	2byte	2byte	2byte
+//oid缁勬垚閮ㄥ垎锛�
+//鏉ユ簮	鍘傚晢浠g爜	閫氳鏂瑰紡	浜у搧鏃堕棿鎴�	浜у搧绫诲埆
+//1byte	1 byte	1 byte	4 byte	1byte
+//鍏朵腑鍚勯儴鍒嗕唬鐮佸垪琛細
+//鏉ユ簮	1byte	缂栧彿	鎻忚堪
+//		00	榛樿鍘熺敓鎬佺郴缁熸暟鎹�
+//		01	缃戝叧鎴栬�呭叾浠朅璁惧
+//		02	璋冭瘯杞欢
+//		03	APP搴旂敤绋嬪簭
+//		04	绗笁鏂圭綉鍏虫垨鑰呭钩鍙�
+
+//鍘傚晢浠g爜	1byte	缂栧彿	鎻忚堪
+//		01	HDL
+//		02	
+
+//閫氳鏂瑰紡	1byte	缂栧彿	鎻忚堪
+//		01	HDL Bus
+//		02	Zigbee
+//		03	KNX
+//		04	Z-Wave
+
+//浜у搧鏃堕棿鎴�	4bytes	浠�2020骞�1鏈�1鏃ョ畻鍑虹殑鏃堕棿鎴�0.1s涓哄崟浣�
+
+//浜у搧绫诲埆	1byte	缂栧彿	鎻忚堪
+//		01	璋冨厜鍣�
+//		02	缁х數鍣�
+//		03	骞叉帴鐐规ā鍧�
+//		04	浼犳劅鍣�
+//		05	闈㈡澘
+//		06	RCU
+//		07	缃戝叧
+//		08	绾㈠鍙戝皠
+//		09	Android灞�
+//		10	鍦烘櫙
+//		11	闊充箰鎾斁鍣�
+//		12	232/485杞崲鍣�
+//		21	鑷姩鍖�
+//		22	瀹夐槻闃插尯
+//		14	绐楀笜妯″潡
+//		15	HVAC
+//		16	鍦扮儹妯″潡
+
+//鐗╂ā鍨嬬被鍨�	2bytes	缂栧彿	鎻忚堪
+//		01	寮�鍏崇被	01	寮�鍏�
+//				02	鎻掑骇
+//				03	
+//		02	鐓ф槑	01	寮�鍏�
+//				02	璋冨厜
+//				03	鑹叉俯(CCT)
+//				04	RGB
+//		03	閬槼	01	绐楀笜鎺у埗鍣�
+//				02	鐧惧彾绐�
+//				03	寮�鍚堝笜
+//				04	鍗峰笜
+//				05	聽鎺ㄧ獥鍣�
+//				06	聽鎶曞奖骞�
+//		04	闈㈡澘	01	鎸夐敭闈㈡澘
+//		05	浼犳劅鍣�	01	绉诲姩鎺㈡祴
+//				02	娓╁害浼犳劅鍣�
+//				03	婀垮害浼犳劅鍣�
+//				04	鐓у害浼犳劅鍣�
+//				05	TVOC
+//				06	PM2.5
+//				07	CO2
+//				08	姣背娉紶鎰熷櫒
+//				09	
+//				10	
+//				11	鐑熼浘浼犳劅鍣�
+//				25	骞叉帴鐐�
+//		07	鎭掓俯鍣�	01	绌鸿皟
+//				02	椋庢墖
+//				03	姣涚粏绌鸿皟
+//		08	鍦扮儹	01	鍦扮儹妯″潡
+//		09	鑳屾櫙闊充箰	01	闊充箰鎾斁鍣�
+//				02	Sonos
+//		10	鍦烘櫙	01	鍦烘櫙
+//				02	鐢靛奖鍦烘櫙
+//		19	鏂伴	01	鏂伴
+
+//13	鑳芥簮	01	鐢佃〃
+//				02	姘磋〃
+//				03	鐕冩皵
+//		16	鐢靛櫒	01	椋庢墖
+//				02	TV
+//		20	瀹夐槻	01	瀹夐槻
+//		21	鑷姩鍖�	01	鑷姩鍖�
+//澶х被鍒�	1bytes	锛堥鐣欙級
+//灏忕被鍒�	1byte	锛堥鐣欙級
\ No newline at end of file

--
Gitblit v1.8.0