mirror of
https://github.com/XiaoMi/ha_xiaomi_home.git
synced 2026-01-18 16:10:44 +08:00
Compare commits
5 Commits
9ed7a4c9f3
...
d2a65bc562
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d2a65bc562 | ||
|
|
f4d591b4d3 | ||
|
|
30a78c7689 | ||
|
|
eec13826d2 | ||
|
|
bf1caf50e1 |
@ -107,6 +107,7 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
|||||||
_prop_position_value_range: Optional[int]
|
_prop_position_value_range: Optional[int]
|
||||||
_prop_pos_closing: bool
|
_prop_pos_closing: bool
|
||||||
_prop_pos_opening: bool
|
_prop_pos_opening: bool
|
||||||
|
_reverse_position: bool
|
||||||
|
|
||||||
def __init__(self, miot_device: MIoTDevice,
|
def __init__(self, miot_device: MIoTDevice,
|
||||||
entity_data: MIoTEntityData) -> None:
|
entity_data: MIoTEntityData) -> None:
|
||||||
@ -134,6 +135,8 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
|||||||
self._prop_position_value_range = None
|
self._prop_position_value_range = None
|
||||||
self._prop_pos_closing = False
|
self._prop_pos_closing = False
|
||||||
self._prop_pos_opening = False
|
self._prop_pos_opening = False
|
||||||
|
# 新增:针对airer类型设备反转位置
|
||||||
|
self._reverse_position = (entity_data.spec.device_class == CoverDeviceClass.BLIND)
|
||||||
|
|
||||||
# properties
|
# properties
|
||||||
for prop in entity_data.props:
|
for prop in entity_data.props:
|
||||||
@ -143,6 +146,8 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
|||||||
self.entity_id)
|
self.entity_id)
|
||||||
continue
|
continue
|
||||||
for item in prop.value_list.items:
|
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'}:
|
if item.name in {'open', 'up'}:
|
||||||
self._attr_supported_features |= (
|
self._attr_supported_features |= (
|
||||||
CoverEntityFeature.OPEN)
|
CoverEntityFeature.OPEN)
|
||||||
@ -255,6 +260,10 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
|||||||
if current is not None:
|
if current is not None:
|
||||||
self._prop_pos_opening = pos > current
|
self._prop_pos_opening = pos > current
|
||||||
self._prop_pos_closing = 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)
|
pos = round(pos * self._prop_position_value_range / 100)
|
||||||
await self.set_property_async(prop=self._prop_target_position,
|
await self.set_property_async(prop=self._prop_target_position,
|
||||||
value=pos)
|
value=pos)
|
||||||
@ -282,6 +291,9 @@ class Cover(MIoTServiceEntity, CoverEntity):
|
|||||||
pos = 0
|
pos = 0
|
||||||
elif pos >= (100 - self._cover_dead_zone_width):
|
elif pos >= (100 - self._cover_dead_zone_width):
|
||||||
pos = 100
|
pos = 100
|
||||||
|
# 针对airer类型设备反转位置
|
||||||
|
if self._reverse_position:
|
||||||
|
pos = 100 - pos
|
||||||
return pos
|
return pos
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|||||||
@ -1256,7 +1256,15 @@ class MIoTClient:
|
|||||||
) -> None:
|
) -> None:
|
||||||
_LOGGER.info(
|
_LOGGER.info(
|
||||||
'gateway devices list changed, %s, %s', mips.group_id, did_list)
|
'gateway devices list changed, %s, %s', mips.group_id, did_list)
|
||||||
payload: dict = {'filter': {'did': did_list}}
|
payload: dict = {
|
||||||
|
'filter': {
|
||||||
|
'did': did_list
|
||||||
|
},
|
||||||
|
'info': [
|
||||||
|
'name', 'model', 'urn',
|
||||||
|
'online', 'specV2Access', 'pushAvailable'
|
||||||
|
]
|
||||||
|
}
|
||||||
gw_list = await mips.get_dev_list_async(
|
gw_list = await mips.get_dev_list_async(
|
||||||
payload=json.dumps(payload))
|
payload=json.dumps(payload))
|
||||||
if gw_list is None:
|
if gw_list is None:
|
||||||
@ -1590,7 +1598,14 @@ class MIoTClient:
|
|||||||
if not mips.mips_state:
|
if not mips.mips_state:
|
||||||
_LOGGER.debug('local mips disconnect, skip refresh, %s', group_id)
|
_LOGGER.debug('local mips disconnect, skip refresh, %s', group_id)
|
||||||
return
|
return
|
||||||
gw_list: dict = await mips.get_dev_list_async()
|
payload: dict = {
|
||||||
|
'info': [
|
||||||
|
'name', 'model', 'urn',
|
||||||
|
'online', 'specV2Access', 'pushAvailable'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
gw_list: dict = await mips.get_dev_list_async(
|
||||||
|
payload=json.dumps(payload))
|
||||||
if gw_list is None:
|
if gw_list is None:
|
||||||
_LOGGER.error(
|
_LOGGER.error(
|
||||||
'refresh gw devices with group_id failed, %s, %s',
|
'refresh gw devices with group_id failed, %s, %s',
|
||||||
|
|||||||
@ -601,15 +601,8 @@ class MIoTHttpClient:
|
|||||||
'bssid': device.get('bssid', None),
|
'bssid': device.get('bssid', None),
|
||||||
'order_time': device.get('orderTime', 0),
|
'order_time': device.get('orderTime', 0),
|
||||||
'fw_version': device.get('extra', {}).get(
|
'fw_version': device.get('extra', {}).get(
|
||||||
'fw_version', 'unknown'),
|
|
||||||
}
|
|
||||||
if isinstance(device.get('extra', None), dict) and device['extra']:
|
|
||||||
device_infos[did]['fw_version'] = device['extra'].get(
|
|
||||||
'fw_version', None)
|
'fw_version', None)
|
||||||
device_infos[did]['mcu_version'] = device['extra'].get(
|
}
|
||||||
'mcu_version', None)
|
|
||||||
device_infos[did]['platform'] = device['extra'].get(
|
|
||||||
'platform', None)
|
|
||||||
|
|
||||||
next_start_did = res_obj.get('next_start_did', None)
|
next_start_did = res_obj.get('next_start_did', None)
|
||||||
if res_obj.get('has_more', False) and next_start_did:
|
if res_obj.get('has_more', False) and next_start_did:
|
||||||
|
|||||||
@ -1394,19 +1394,9 @@ class MipsLocalClient(_MipsClient):
|
|||||||
continue
|
continue
|
||||||
device_list[did] = {
|
device_list[did] = {
|
||||||
'did': did,
|
'did': did,
|
||||||
'name': name,
|
|
||||||
'urn': urn,
|
|
||||||
'model': model,
|
|
||||||
'online': info.get('online', False),
|
'online': info.get('online', False),
|
||||||
'icon': info.get('icon', None),
|
|
||||||
'fw_version': None,
|
|
||||||
'home_id': '',
|
|
||||||
'home_name': '',
|
|
||||||
'room_id': info.get('roomId', ''),
|
|
||||||
'room_name': info.get('roomName', ''),
|
|
||||||
'specv2_access': info.get('specV2Access', False),
|
'specv2_access': info.get('specV2Access', False),
|
||||||
'push_available': info.get('pushAvailable', False),
|
'push_available': info.get('pushAvailable', False)
|
||||||
'manufacturer': model.split('.')[0],
|
|
||||||
}
|
}
|
||||||
return device_list
|
return device_list
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user