HDL Home App 第二版本 旧平台金堂用 正在使用
黄学彪
2021-01-14 d78515ac4ac8cf4a1785d9df18058d6724f12b79
ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/PaneTargetsBaseForm.cs
@@ -17,7 +17,7 @@
        /// 构造函数
        /// </summary>
        /// <param name="device"></param>
        /// <param name="deviceBindType">1:新风;2:温度传感器;3:湿度传感器;4:PM2.5传感器;5:空调目标,6:地暖目标【暂时没做,因为没有该设备,后期增加】</param>
        /// <param name="deviceBindType">1:新风;2:温度传感器;3:湿度传感器;4:PM2.5传感器;5:空调目标,6:地暖目标,7:Co2目标</param>
        /// <param name="bindDev">绑定目标 </param>
        public PaneTargetsBaseForm(CommonDevice device, CommonDevice bindDev, DeviceBind.BindInfo.BindType deviceBindType)
        {
@@ -71,7 +71,8 @@
        /// 3:湿度传感器
        /// 4:PM2.5传感器
        /// 5:空调目标
        /// 6:地暖目标【暂时没做,因为没有该设备,后期增加】
        /// 6:地暖目标
        /// 7:Co2目标
        /// </summary>
        DeviceBind.BindInfo.BindType curDeviceBindType = 0;
        /// <summary>
@@ -131,6 +132,10 @@
        /// </summary>
        public Action<string> actionPMTarget = null;
        /// <summary>
        /// Co2绑定目标回调
        /// </summary>
        public Action<string> actionCo2Target = null;
        /// <summary>
        /// Ac绑定目标回调
        /// </summary>
        public Action<string> actionAcTarget = null;
@@ -184,6 +189,9 @@
                case DeviceBind.BindInfo.BindType.Fh:
                    titleText = Language.StringByID(R.MyInternationalizationString.uFloorHeatingTarget);
                    break;
                    //case DeviceBind.BindInfo.BindType.CO2:
                    //titleText = Language.StringByID(R.MyInternationalizationString.CO2Source);
                    //break;
            }
            this.TopFrameLayout(this, titleText);
            EventHandler<MouseEventArgs> eHandlerBack = (sender, e) =>
@@ -564,6 +572,8 @@
                {
                    btnBindName.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
                }
                //获取设备类型
                var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<ZigBee.Device.CommonDevice>() { device });
                switch (curDeviceBindType)
                {
                    case DeviceBind.BindInfo.BindType.FreshAir:
@@ -575,6 +585,11 @@
                        {
                            btnBindName.Text = Common.LocalDevice.Current.GetDeviceEpointName(device) + "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                        }
                        //空气质量传感器
                        if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                        {
                            btnBindName.Text = Common.LocalDevice.Current.GetDeviceEpointName(device) + "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                        }
                        break;
                    case DeviceBind.BindInfo.BindType.Humidity:
                        devicePic.UnSelectedImagePath = "Device/SensorHumidity.png";
@@ -582,8 +597,16 @@
                        {
                            btnBindName.Text = Common.LocalDevice.Current.GetDeviceEpointName(device) + "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                        }
                        //空气质量传感器
                        if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                        {
                            btnBindName.Text = Common.LocalDevice.Current.GetDeviceEpointName(device) + "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                        }
                        break;
                    case DeviceBind.BindInfo.BindType.PM:
                        devicePic.UnSelectedImagePath = "Device/AirQualitySensorEpoint.png";
                        break;
                    case DeviceBind.BindInfo.BindType.CO2:
                        devicePic.UnSelectedImagePath = "Device/AirQualitySensorEpoint.png";
                        break;
                    case DeviceBind.BindInfo.BindType.AC:
@@ -848,6 +871,8 @@
                                    else
                                    {
                                        curControlDev.currentSelectRoomId = "UndistributedId";
                                        //目标在未分配时,默认第一个楼层
                                        curControlDev.currentSelectFloorId = BindInfo.GetCurrentSelectFloorId();
                                    }
                                }
@@ -862,11 +887,31 @@
                                            {
                                                bindName += "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                                            }
                                            if (dev.Type == ZigBee.Device.DeviceType.TemperatureSensor)
                                            {
                                                //获取设备类型
                                                var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<ZigBee.Device.CommonDevice>() { dev });
                                                //空气质量传感器
                                                if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                                                {
                                                    bindName += "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                                                }
                                            }
                                            break;
                                        case BindInfo.BindType.Humidity:
                                            if (dev.Type == DeviceType.PMSensor)
                                            {
                                                bindName += "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                                            }
                                            if (dev.Type == ZigBee.Device.DeviceType.TemperatureSensor)
                                            {
                                                //获取设备类型
                                                var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<ZigBee.Device.CommonDevice>() { dev });
                                                //空气质量传感器
                                                if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                                                {
                                                    bindName += "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                                                }
                                            }
                                            break;
                                    }
@@ -1192,11 +1237,17 @@
                                case BindInfo.BindType.AC:
                                    addBindInfo.BindCluster = 513;
                                    break;
                                case BindInfo.BindType.CO2:
                                    addBindInfo.BindCluster = 1037;
                                    break;
                            }
                            addBindInfo.BindType = 0;
                            addBindInfo.BindMacAddr = de.DeviceAddr;
                            addBindInfo.BindEpoint = de.DeviceEpoint;
                            addBindeDev.BindName = Common.LocalDevice.Current.GetDeviceEpointName(de);
                            //获取设备类型
                            var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<ZigBee.Device.CommonDevice>() { de });
                            switch (curDeviceBindType)
                            {
                                case BindInfo.BindType.Temperature:
@@ -1204,9 +1255,20 @@
                                    {
                                        addBindeDev.BindName = Common.LocalDevice.Current.GetDeviceEpointName(de) + "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                                    }
                                    //空气质量传感器
                                    if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                                    {
                                        addBindeDev.BindName = Common.LocalDevice.Current.GetDeviceEpointName(de) + "-" + Language.StringByID(R.MyInternationalizationString.TemperatureSensor);
                                    }
                                    break;
                                case BindInfo.BindType.Humidity:
                                    if (de.Type == DeviceType.PMSensor)
                                    {
                                        addBindeDev.BindName = Common.LocalDevice.Current.GetDeviceEpointName(de) + "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                                    }
                                    //空气质量传感器
                                    if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                                    {
                                        addBindeDev.BindName = Common.LocalDevice.Current.GetDeviceEpointName(de) + "-" + Language.StringByID(R.MyInternationalizationString.HumiditySensor);
                                    }
@@ -1402,11 +1464,12 @@
        /// <param name="bindDev"></param>
        void BindTypeTargetsList(CommonDevice device, BindListResponseObj bindDev)
        {
            //获取设备类型的
            var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<CommonDevice>() { device });
            switch (curDeviceBindType)
            {
                case BindInfo.BindType.FreshAir:
                    //获取设备类型的
                    var deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(new List<CommonDevice>() { device });
                    //新风面板的新风设备,则不显示
                    if (deviceEnumInfo.ConcreteType != Common.DeviceConcreteType.ButtonPanel_FangyueFreshAir)
                    {
@@ -1422,7 +1485,18 @@
                        var bDev = device as TemperatureSensor;
                        if (bDev.SensorDiv == 1)
                        {
                            oldTargetList.Add(device);
                            //空气质量传感器
                            if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                            {
                                if (bindDev.BindCluster == 1026)
                                {
                                    oldTargetList.Add(device);
                                }
                            }
                            else
                            {
                                oldTargetList.Add(device);
                            }
                        }
                    }
                    if (device.Type == DeviceType.PMSensor)
@@ -1440,6 +1514,15 @@
                        if (bDev.SensorDiv == 2)
                        {
                            oldTargetList.Add(device);
                        }
                        //空气质量传感器
                        if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                        {
                            if (bindDev.BindCluster == 1029)
                            {
                                oldTargetList.Add(device);
                            }
                        }
                    }
                    if (device.Type == DeviceType.FreshAirHumiditySensor)
@@ -1462,6 +1545,17 @@
                            oldTargetList.Add(device);
                        }
                    }
                    else if (device.Type == ZigBee.Device.DeviceType.TemperatureSensor)
                    {
                        //空气质量传感器
                        if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                        {
                            if (bindDev.BindCluster == 1066)
                            {
                                oldTargetList.Add(device);
                            }
                        }
                    }
                    break;
                case BindInfo.BindType.AC:
                    if (device.Type == DeviceType.Thermostat)
@@ -1472,6 +1566,19 @@
                        }
                    }
                    break;
                case BindInfo.BindType.CO2:
                    if (device.Type == ZigBee.Device.DeviceType.TemperatureSensor)
                    {
                        //空气质量传感器
                        if (deviceEnumInfo.ConcreteType == Common.DeviceConcreteType.AirQualitySensor)
                        {
                            if (bindDev.BindCluster == 1037)
                            {
                                oldTargetList.Add(device);
                            }
                        }
                    }
                    break;
            }
            targetList.Clear();