xiaomi_mi_scale/README.md

131 lines
5.7 KiB
Markdown
Raw Normal View History

2019-05-20 11:26:45 +00:00
# Xiaomi Mi Scale
2020-06-27 19:35:51 +00:00
Code to read weight measurements from Xiaomi Body Scales.
2019-05-20 11:26:45 +00:00
2020-06-27 19:35:51 +00:00
## Supported Scales:
Name | Model | Picture
2020-06-27 19:50:38 +00:00
--- | --- | :---:
[Mi Smart Scale 2](https://www.mi.com/global/scale)                                                                                               | XMTZC04HM | ![Mi Scale_2](Screenshots/Mi_Smart_Scale_2_Thumb.png)
2020-06-27 19:35:51 +00:00
[Mi Body Composition Scale](https://www.mi.com/global/mi-body-composition-scale/) | XMTZC02HM | ![Mi Scale](Screenshots/Mi_Body_Composition_Scale_Thumb.png)
2020-06-27 19:43:49 +00:00
[Mi Body Composition Scale 2](https://c.mi.com/thread-2289389-1-0.html) | XMTZC05HM | ![Mi Body Composition Scale 2](Screenshots/Mi_Body_Composition_Scale_2_Thumb.png)
2019-11-06 09:23:40 +00:00
2019-05-20 11:26:45 +00:00
2020-06-29 13:51:33 +00:00
## Home Assistant Add-On:
2020-07-06 13:11:13 +00:00
If using Home Assistant (formerly known as hass.io), try instead the [Xiaomi Mi Scale Add-On for Home Assistant](https://github.com/lolouk44/hassio-addons/tree/master/mi-scale) based on this repository.
2020-06-29 13:51:33 +00:00
## Getting the Mac Address of your Scale:
2020-07-06 12:09:23 +00:00
1. Retrieve the scale's MAC Address from the Xiaomi Mi Fit App:
2020-07-06 13:32:17 +00:00
2020-07-06 12:09:23 +00:00
![MAC Address](Screenshots/MAC_Address.png)
## Setup & Configuration:
### Running script with Docker:
2019-09-18 21:25:30 +00:00
1. Supported platforms:
2020-07-01 21:32:33 +00:00
1. linux/386
2019-09-18 21:25:30 +00:00
1. linux/amd64
2019-10-07 20:46:42 +00:00
1. linux/arm32v6
1. linux/arm32v7
2019-10-07 20:47:19 +00:00
1. linux/arm64v8
2020-06-01 13:58:09 +00:00
1. Open `docker-compose.yml` (see below) and edit the environment to suit your configuration...
2019-09-18 21:21:21 +00:00
1. Stand up the container - `docker-compose up -d`
### docker-compose:
2020-01-29 15:32:22 +00:00
```yaml
2019-09-18 21:21:21 +00:00
version: '3'
services:
mi-scale:
image: lolouk44/xiaomi-mi-scale:latest
container_name: mi-scale
restart: always
network_mode: host
privileged: true
environment:
2020-06-27 20:02:14 +00:00
- HCI_DEV=hci0 # Bluetooth hci device to use. Defaults to hci0
- MISCALE_MAC=00:00:00:00:00:00 # Mac address of your scale
2020-06-27 20:02:14 +00:00
- MQTT_HOST=127.0.0.1 # MQTT Server (defaults to 127.0.0.1)
2020-09-08 20:58:07 +00:00
- MQTT_PREFIX=miscale # MQTT Topic Prefix. Defaults to miscale
2020-06-27 20:02:14 +00:00
- MQTT_USERNAME= # Username for MQTT server (comment out if not required)
- MQTT_PASSWORD= # Password for MQTT (comment out if not required)
- MQTT_PORT= # Defaults to 1883
- TIME_INTERVAL=30 # Time in sec between each query to the scale, to allow other applications to use the Bluetooth module. Defaults to 30
2020-07-01 21:32:33 +00:00
- MQTT_DISCOVERY=true # Home Assistant Discovery (true/false), defaults to true
- MQTT_DISCOVERY_PREFIX= # Home Assistant Discovery Prefix, defaults to homeassistant
2019-09-18 21:21:21 +00:00
# Auto-gender selection/config -- This is used to create the calculations such as BMI, Water/Bone Mass etc...
2019-09-18 21:34:46 +00:00
# Up to 3 users possible as long as weights do not overlap!
2019-09-18 21:21:21 +00:00
2020-07-08 10:31:50 +00:00
# Here is the logic used to assign a measured weight to a user:
2020-09-08 20:58:07 +00:00
# if [measured value in kg] is greater than USER1_GT, assign it to USER1
# else if [measured value in kg] is less than USER2_LT, assign it to USER2
# else assign it to USER3 (e.g. USER2_LT < [measured value in kg] < USER1_GT)
2020-07-08 10:31:50 +00:00
2020-09-08 20:58:07 +00:00
- USER1_GT=70 # If the weight (in kg) is greater than this number, we'll assume that we're weighing User #1
2020-06-27 20:02:14 +00:00
- USER1_SEX=male # male / female
- USER1_NAME=Jo # Name of the user
- USER1_HEIGHT=175 # Height (in cm) of the user
- USER1_DOB=1990-01-01 # DOB (in yyyy-mm-dd format)
2020-09-08 20:58:07 +00:00
- USER2_LT=35 # If the weight (in kg) is less than this number, we'll assume that we're weighing User #2
2020-06-27 20:02:14 +00:00
- USER2_SEX=female # male / female
- USER2_NAME=Serena # Name of the user
- USER2_HEIGHT=95 # Height (in cm) of the user
- USER2_DOB=1990-01-01 # DOB (in yyyy-mm-dd format)
- USER3_SEX=female # male / female
- USER3_NAME=Missy # Name of the user
- USER3_HEIGHT=150 # Height (in cm) of the user
- USER3_DOB=1990-01-01 # DOB (in yyyy-mm-dd format)
2019-09-18 21:21:21 +00:00
```
2019-09-18 21:25:30 +00:00
### Running script directly on your host system (if your platform is not listed/supported):
2020-06-19 10:52:48 +00:00
**Note: Python 3.6 or higher is required to run the script manually**
1. Install python requirements (pip3 install -r requirements.txt)
1. Open `wrapper.sh` and configure your environment variables to suit your setup.
1. Add a cron-tab entry to wrapper like so:
```sh
2020-01-29 15:24:20 +00:00
@reboot bash /path/to/wrapper.sh
```
**NOTE**: Although once started the script runs continuously, it may take a few seconds for the data to be retrieved, computed and sent via mqtt.
2019-05-20 11:26:45 +00:00
2019-05-20 11:48:32 +00:00
## Home-Assistant Setup:
Under the `sensor` block, enter as many blocks as users configured in your environment variables:
```yaml
2019-05-20 11:48:32 +00:00
- platform: mqtt
name: "Example Name Weight"
2020-09-08 20:58:07 +00:00
state_topic: "miscale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
value_template: "{{ value_json['Weight'] }}"
unit_of_measurement: "kg"
2020-09-08 20:58:07 +00:00
json_attributes_topic: "miscale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
icon: mdi:scale-bathroom
- platform: mqtt
name: "Example Name BMI"
2020-09-08 20:58:07 +00:00
state_topic: "miscale/USER_NAME/weight"
2019-05-20 11:48:32 +00:00
value_template: "{{ value_json['BMI'] }}"
icon: mdi:human-pregnant
2020-09-08 20:58:07 +00:00
unit_of_measurement: "kg/m2"
2019-05-20 11:48:32 +00:00
```
![Mi Scale](Screenshots/HA_Lovelace_Card.png)
![Mi Scale](Screenshots/HA_Lovelace_Card_Details.png)
2019-05-20 11:48:32 +00:00
2020-06-01 13:58:09 +00:00
## Acknowledgements:
2019-05-20 11:26:45 +00:00
Thanks to @syssi (https://gist.github.com/syssi/4108a54877406dc231d95514e538bde9) and @prototux (https://github.com/wiecosystem/Bluetooth) for their initial code
2019-09-18 21:34:46 +00:00
2020-06-29 13:51:33 +00:00
Special thanks to [@ned-kelly](https://github.com/ned-kelly) for his help turning a "simple" python script into a fully fledged docker container
2020-06-01 22:56:19 +00:00
2020-06-01 22:55:33 +00:00
Thanks to [@bpaulin](https://github.com/bpaulin) for his PRs and collaboration