1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-17 21:27:31 +01:00
cpfeiffer a1cb246e27 Add and use a "client interface" for the actions of the service
Previously, the DeviceCommunicationService was invoked directly,
via
Intent intent = new Intent(foo, bar);
intent.setExtra(EXTRA_BAZ, baz);
startService(...);

and this was scattered throughout GadgetBridge.
Now there is a "frontend" available, so that you can call
the service more easily, like
GBApplication.deviceService().connect();

For a start, this client interface (DeviceService) actually
implements the same interface (EventHandler) as the receiving side
(DeviceSupport). This may change in the future.

This will also make testing much easier, because we can use
this client interface to invoke the test service as well.
2015-08-21 01:03:57 +02:00
2015-01-07 14:00:18 +01:00
2015-08-13 23:23:40 +02:00
2015-08-20 22:51:55 +02:00
2015-01-07 14:00:18 +01:00
2015-01-07 14:00:18 +01:00
2015-01-07 14:00:18 +01:00
2015-01-06 00:19:03 +01:00
2015-08-15 23:21:42 +02:00
2015-01-07 14:00:18 +01:00

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.

Build

Download

Gadgetbridge on F-Droid

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
  • Take and share screenshots from the Pebble's screen
  • Morpheuz sleep data syncronization (experimental)

How to use (Pebble)

  1. Pair your Pebble through Gadgetbridge's Discovery Activity or the Android Bluetooth Settings
  2. Start Gadgetbridge, tap on the device you want to connect to
  3. 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
  • Synchronize activity data
  • Display sleep data (alpha)
  • Display sports data (step count) (alpha)
  • Set alarms on the Mi Band

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.

  1. Configure other notifications as desired
  2. Go back to the "Gadgetbridge" Activity
  3. Tap the "MI" item to connect if you're not connected yet.
  4. 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.

Authors (in order of first code contribution)

  • Andreas Shimokawa
  • Carsten Pfeiffer
  • Daniele Gobbetti

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?

  1. Open Gadgetbridge's settings and check the option to write log files
  2. Quit Gadgetbridge and restart it
  3. Reproduce the problem you encountered
  4. Check the logfile at /sdcard/Android/data/nodomain.freeyourgadget.gadgetbridge/files/gadgetbridge.log
  5. 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.

Description
A free and cloudless replacement for your gadget vendors' closed source Android applications. See the list for supported devices.
Readme 88 MiB
Languages
Java 99.6%
Shell 0.2%
JavaScript 0.1%