- Live sensor data reading is toggled using the "Set music info" in the debug activity. - The readings are ONLY logged at the moment - The miband increments a "counter" (two bytes) at every reading, but it may be that more readings are sent with the same counter value. This is already addressed. - The name of the axes is general (axis1, 2 and 3) because we still don't know which is which - It could be that the axes depend on the wear location (especially wearing as a necklace means that the miband rests in a vertical position, while wearing on the wrist means it rests in a horizontal position). NB: It could be that we get RAW data, hence not dependent on the wear location. - Since the miband may be inserted in two directions in its strap, I guess this also has to be taken into account - the battery impact of reading this data in unknown
Gadgetbridge
Gadgetbridge is an Android (4.4+) Application which will allow you to use your Pebble or Mi Band without the vendor's closed source application and without the need to create an account and transmit any of your data to the vendor's servers.
Download
Features (Pebble)
- Incoming calls notification and display (caller, phone number)
- Outgoing call display
- Reject/hangup calls
- SMS notification (sender, body)
- K-9 Mail notification support (sender, subject, preview)
- Support for generic notifications (above filtered out)
- Music playback info (artist, album, track). Apollo and CM 12.1 Music App supported.
- Music control: play/pause, next track, previous track, volume up, volume down
- List and remove installed apps/watchfaces
- Install .pbw files
- Install firmware from .pbz files
How to use (Pebble)
- Pair your Pebble through Gadgetbridge's Discovery Activity or the Android Bluetooth Settings
- Start Gadgetbridge, tap on the device you want to connect to
- To test, choose "Debug" from the menu and play around
Features (Mi Band)
- Mi Band notifications (LEDs + vibration) for
- Discovery and pairing
- Incoming calls
- SMS received
- K-9 mails received
- Generic Android notifications
- Synchronize the time to the Mi Band
- Display firmware version and battery state
How to use (Mi Band)
-
When starting Gadgetbridge and no device is visible, it will automatically attempt to discover and pair your Mi Band. Alternatively you can invoke this manually via the menu button. It will ask you for some personal info that appears to be needed for proper steps calculation on the band. If you do not provide these, some hardcoded default "dummy" values will be used instead.
When your Mi Band starts to vibrate and blink with all three LEDs during the pairing process, tap it quickly a few times in a row to confirm the pairing with the band.
- Configure other notifications as desired
- Go back to the "Gadgetbridge" Activity
- Tap the "MI" item to connect if you're not connected yet.
- To test, chose "Debug" from the menu and play around
Known Issues:
-
Android 4.4+ only, we can only change this by not handling generic notifications or by using AccessibiltyService. Don't know if it is worth the hassle.
-
The initial connection to a Mi Band sometimes takes a little patience. Try to connect a few times, wait, and try connecting again. This only happens until you have "bonded" with the Mi Band, i.e. until it knows your MAC address. This behavior may also only occur with older firmware versions.
Contribute
Contributions are welcome, be it feedback, bugreports, documentation, translation, research or code. Feel free to work on any of the open issues; just leave a comment that you're working on one to avoid duplicated work.
Translations can be contributed via https://www.transifex.com/projects/p/gadgetbridge/resource/strings/ or manually.
Having problems?
- Open Gadgetbridge's settings and check the option to write log files
- Quit Gadgetbridge and restart it
- Reproduce the problem you encountered
- Check the logfile at /sdcard/Android/data/nodomain.freeyourgadget.gadgetbridge/files/gadgetbridge.log
- File an issue at https://github.com/Freeyourgadget/Gadgetbridge/issues/new and possibly provide the logfile
Alternatively you may use the standard logcat functionality to access the log.