mirror of
https://github.com/XiaoMi/ha_xiaomi_home.git
synced 2026-01-12 20:00:42 +08:00
Compare commits
5 Commits
d2a65bc562
...
df0b0ed73a
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
df0b0ed73a | ||
|
|
b40d357230 | ||
|
|
30a78c7689 | ||
|
|
eec13826d2 | ||
|
|
bf1caf50e1 |
@ -107,6 +107,7 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
||||
_prop_position_value_range: Optional[int]
|
||||
_prop_pos_closing: bool
|
||||
_prop_pos_opening: bool
|
||||
_reverse_position: bool
|
||||
|
||||
def __init__(self, miot_device: MIoTDevice,
|
||||
entity_data: MIoTEntityData) -> None:
|
||||
@ -134,6 +135,8 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
||||
self._prop_position_value_range = None
|
||||
self._prop_pos_closing = False
|
||||
self._prop_pos_opening = False
|
||||
# 新增:针对airer类型设备反转位置
|
||||
self._reverse_position = (entity_data.spec.device_class == CoverDeviceClass.BLIND)
|
||||
|
||||
# properties
|
||||
for prop in entity_data.props:
|
||||
@ -143,6 +146,8 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
||||
self.entity_id)
|
||||
continue
|
||||
for item in prop.value_list.items:
|
||||
item_str: str = item.name
|
||||
item_name: str = re.sub(r'[^a-z]', '', item_str)
|
||||
if item.name in {'open', 'up'}:
|
||||
self._attr_supported_features |= (
|
||||
CoverEntityFeature.OPEN)
|
||||
@ -255,6 +260,10 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
||||
if current is not None:
|
||||
self._prop_pos_opening = pos > current
|
||||
self._prop_pos_closing = pos < current
|
||||
# 针对airer类型设备反转位置
|
||||
if self._reverse_position:
|
||||
pos = 100 - pos
|
||||
|
||||
pos = round(pos * self._prop_position_value_range / 100)
|
||||
await self.set_property_async(prop=self._prop_target_position,
|
||||
value=pos)
|
||||
@ -282,6 +291,9 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
||||
pos = 0
|
||||
elif pos >= (100 - self._cover_dead_zone_width):
|
||||
pos = 100
|
||||
# 针对airer类型设备反转位置
|
||||
if self._reverse_position:
|
||||
pos = 100 - pos
|
||||
return pos
|
||||
|
||||
@property
|
||||
|
||||
@ -1527,6 +1527,8 @@ class MIoTClient:
|
||||
if did not in filter_dids:
|
||||
continue
|
||||
device_old = self._device_list_gateway.get(did, None)
|
||||
gw_state_old = device_old.get(
|
||||
'online', False) if device_old else False
|
||||
gw_state_new: bool = False
|
||||
device_new = gw_list.pop(did, None)
|
||||
if device_new:
|
||||
@ -1540,7 +1542,7 @@ class MIoTClient:
|
||||
device_old['online'] = False
|
||||
# Update cache group_id
|
||||
info['group_id'] = group_id
|
||||
if not gw_state_new:
|
||||
if (gw_state_old == gw_state_new) and (not gw_state_new):
|
||||
continue
|
||||
self.__update_device_msg_sub(did=did)
|
||||
state_old: Optional[bool] = info.get('online', None)
|
||||
|
||||
Loading…
Reference in New Issue
Block a user