From dc6493db59dcb0893eac50b72122f94c24056b3f Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期一, 12 十月 2020 14:35:39 +0800
Subject: [PATCH] 新版本
---
ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindInfo.cs | 1249 ++++++++++++++++++++++++++++++++++++++++------------------
1 files changed, 855 insertions(+), 394 deletions(-)
diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindInfo.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindInfo.cs
index 1991435..80f0596 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindInfo.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindInfo.cs
@@ -2,19 +2,853 @@
using System.Collections.Generic;
using System.Threading.Tasks;
using Shared.Common;
-using Shared.Phone.Device.Category;
using Shared.Phone.UserCenter.Device;
using ZigBee.Device;
+using static ZigBee.Device.BindObj;
using static ZigBee.Device.Panel;
namespace Shared.Phone.UserCenter.DeviceBind
{
public class BindInfo
{
+ #region 缁戝畾璁捐鐨勫彉閲忓畾涔�
/// <summary>
- /// 褰撳墠鎸夐敭閰嶇疆鐨勫姛鑳�
+ /// 褰撳墠璁惧缁戝畾绫诲瀷
/// </summary>
- public static int clusterID = 0;
+ public enum BindType
+ {
+ /// <summary>
+ /// 鏂伴
+ /// </summary>
+ FreshAir = 1,
+ /// <summary>
+ /// 娓╁害浼犳劅鍣�
+ /// </summary>
+ Temperature = 2,
+ /// <summary>
+ /// 婀垮害浼犳劅鍣�
+ /// </summary>
+ Humidity = 3,
+ /// <summary>
+ /// PM2.5浼犳劅鍣�
+ /// </summary>
+ PM = 4,
+ /// <summary>
+ /// 绌鸿皟鐩爣
+ /// </summary>
+ AC = 5,
+ /// <summary>
+ /// 鍦版殩鐩爣
+ /// </summary>
+ Fh = 6,
+ }
+
+ #endregion
+
+ #region 缁戝畾娑夊強鐨勬暟鎹鐞�
+ /// <summary>
+ /// 鑾峰彇褰撳墠妤煎眰鍚嶇О
+ /// </summary>
+ /// <returns></returns>
+ public static string GetCurrentKeyAllRoomList()
+ {
+ var dicFloor = HdlRoomLogic.Current.GetFloorSortList();
+ foreach (var floorId in dicFloor.Keys)
+ {
+ //绗竴涓ゼ灞�
+ return dicFloor[floorId];
+ break;
+ }
+ return null;
+ }
+
+ /// <summary>
+ /// 鑾峰彇褰撳墠妤煎眰
+ /// </summary>
+ /// <returns></returns>
+ public static string GetCurrentSelectFloorId()
+ {
+ var dicFloor = HdlRoomLogic.Current.GetFloorSortList();//
+ foreach (var floorId in dicFloor.Keys)
+ {
+ //绗竴涓ゼ灞�
+ return floorId;
+ break;
+ }
+ return null;
+ }
+
+ /// <summary>
+ /// 鑾峰彇褰撳墠妤煎眰鍚嶇О
+ /// </summary>
+ /// <returns></returns>
+ public static string GetCurrentSelectFloorIdName()
+ {
+ var dicFloor = HdlRoomLogic.Current.GetFloorSortList();
+ foreach (var floorId in dicFloor.Keys)
+ {
+ //绗竴涓ゼ灞�
+ return dicFloor[floorId];
+ break;
+ }
+ return null;
+ }
+
+ /// <summary>
+ /// 鑾峰彇褰撳墠妤煎眰鍚嶇О
+ /// fllodID:妤煎眰ID
+ /// </summary>
+ /// <returns></returns>
+ public static string GetBindTargetsFloorIdName(string curFllodID)
+ {
+ var dicFloor = HdlRoomLogic.Current.GetFloorSortList();
+ foreach (var floorId in dicFloor.Keys)
+ {
+ //褰撳墠妤煎眰
+ if (curFllodID == floorId)
+ {
+ return dicFloor[floorId];
+ break;
+ }
+ }
+ return null;
+ }
+
+ /// <summary>
+ /// 鑾峰彇褰撳墠鎴块棿涓尮閰嶇殑鏀寔缁戝畾鐨勮澶囧垪琛�
+ /// currentRoomSupportBindDeviceList 褰撳墠鎴块棿涓敮鎸佽缁戝畾鐨勮澶囧垪琛�
+ /// curRoom 褰撳墠鎴块棿
+ /// curDeviceBindType 褰撳墠璁惧缁戝畾绫诲瀷
+ /// </summary>
+ /// <returns></returns>
+ public static List<CommonDevice> GetCurRoomSupportDeviceList(List<CommonDevice> currentRoomSupportBindDeviceList, Room curRoom, BindInfo.BindType curDeviceBindType)
+ {
+ currentRoomSupportBindDeviceList.Clear();
+ List<CommonDevice> curRoomDeviceListTemp = new List<CommonDevice>();
+ switch (curDeviceBindType)
+ {
+ case BindType.FreshAir:
+ foreach (var deviceKeys in curRoom.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (BindInfo.checkRealFreshAirDevice(device) == false)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.FreshAir)
+ {
+ curRoomDeviceListTemp.Add(device);
+ }
+ }
+ }
+ break;
+ case BindType.Temperature:
+ curRoomDeviceListTemp = GetMatchTemperatureSensorDevice(curRoom);
+ break;
+ case BindType.Humidity:
+ curRoomDeviceListTemp = GetMatchHumiditySensorDevice(curRoom);
+ foreach (var deviceKeys in curRoom.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.FreshAirHumiditySensor)
+ {
+ curRoomDeviceListTemp.Add(device);
+ }
+ }
+ }
+ break;
+ case BindType.PM:
+ foreach (var deviceKeys in curRoom.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.PMSensor)
+ {
+ curRoomDeviceListTemp.Add(device);
+ }
+ }
+ }
+ break;
+ case BindType.AC:
+ foreach (var deviceKeys in curRoom.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.Thermostat)
+ {
+ if (BindInfo.checkRealAcDevice(device) == false)
+ {
+ continue;
+ }
+ curRoomDeviceListTemp.Add(device);
+ }
+ }
+ }
+ break;
+ }
+ return curRoomDeviceListTemp;
+ }
+
+ /// <summary>
+ /// 鍖归厤娓╁害浼犳劅鍣�
+ /// </summary>
+ /// <param name="room"></param>
+ public static List<CommonDevice> GetMatchTemperatureSensorDevice(Room room)
+ {
+ List<CommonDevice> roomIncludeMatchTempDevice = new List<CommonDevice>();
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ //鐢垫睜璁惧涓嶆敮鎸佺粦瀹�
+ if (device.ZigbeeType != 1)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.TemperatureSensor)
+ {
+ var dev = device as TemperatureSensor;
+ if (BindInfo.checkRealTemperatureDevice(device) == false)
+ {
+ continue;
+ }
+ if (dev.SensorDiv == 1)
+ {
+ roomIncludeMatchTempDevice.Add(device);
+ }
+ }
+ else if (device.Type == DeviceType.PMSensor)
+ {
+ var dev = device as PMSensor;
+ foreach (var clu in dev.InClusterList)
+ {
+ if (clu.InCluster == 1026)
+ {
+ roomIncludeMatchTempDevice.Add(device);
+ }
+ }
+ }
+ }
+ }
+ return roomIncludeMatchTempDevice;
+ }
+
+ /// <summary>
+ /// 鍖归厤婀垮害浼犳劅鍣�
+ /// </summary>
+ /// <param name="room"></param>
+ public static List<CommonDevice> GetMatchHumiditySensorDevice(Room room)
+ {
+ List<CommonDevice> roomIncludeMatchHumpDevice = new List<CommonDevice>();
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ //鐢垫睜璁惧涓嶆敮鎸佺粦瀹�
+ if (device.ZigbeeType != 1)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.TemperatureSensor)
+ {
+ var dev = device as TemperatureSensor;
+ if (BindInfo.checkRealTemperatureDevice(device) == false)
+ {
+ continue;
+ }
+ if (dev.SensorDiv == 2)
+ {
+ roomIncludeMatchHumpDevice.Add(device);
+ }
+ }
+ else if (device.Type == DeviceType.PMSensor)
+ {
+ var dev = device as PMSensor;
+ foreach (var clu in dev.InClusterList)
+ {
+ if (clu.InCluster == 1029)
+ {
+ roomIncludeMatchHumpDevice.Add(device);
+ }
+ }
+ }
+ }
+ }
+ return roomIncludeMatchHumpDevice;
+ }
+
+ /// <summary>
+ /// 鑾峰彇鏀寔鐨勬埧闂村垪琛�
+ /// </summary>
+ /// <returns></returns>
+ public static List<Room> GetSupportRoomList()
+ {
+ var supportRoomListTemp = new List<Room>();
+ var listAllRoom = HdlRoomLogic.Current.GetAllListRooms();
+ if (Common.Config.Instance.Home.FloorDics.Count == 0)
+ {
+ // 鑾峰彇娌℃湁妤煎眰鎴块棿
+ foreach (var room in listAllRoom)
+ {
+ if (string.IsNullOrEmpty(room.FloorId))
+ {
+ if (room.IsLove)
+ {
+ continue;
+ }
+ supportRoomListTemp.Add(room);
+ }
+ }
+ }
+ else
+ {
+ // 鑾峰彇鏀寔鐨勬埧闂�
+ foreach (var room in listAllRoom)
+ {
+ if (room.IsLove)
+ {
+ continue;
+ }
+ supportRoomListTemp.Add(room);
+ }
+ }
+ return supportRoomListTemp;
+ }
+
+ /// <summary>
+ /// 鑳芥樉绀虹殑鎴块棿鍒楄〃
+ /// curControlDev 鎺у埗璁惧
+ /// supportRoomList 鏈湴鎴块棿鍒楄〃
+ /// curDeviceBindType 褰撳墠璁惧缁戝畾绫诲瀷
+ /// </summary>
+ public static List<Room> GetSupportRoomList(Panel curControlDev, List<Room> supportRoomList, BindInfo.BindType curDeviceBindType)
+ {
+ var roomTempList = new List<Room>();
+ for (int i = 0; i < supportRoomList.Count; i++)
+ {
+ var room = supportRoomList[i];
+ //濡傛灉鎴块棿涓哄枩鐖盵鍚庢潵鏀瑰悕涓哄父鐢ㄦ埧闂碷锛屽垯涓嶆樉绀�
+ if (room.IsLove == true)
+ {
+ continue;
+ }
+
+ //濡傛灉鎴块棿涓病鏈夎澶囷紝鍒欎笉鏄剧ず
+ if (room.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ else
+ {
+ List<CommonDevice> roomIncludeMatchDevice = new List<CommonDevice>();
+
+ //鎴块棿涓病鏈夊搴旂殑鏀寔缁戝畾鐨勭洰鏍�
+ switch (curDeviceBindType)
+ {
+ case BindInfo.BindType.FreshAir:
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ if (BindInfo.checkRealFreshAirDevice(device) == false)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.FreshAir)
+ {
+ roomIncludeMatchDevice.Add(device);
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.Temperature:
+ roomIncludeMatchDevice = BindInfo.GetMatchTemperatureSensorDevice(room);
+ break;
+ case BindInfo.BindType.Humidity:
+ roomIncludeMatchDevice = GetMatchHumiditySensorDevice(room);
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.FreshAirHumiditySensor)
+ {
+ roomIncludeMatchDevice.Add(device);
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.PM:
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.PMSensor)
+ {
+ roomIncludeMatchDevice.Add(device);
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.AC:
+ foreach (var de in room.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(de);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.Thermostat)
+ {
+ if (BindInfo.checkRealAcDevice(device) == false)
+ {
+ continue;
+ }
+ roomIncludeMatchDevice.Add(device);
+ }
+ }
+ }
+ break;
+ }
+
+ if (roomIncludeMatchDevice.Count == 0)
+ {
+ continue;
+ }
+
+ if (!string.IsNullOrEmpty(room.FloorId))
+ {
+ //鏈夋ゼ灞�
+ if (room.FloorId == curControlDev.currentSelectFloorId)
+ {
+ roomTempList.Add(room);
+ }
+ }
+ else
+ {
+ //娌℃湁妤煎眰
+ roomTempList.Add(room);
+ }
+ }
+ }
+ return roomTempList;
+ }
+
+ /// <summary>
+ /// 鑾峰彇鏈湴鏈垎閰嶇殑鏀寔褰撳墠绫诲瀷鐨勭粦瀹氳澶囧垪琛�
+ /// </summary>
+ /// <returns></returns>
+ public static List<CommonDevice> GetUndistributeDeviceList(List<CommonDevice> undistruibuteDevList, DeviceBind.BindInfo.BindType curDeviceBindType)
+ {
+ undistruibuteDevList.Clear();
+ List<CommonDevice> UndistributeCommonDeviceListTemp = new List<CommonDevice>();
+
+ //鑾峰彇鏈湴璁惧鍒楄〃
+ foreach (var tempDev in Shared.Common.LocalDevice.Current.listAllDevice)
+ {
+ //鑾峰彇璁惧鎵�灞炴埧闂�
+ var tempDevRoom = HdlRoomLogic.Current.GetRoomByDevice(tempDev);
+ if (tempDevRoom == null)
+ {
+ UndistributeCommonDeviceListTemp.Add(tempDev);
+ }
+ }
+ switch (curDeviceBindType)
+ {
+ case BindType.FreshAir:
+ foreach (var device in UndistributeCommonDeviceListTemp)
+ {
+ if (BindInfo.checkRealFreshAirDevice(device) == false)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.FreshAir)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ break;
+ case BindType.Temperature:
+ foreach (var device in UndistributeCommonDeviceListTemp)
+ {
+ //鐢垫睜璁惧涓嶆敮鎸佺粦瀹�
+ if (device.ZigbeeType != 1)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.TemperatureSensor)
+ {
+ var dev = device as TemperatureSensor;
+ if (dev.SensorDiv == 1)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ else if (device.Type == DeviceType.PMSensor)
+ {
+ var dev = device as PMSensor;
+ foreach (var clu in dev.InClusterList)
+ {
+ if (clu.InCluster == 1026)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ }
+ }
+ break;
+ case BindType.Humidity:
+ foreach (var device in UndistributeCommonDeviceListTemp)
+ {
+ //鐢垫睜璁惧涓嶆敮鎸佺粦瀹�
+ if (device.ZigbeeType != 1)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.TemperatureSensor)
+ {
+ var dev = device as TemperatureSensor;
+ if (dev.SensorDiv == 2)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ else if (device.Type == DeviceType.PMSensor)
+ {
+ var dev = device as PMSensor;
+ foreach (var clu in dev.InClusterList)
+ {
+ if (clu.InCluster == 1029)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ }
+ if (device.Type == DeviceType.FreshAirHumiditySensor)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ break;
+ case BindType.PM:
+ foreach (var device in UndistributeCommonDeviceListTemp)
+ {
+ if (device.Type == DeviceType.PMSensor)
+ {
+ undistruibuteDevList.Add(device);
+ }
+ }
+ break;
+ case BindType.AC:
+ foreach (var device in UndistributeCommonDeviceListTemp)
+ {
+ if (device.Type == DeviceType.Thermostat)
+ {
+ if (BindInfo.checkRealAcDevice(device) == false)
+ {
+ continue;
+ }
+ undistruibuteDevList.Add(device);
+ }
+ }
+ break;
+ }
+
+ return undistruibuteDevList;
+ }
+
+ /// <summary>
+ /// 鎵�鏈夋埧闂翠腑鍖归厤鐨勬敮鎸佺粦瀹氱殑鎵�鏈夌洰鏍囧垪琛�
+ /// </summary>
+ /// <returns></returns>
+ public static List<CommonDevice> GetAllRoomSupportDeviceList(List<CommonDevice> currentPanelSupportBindDeviceList, List<Room> supportRoomList, DeviceBind.BindInfo.BindType curDeviceBindType)
+ {
+ currentPanelSupportBindDeviceList.Clear();
+ List<CommonDevice> currentPanelBindSupportDeviceListTemp = new List<CommonDevice>();
+ switch (curDeviceBindType)
+ {
+ case BindInfo.BindType.FreshAir:
+ foreach (var r in supportRoomList)
+ {
+ if (r.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ foreach (var deviceKeys in r.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (BindInfo.checkRealFreshAirDevice(device) == false)
+ {
+ continue;
+ }
+ if (device.Type == DeviceType.FreshAir)
+ {
+ currentPanelBindSupportDeviceListTemp.Add(device);
+ }
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.Temperature:
+ foreach (var r in supportRoomList)
+ {
+ if (r.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ var deviceListTemp = GetMatchTemperatureSensorDevice(r);
+ foreach (var dev in deviceListTemp)
+ {
+ currentPanelBindSupportDeviceListTemp.Add(dev);
+ }
+ }
+ break;
+ case BindInfo.BindType.Humidity:
+ foreach (var r in supportRoomList)
+ {
+ if (r.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ var deviceListTemp = GetMatchHumiditySensorDevice(r);
+ foreach (var dev in deviceListTemp)
+ {
+ currentPanelBindSupportDeviceListTemp.Add(dev);
+ }
+ foreach (var deviceKeys in r.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.FreshAirHumiditySensor)
+ {
+ currentPanelBindSupportDeviceListTemp.Add(device);
+ }
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.PM:
+ foreach (var r in supportRoomList)
+ {
+ if (r.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ foreach (var deviceKeys in r.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.PMSensor)
+ {
+ currentPanelBindSupportDeviceListTemp.Add(device);
+ }
+ }
+ }
+ }
+ break;
+ case BindInfo.BindType.AC:
+ foreach (var r in supportRoomList)
+ {
+ if (r.ListDevice.Count == 0)
+ {
+ continue;
+ }
+ foreach (var deviceKeys in r.ListDevice)
+ {
+ var device = LocalDevice.Current.GetDevice(deviceKeys);
+ if (device != null)
+ {
+ if (device.Type == DeviceType.Thermostat)
+ {
+ if (BindInfo.checkRealAcDevice(device) == false)
+ {
+ continue;
+ }
+ currentPanelBindSupportDeviceListTemp.Add(device);
+ }
+ }
+ }
+ }
+ break;
+ }
+ return currentPanelBindSupportDeviceListTemp;
+ }
+
+ /// <summary>
+ /// 妫�娴嬬洰鏍囨槸鍚﹁缁戝畾杩�
+ /// targetList 鎸夐敭閰嶇疆鐨勭洰鏍囧垪琛�
+ /// oldTargetList 闈㈡澘涓凡缁忓瓨鍦ㄧ殑鐩爣鍒楄〃
+ /// </summary>
+ /// <returns></returns>
+ public static bool checkExistDevice(List<CommonDevice> targetList, List<CommonDevice> oldTargetList)
+ {
+ bool exist = false;
+ foreach (var oldDev in oldTargetList)
+ {
+ var key = oldDev.DeviceAddr + oldDev.DeviceEpoint;
+ var result = targetList.Find(obj => (obj != null) && (obj.DeviceAddr + obj.DeviceEpoint == key));
+ if (result != null)
+ {
+ exist = true;
+ }
+ else
+ {
+ exist = false;
+ }
+ }
+ return exist;
+ }
+
+ /// <summary>
+ /// 鏄惁鏄湡瀹炵殑绌鸿皟璁惧 銆愯繃婊erver绔��
+ /// </summary>
+ /// <param name="device"></param>
+ /// <returns></returns>
+ public static bool checkRealAcDevice(CommonDevice device)
+ {
+ bool result = true;
+ //鑾峰彇璁惧绫诲瀷鐨�
+ var clu = device.OutClusterList.Find((obj) => obj.OutCluster == 513 || obj.OutCluster == 514);
+ if (clu != null)
+ {
+ result = false;
+ }
+ return result;
+ }
+
+ /// <summary>
+ /// 鏄惁鏄湡瀹炵殑鏂伴璁惧 銆愯繃婊erver绔��
+ /// </summary>
+ /// <param name="device"></param>
+ /// <returns></returns>
+ public static bool checkRealFreshAirDevice(CommonDevice device)
+ {
+ bool result = true;
+ //鑾峰彇璁惧绫诲瀷鐨�
+ var clu = device.OutClusterList.Find((obj) => obj.OutCluster == 514);
+ if (clu != null)
+ {
+ result = false;
+ }
+ return result;
+ }
+
+ /// <summary>
+ /// 鏄惁鏄湡瀹炵殑娓╁害璁惧 銆愯繃婊erver绔��
+ /// </summary>
+ /// <param name="device"></param>
+ /// <returns></returns>
+ public static bool checkRealTemperatureDevice(CommonDevice device)
+ {
+ bool result = true;
+ //鑾峰彇璁惧灞炰簬銆愮畝绾﹀鍔熻兘闈㈡澘銆�
+ var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<CommonDevice> { device });
+ if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.ButtonPanel_SimpleMultifunction)
+ {
+ if (device.Type == DeviceType.TemperatureSensor && device.DeviceEpoint == 1)
+ {
+ //绠�绾﹀鍔熻兘闈㈡澘绗�1鍥炶矾鏄竴涓粦瀹氭俯婀垮害浼犳劅鍣ㄧ绫诲瀷锛屼笉鏄湡鐨勬俯婀垮害鐨勪紶鎰熷櫒锛岄渶瑕佸睆钄芥帀
+ result = false;
+ }
+ }
+ return result;
+ }
+
+ /// <summary>
+ /// 妫�娴嬭璁惧鑳藉惁鏄剧ず銆愯繃婊erver绔��
+ /// </summary>
+ /// <param name="device"></param>
+ /// <returns></returns>
+ public static bool CheckCanShowDevice(ZigBee.Device.CommonDevice device, string curDeviceBindType = "AddSwitch")
+ {
+ if (device == null)
+ {
+ return false;
+ }
+ //濡傛灉鏄紶鎰熷櫒锛屾垨鑰呮槸娌℃湁寮�鍏崇皣鐨勮瘽(杩欓噷鍒ゆ柇鐨勬槸杈撳叆绨�)
+ if ((device.Type == ZigBee.Device.DeviceType.IASZone) || InMatchDevice(device, curDeviceBindType) == false)
+ {
+ return false;
+ }
+ return true;
+ }
+
+ /// <summary>
+ /// 妫�娴嬭鎴块棿鑳藉惁鏄剧ず
+ /// </summary>
+ /// <param name="room"></param>
+ /// <returns></returns>
+ public static bool CheckCanShowRoom(Common.Room room, string curDeviceBindType = "AddSwitch")
+ {
+ if (room.ListDevice.Count == 0)
+ {
+ return false;
+ }
+ if (room.IsLove == true)
+ {
+ return false;
+ }
+ foreach (var deviceKeys in room.ListDevice)
+ {
+ var device = Common.LocalDevice.Current.GetDevice(deviceKeys);
+ //妫�娴嬭璁惧鑳藉惁鏄剧ず
+ if (CheckCanShowDevice(device, curDeviceBindType) == false)
+ {
+ continue;
+ }
+
+ //瀛樺湪璁惧鐨勮瘽锛屾鎴块棿鍙互鏄剧ず
+ return true;
+ }
+ return false;
+ }
+
+ /// <summary>
+ /// 妫�娴嬭澶囨槸鍚︽嫢鏈夊紑鍏崇殑鍔熻兘(杈撳叆绨�)
+ /// </summary>
+ /// <param name="device"></param>
+ /// <returns></returns>
+ public static bool InMatchDevice(CommonDevice device, string curDeviceBindType = "AddSwitch")
+ {
+ foreach (var data in device.InClusterList)
+ {
+ switch (curDeviceBindType)
+ {
+ case "AddSwitch":
+ //鎷ユ湁on/off鍔熻兘鐨勶紝鎵嶆敮鎸佹祴璇�
+ if (data.InCluster == 6)
+ {
+ return true;
+ }
+ break;
+ case "AddDimmer":
+ if (data.InCluster == 8)
+ {
+ return true;
+ }
+ break;
+ case "AddCurtain":
+ if (data.InCluster == 258)
+ {
+ return true;
+ }
+ break;
+ }
+ }
+ return false;
+ }
/// <summary>
/// 妫�娴嬫帶鍒堕潰鏉�(鎸夐敭绫�)鎵�鎷ユ湁鐨勫姛鑳�,鐜版敮鎸佺殑鏈変互涓嬪嚑绉�(蹇呭畾瀛樺湪閿��,鍑洪敊浼氳繑鍥瀗ull)
@@ -223,399 +1057,26 @@
}
}
}
-
return dicCheck;
}
- #region 绉佹湁鏁版嵁澶囦唤姝ラ(鏈夌敤浠g爜锛岃繖閲屽厛娉ㄩ噴鎺夛級
- // title.MouseLongEventHandler += async(sender, e) =>
- // {
- // string fileName = "Panel_";
- // fileName += currentKey.FilePath;
- // var file = await System.Threading.Tasks.Task.Factory.StartNew(() => Newtonsoft.Json.JsonConvert.SerializeObject(currentKey));
- // var data = System.Text.Encoding.UTF8.GetBytes(file);
- // //缃戝叧涓垱寤哄瓨鍌ㄦ暟鎹殑鏂囦欢
- // var saveFile = await currentKey.Gateway.CreateFileAsync(fileName);
- // //涓婁紶鏁版嵁鍒扮綉鍏�
- // var saveData = await currentKey.Gateway.SendFileAsync(data);
- // };
-
- // //瀛樺偍涓嬭浇鐨勬枃浠舵暟鎹�
- // var byteSource = new System.Collections.Generic.List<byte>();
- // if (byteSource != null)
- // {
- // //鎭㈠鏁版嵁瀵硅薄
- // var realDa = Newtonsoft.Json.JsonConvert.DeserializeObject<Panel>(System.Text.Encoding.UTF8.GetString(byteSource.ToArray()));
- //}
-
- ////涓嬭浇鎭㈠绉佹湁鏁版嵁
- //title.MouseUpEventHandler +=async(sender, e) =>
- // {
- // var key11 = currentKey;
- //string fileName = "Panel_";
- //fileName += currentKey.FilePath;
- // //鑾峰彇褰撳墠鏂囦欢鐨勫叿浣撲俊鎭�
- // var getFileSize = await currentKey.Gateway.GetCurrentFileInfoAsync(fileName);
- ////涓嬭浇鏂囦欢
- //var saveFileName = await currentKey.Gateway.SetDownloadFileAsync(fileName);
- ////鎺ユ敹鏁版嵁
- //Action<string, byte[]> action = (topic, dataContent) =>
- //{
- // if (topic.Split('/')[0] + "/" + topic.Split('/')[1] + "/" + topic.Split('/')[2] == topic.Split('/')[0] + "/" + "FileTransfer/DownloadFile")
- // {
- // byte[] fileBytes = dataContent;
- // if (fileBytes[5] != 1)
- // {
- // if (fileBytes.Length == 2056)
- // {
- // var tempBytes = new byte[2048];
- // System.Array.Copy(fileBytes, 8, tempBytes, 0, 2048);
- // byteSource.AddRange(tempBytes);
- // }
- // else
- // {
- // var tempBytes = new byte[fileBytes.Length - 8];
- // System.Array.Copy(fileBytes, 8, tempBytes, 0, tempBytes.Length);
- // byteSource.AddRange(tempBytes);
- // }
- // }
- // else
- // {
- // var tempBytes = new byte[fileBytes.Length - 8];
- // System.Array.Copy(fileBytes, 8, tempBytes, 0, tempBytes.Length);
- // byteSource.AddRange(tempBytes);
- // }
-
- // }
- //};
- //currentKey.Gateway.FileContentAction += action;
- //};
- #endregion
-
- ///// <summary>
- ///// 鍒楄〃鎺т欢
- ///// </summary>
- //private VerticalScrolViewLayout listView = null;
- ///// <summary>
- ///// 宸茬粡瀛樺湪鐨勭粦瀹氳澶�
- ///// </summary>
- //private Dictionary<string, CommonDevice> dicEsixtDevice = new Dictionary<string, CommonDevice>();
-
- ///// <summary>
- ///// 鑾峰彇璁惧鐨勫敮涓�涓婚敭
- ///// </summary>
- ///// <param name="device"></param>
- ///// <returns></returns>
- //public string GetDeviceMainKeys(CommonDevice device)
- //{
- // return device.DeviceAddr + device.DeviceEpoint;
- //}
-
- ///// <summary>
- ///// 鏄剧ず閿欒淇℃伅绐楀彛
- ///// </summary>
- ///// <param name="msg"></param>
- //private void ShowErrorMsg(string msg)
- //{
- // Application.RunOnMainThread(() =>
- // {
- // var contr = new Phone.UserCenter.ErrorMsgControl(msg);
- // contr.Show();
- // });
- //}
-
- ///// <summary>
- ///// 鏄剧ずTip淇℃伅绐楀彛
- ///// </summary>
- ///// <param name="msg"></param>
- //private void ShowTipMsg(string msg)
- //{
- // Application.RunOnMainThread(() =>
- // {
- // var contr = new Phone.UserCenter.TipViewControl(msg);
- // contr.ShowView();
- // });
- //}
-
- ///// <summary>
- ///// 鏄剧ず涓�涓渶瑕佺‘璁ょ殑淇℃伅妗�
- ///// </summary>
- ///// <param name="msg">淇℃伅</param>
- ///// <param name="methodName">鏂规硶鍚�(璇风‘璁よ繖鏄竴涓叡鏈夋柟娉�)</param>
- ///// <param name="obj">鍥炶皟鍑芥暟鐨勫惎鍔ㄥ弬鏁�</param>
- //public void ShowConfirmMsg(string msg, string methodName = null, params object[] obj)
- //{
- // Application.RunOnMainThread(() =>
- // {
- // var alert = new ConfirmMsgControl(msg);
- // alert.Show();
-
- // if (methodName != null)
- // {
- // alert.ResultEventHandler += (sender, result) =>
- // {
- // if (result == true)
- // {
- // this.LoadFormMethodByName(this, methodName, obj);
- // }
- // };
- // }
- // });
- //}
-
- ///// <summary>
- ///// 鎵ц鎸囧畾鐢婚潰鐨勬柟娉�
- ///// </summary>
- ///// <param name="form">鎸囧畾鐢婚潰鐨勮嫳鏂囧悕</param>
- ///// <param name="method">鎸囧畾瑕佸姞杞界殑鏂规硶鍚�</param>
- ///// <param name="parameter">鍚姩鍙傛暟</param>
- //public object LoadFormMethodByName(BindInfo form, string method, params object[] parameter)
- //{
- // return form.GetType().InvokeMember(method, System.Reflection.BindingFlags.InvokeMethod, null, form, parameter);
- //}
-
- ///// <summary>
- ///// 娣诲姞鐢婚潰,鍚姩鍙傛暟鐢辨寚瀹氱敾闈㈢殑ShowForm鍑芥暟鎵�鎸囧畾
- ///// </summary>
- ///// <param name="newform">瀵硅薄鐢婚潰</param>
- ///// <param name="parameter">鍚姩鍙傛暟锛氬弬鏁扮敱鎸囧畾鐢婚潰鐨凷howForm鍑芥暟鎵�鎸囧畾</param>
- //public void AddForm(UserCenterCommonForm newform, params object[] parameter)
- //{
- // //妫�娴嬭兘鍚﹁拷鍔犵敾闈�(闃叉鐢婚潰浜岄噸娣诲姞)锛屽綋鐐瑰嚮杩囧揩鏃讹紝浼氭湁鍑犵巼浜岄噸娣诲姞
- // if (UserCenterLogic.CheckCanAddForm(newform) == false)
- // {
- // return;
- // }
- // newform.FormID = UserCenterLogic.GetFormName(newform);
-
- // UserView.HomePage.Instance.AddChidren(newform);
- // UserView.HomePage.Instance.PageIndex += 1;
- // //鍒濆鍖栫晫闈㈡鏋�
- // newform.InitForm(parameter);
- // //鎵цShowForm()鏂规硶
- // newform.LoadShowFormMethod(parameter);
- //}
-
- ///// <summary>
- ///// 鑳界粦瀹氬埌鎸夐敭鐨勮澶�
- ///// </summary>
- ///// <param name="device"></param>
- ///// <returns></returns>
- //public bool SupportDevice(CommonDevice device,int currentClusterID)
- //{
- // foreach (var data in device.InClusterList)
- // {
- // //鎷ユ湁on/off鍔熻兘鐨勶紝鎵嶆敮鎸佹祴璇�
- // if (data.InCluster == currentClusterID)
- // {
- // return true;
- // }
- // }
- // return false;
- //}
-
- ///// <summary>
- ///// 缁戝畾PIR浼犳劅鍣ㄧ殑鐩爣(杩斿洖鎴愬姛璁剧疆鐨勮澶�,閿欒鏃讹紝杩斿洖null)
- ///// </summary>
- ///// <param name="i_iasZone">浼犳劅鍣�</param>
- ///// <param name="listDevice">瑕佺粦瀹氱殑鐩爣璁惧</param>
- ///// <returns></returns>
- //public async Task<List<CommonDevice>> BindKeyDeviceTargets(Panel key, List<CommonDevice> listDevice,int currentClusterID)
- //{
- // if (listDevice.Count == 0)
- // {
- // return new List<CommonDevice>();
- // }
-
- // var dicDevice = new Dictionary<string, CommonDevice>();
-
- // //缁勮鏁版嵁
- // var addData = new Panel.AddBindData();
- // addData.DeviceAddr = key.DeviceAddr;
- // addData.Epoint = key.DeviceEpoint;
- // foreach (var device in listDevice)
- // {
- // var info = new Panel.AddBindListObj();
- // info.BindCluster = currentClusterID;
- // info.BindMacAddr = device.DeviceAddr;
- // info.BindEpoint = device.DeviceEpoint;
- // info.BindType = 0;
-
- // addData.BindList.Add(info);
-
- // //杩斿洖鎴愬姛璁惧鐨勬椂鍊欎娇鐢�
- // string mainkeys = Common.LocalDevice.Current.GetDeviceMainKeys(device);
- // dicDevice[mainkeys] = device;
- // }
-
- // var result = await key.AddDeviceBindAsync(addData);
- // if (result.addedDeviceBindResponseData == null)
- // {
- // //濡傛灉缃戝叧宸茬粡鎺夌嚎
- // bool flage = Common.LocalGateway.Current.CheckGatewayOnLineOnTimeout(key.CurrentGateWayId, result.errorMessageBase);
- // if (flage == false)
- // {
- // return null;
- // }
- // //缁戝畾鐩爣璁剧疆澶辫触
- // string msg = Language.StringByID(R.MyInternationalizationString.uSetBindTargetsFail);
- // //鎷兼帴涓娿�愮綉鍏冲洖澶嶈秴鏃躲�戠殑Msg
- // msg = UserCenterLogic.CombineGatewayTimeOutMsg(msg);
-
- // this.ShowErrorMsg(msg);
- // return null;
- // }
-
- // var listSuccess = new List<CommonDevice>();
- // foreach (var data in result.addedDeviceBindResponseData.BindList)
- // {
- // string mainkeys = Common.LocalDevice.Current.GetDeviceMainKeys(data.BindMacAddr, data.BindEpoint);
- // //0:娣诲姞鎴愬姛 3:宸茬粡瀛樺湪锛屼篃鍙互浠h〃鎴愬姛
- // if (data.Result == 0 || data.Result == 3)
- // {
- // if (dicDevice.ContainsKey(mainkeys) == true)
- // {
- // listSuccess.Add(dicDevice[mainkeys]);
- // }
- // }
- // //1锛氬け璐ワ紝鑺傜偣璁惧鎴栧満鏅笉瀛樺湪
- // else if (data.Result == 1)
- // {
- // if (dicDevice.ContainsKey(mainkeys) == true)
- // {
- // //璁惧鍚嶇О 缁戝畾澶辫触
- // string msg = Shared.Common.LocalDevice .Current.GetDeviceEpointName(dicDevice[mainkeys]) + " ";
- // msg += Language.StringByID(R.MyInternationalizationString.BindFailed);
- // this.ShowTipMsg(msg);
- // }
- // }
- // //2锛氭湭鐭ワ紝鐢辫妭鐐硅澶囧弽棣堝彂閫佲�淏ind/BindResult鈥濅富棰樻秷鎭‘瀹氭槸鍚︽垚鍔�
- // else if (data.Result == 2)
- // {
- // if (result.addBindResultResponseData == null)
- // {
- // //璁惧鍚嶇О 缁戝畾澶辫触
- // string msg = Shared.Common.LocalDevice.Current.GetDeviceEpointName(dicDevice[mainkeys]) + " ";
- // msg += Language.StringByID(R.MyInternationalizationString.BindFailed);
- // this.ShowTipMsg(msg);
- // }
- // else
- // {
- // //娣诲姞鎴愬姛
- // if (result.addBindResultResponseData.Result == 0)
- // {
- // if (dicDevice.ContainsKey(mainkeys) == true)
- // {
- // listSuccess.Add(dicDevice[mainkeys]);
- // }
- // }
- // //璁惧鍚嶇О 缁戝畾鍒楄〃宸叉弧
- // else if (result.addBindResultResponseData.Result == 140)
- // {
- // string msg = Shared.Common.LocalDevice.Current.GetDeviceEpointName(dicDevice[mainkeys]) + " ";
- // msg += Language.StringByID(R.MyInternationalizationString.uBindListIsFull);
- // this.ShowTipMsg(msg);
- // }
- // else
- // {
- // //璁惧鍚嶇О 缁戝畾澶辫触
- // string msg = Shared.Common.LocalDevice.Current.GetDeviceEpointName(dicDevice[mainkeys]) + " ";
- // msg += Language.StringByID(R.MyInternationalizationString.BindFailed);
- // this.ShowTipMsg(msg);
- // }
- // }
- // }
- // }
-
- // return listSuccess;
- //}
-
- ///// <summary>
- ///// 鏄剧ず璁惧閫夋嫨鐨勭晫闈�
- ///// </summary>
- //public void ShowDeviceSelectForm(Panel key, int currentClusterID)
- //{
- // var listShowDevice = new List<CommonDevice>();
- // foreach (var device in PanelBindPage.list)
- // {
- // if (SupportDevice(device, currentClusterID) == false)
- // {
- // continue;
- // }
-
- // string mainKeys = this.GetDeviceMainKeys(device);
- // if (this.dicEsixtDevice.ContainsKey(mainKeys) == true)
- // {
- // //濡傛灉宸茬粡娣诲姞浜嗭紝鍒欎笉鍐嶆樉绀�
- // continue;
- // }
-
- // listShowDevice.Add(device);
- // }
-
- // var listSelect = new List<string>();
- // foreach (string mainkeys in this.dicEsixtDevice.Keys)
- // {
- // listSelect.Add(mainkeys);
- // }
-
- // var form = new SelectDeviceForm();
- // this.AddForm(form, listShowDevice, listSelect, false);
- // //娣诲姞缁戝畾鐩爣
- // form.SetTitleText(Language.StringByID(R.MyInternationalizationString.AddBindTargets));
-
- // //璁惧閫夋嫨纭畾
- // form.ActionSelectDevice += (async (listDevice) =>
- // {
- // if (listDevice.Count == 0)
- // {
- // return;
- // }
-
- // var listNewDevice = await this.BindKeyDeviceTargets(key, listDevice,currentClusterID);
-
- // if (listNewDevice == null || listNewDevice.Count == 0)
- // {
- // return;
- // }
-
- // foreach (CommonDevice device in listNewDevice)
- // {
- // string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(device);
- // this.dicEsixtDevice[mainKeys] = device;
-
- // Application.RunOnMainThread(() =>
- // {
- // this.AddRowlayout(device);
- // });
- // }
- // });
- //}
-
- ///// <summary>
- ///// 娣诲姞琛�
- ///// </summary>
- ///// <param name="device"></param>
- //private void AddRowlayout(CommonDevice device)
- //{
- // string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(device);
- // this.dicEsixtDevice[mainKeys] = device;
-
- // var row = new DeviceRoomViewRow(this.listView, device);
- // row.ChangedChidrenBindMode(row.btnIcon, ChidrenBindMode.BindEventOnly);
- // row.ChangedChidrenBindMode(row.btnRoom, ChidrenBindMode.BindEventOnly);
- // row.ChangedChidrenBindMode(row.btnDevie, ChidrenBindMode.BindEventOnly);
-
- // //鍒犻櫎
- // var btnDelete = new RowDeleteButton();
- // row.AddRightView(btnDelete);
- // btnDelete.MouseUpEventHandler += (sender, e) =>
- // {
- // //纭瑕佸垹闄ゅ悧锛�
- // string msg = Language.StringByID(R.MyInternationalizationString.uShowDoDeleteMsg);
- // this . ShowConfirmMsg(msg, "DeleteTargetDevice", device, row);
- // };
- //}
-
+ /// <summary>
+ /// 搴曢儴瀹屾垚鎸夐挳鏄剧ず
+ /// </summary>
+ /// <returns></returns>
+ public static void FinishDisplay(List<Room> roomTempList, Button btnFinish)
+ {
+ if (roomTempList.Count == 0)
+ {
+ btnFinish.Enable = false;
+ btnFinish.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+ }
+ else
+ {
+ btnFinish.Enable = true;
+ btnFinish.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+ }
+ }
+ #endregion
}
}
--
Gitblit v1.8.0