Bluetooth Smart (4.0) / GATT support in Android 4.0?
Asked Answered
D

6

28

I'm trying to find way to work with Bluetooth 4.0 (AKA Bluetooth Smart) devices using modern Android smartphones, namely - HTC One V.

As I understood, there is some issues using GATT profile even in Android 4.0 with Bluetooth 4.0 hardware because of API limitations.

I saw Motorola released it's own API for BT LE, but not sure it will work for other vendors. My goal is to get universal support for all smartphones with appropriate hardware.

Any suggestion for solution are highly appreciated.

Alexey

PS: Yes, I saw Android API for HDP, but it seems to be used only with 'classic' Bluetooth devices (not low energy ones, as BT LE does).

Dollarbird answered 6/4, 2012 at 9:8 Comment(2)
Samsung published a Bluetooth BLE SDK (beta). See this question #11105208Hydatid
Here is an official statement about BLE from Google employees at the latest IO developers.google.com/events/io/sessions/326240948 All devices with 4.3 and BLE hardware will have the official Android BLE API, which is demonstrated at this video session.Hydatid
D
0

As discovered, 4.3 has support for BLE, but it so broken, especially on Nexus devices. At my opinion, it's not ready for production.

Dollarbird answered 3/6, 2014 at 10:42 Comment(0)
H
26

Unfortunately there are no Android native GATT APIs simply because Android currently does not support Bluetooth Low Energy at all. This may change in upcoming Android releases, but today manufacturers instead integrate 3rd party Bluetooth stacks with Low Energy support from vendors like Qualcomm, Broadcom or CSR. Those come with their own set of APIs, obviously limiting compatibility to the set of phones using that particular vendor's stack. The good news is that on other platforms like iOS or Windows 8 there are native GATT BLE APIs, and those are well supported. For Android, we will have to wait until Google decides to integrate the Linux/BlueZ work that has been done on BLE with Android.

Heiskell answered 9/4, 2012 at 8:55 Comment(10)
Thank you. Could you please provide vendors that proposes custom BT LE Android SDK for their platforms? (except Motorola)Dollarbird
Hi Alexey. Although I do not want to publicly speak about particular vendors, it is usually enough to browse the publicly available Bluetooth Qualification website (bluetooth.org/tpg/listings.cfm) to see who has qualified what in terms of stacks for Android. Try Advanced Search and then restrict the spec version to 4.0 (you may try 4.0+HS too), and then just look for Android or known vendors.Heiskell
I forgot to mention that then you can also look for particular phones and their qualification listings, and they usually refer to the QID (Qualification ID) of the stack they are using, allowing you to match particular phone models with stack vendors.Heiskell
Have you checked out this API for the Broadcom chip?code.google.com/p/broadcom-bleDamask
Rumors say that Google will release an official API around August 2012Choate
As I understood, no any movements on this issue was made in Android 4.1 :(Dollarbird
Moreover, looks like Motorola broke BLE support on RAZR with ICS update.Dollarbird
If you want GATT API support, please Star this Android issue: code.google.com/p/android/issues/detail?id=33371Gyrostatics
Ok, I've starred that issue. Also, I have information that Samsung promised to fix it soon for Galaxy line.Dollarbird
I actually decompiled some apps from Google Play that use the SGSIII's BLE capabilities and found a couple of methods that do not exist in Android's native BT API, and they're names clearly state they're BLE related. I've tried using them through java reflection and am currently working out the possibility of developing a library. But tests I've run so far have had shakey results.Evin
E
13

After some research I can only say this:

  • Motorola has sided with Broadcom to develop a proprietary API. It would seem it is extremely limited since it states there's support for existing profiles only. Check it out here.

  • Samsung fails to provide any information regarding its BLE API, which I can verify exists and is called samsung.bluetoothle. I actually decompiled some apps from Google Play that use the SGSIII's BLE capabilities and found a couple of methods that do not exist in Android's native BT API, and they're names clearly state they're BLE related. I've tried using them through java reflection and am currently working out the possibility of developing a library. But tests I've run so far have had shakey results at best. There is also a thread on Samsung's developer forum, I would suggest making some pressure here if you're interested.

  • Google has made almost no remarks in this aspect. There's a thread regarding this issues in the Galaxy Nexus, which you should star, with a lot of people complaining. The closest thing to an answer from Google can be found here.

[UPDATE]

Samsung has also modified a couple of Android's classes, more especifically:

  • BluetoothAdapter
  • BluetoothDevice

[UPDATE]

Since I've put this issue aside for a while due to lack of support from both Google and Samsung I'll post what I've learned so far:

BluetoothAdapter new methods:

public boolean android.bluetooth.BluetoothAdapter.leTestEnd()
public boolean android.bluetooth.BluetoothAdapter.setAvStreaming(boolean)
public boolean android.bluetooth.BluetoothAdapter.setScanLE(boolean)
public void android.bluetooth.BluetoothAdapter.setScoPathChange(int)
public boolean android.bluetooth.BluetoothAdapter.startLeDiscovery()

To use them do the following:

BluetoothAdapter ba = new BluetoothAdapter();
Method starteLeDiscoveryMethod = null;
starteLeDiscoveryMethod = ba.class.getMethod("startLeDiscovery");
starteLeDiscoveryMethod.invoke(ba);

NOTE: This method in particular works somewhat like the regular startDiscovery() method but, at least for me, it discovers the BLE device 2 out of 5 times. And remember, this is only for the SGSIII. I haven't gotten around to extracting the new methods in BluetoothDevice but when I do, I'll post them here.

Evin answered 28/11, 2012 at 8:39 Comment(5)
I can confirm that this code works on Android 4.1.1 Samsung SGIII. Any further discoveries rodkarom?Harass
I'm likely to have to develop an "as cross-platform as possible" solution for BLE on android during next week. Any chance you have some sample code that could help me in my quest? There isn't as much as I wish online.Grotto
I'm sorry top inform you that it won't be possible to develop a cross platform solution. Keep in mind that the only possibilities are Mototola's API and what I've gathered so far.Evin
You'll notice that the 3 out of 5 times it doesn't work, if you try to turn off bluetooth the phone crashes.Immanuel
Yup, said so on the note (how many times it works, hadn't noticed the crashing issue).Evin
J
2

SDK 18 has support for it now. Docs are here:

http://developer.android.com/guide/topics/connectivity/bluetooth-le.html

Testing on my Nexus 4 is crashing the bluetooth stack.

Jeremyjerez answered 1/8, 2013 at 21:26 Comment(0)
R
1

HTC has had BLE support since last year with HTC One X+, Droid DNA and of course the HTC One. Initially the HTC BLE API was upon request but it's now been freely downloadable at http://htcdev.com.

Yes the new standard Android BLE API from Google in Android API Level 18 is coming very soon (see preview from IO video) - but you can wrap third party APIs (HTC, Samsung, etc) in a compatible way to support the new standard API as all the APIs are quite similar in their support of the GATT profile (similar to IOS).

Renegado answered 12/6, 2013 at 18:24 Comment(0)
P
0

BluetoothGatt api available in andorid

https://developer.android.com/reference/android/bluetooth/BluetoothGatt.html

Preheat answered 30/5, 2014 at 5:38 Comment(0)
D
0

As discovered, 4.3 has support for BLE, but it so broken, especially on Nexus devices. At my opinion, it's not ready for production.

Dollarbird answered 3/6, 2014 at 10:42 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.