- Разработка приложений на основе Bluetooth API (JSR82) – часть 1
- Конфигурация системы
- Разработка приложений
- Сборка апплетов
- Запуск приложений
- Заключение
- Ссылки
- A может Вас также заинтересует что-нибудь из этого:
- Saved searches
- Use saved searches to filter your results more quickly
- android-bluetooth
- Here are 32 public repositories matching this topic.
- dariuszseweryn / RxAndroidBle
- harry1453 / android-bluetooth-serial
- DeveloperPaul123 / SimpleBluetoothLibrary
- MFori / Android-Bluetooth-Printer
- devyok / OkBluetooth
- dan3143 / android-bluetooth-plugin
- Joy-Whale / BluetoothProfile
- RideBeeline / android-bluetooth-current-time-service
- ani8897 / BLE-Packet-Sniffer
- SSSDNSY / bluecar
- traviho / CodeRCCar
- ayvazj / retrotooth
- neXenio / RxAndroidBleServer
- MFori / Bluetooth-Flashlight
- kcy1019 / AndroidWerableMessagingAPI-Tutorial
- MakerStation / FabCatApp
- pranav-gargeshwari / Rpi-RGB_LEDControl-AndroidApp
- owalid / Horaflex
- Tomiwa-Ot / obd
- parmi93 / STxMReader
- Improve this page
- Add this topic to your repo
Разработка приложений на основе Bluetooth API (JSR82) – часть 1
Большинство мобильных устройств (сотовые телефоны, КПК), поддерживающих приложения на платформе J2ME, имеют аппаратные возможности для установления локальных соединений Bluetooth. ОС устройства при этом содержит интерфейс управления такой связью. Однако пользователям, которые хотят использовать эти возможности в J2ME-приложениях собственной разработки, необходимо проверить, поддерживает ли конфигурация конкретного устройства интерфейс методов в соответствии с JSR82 [1], который определяет Bluetooth API.
В настоящей статье будут рассмотрены аспекты конфигурирования системы для разработки и запуска java-приложений, использующих соединения bluetooth, а также приведены фрагменты программного кода классов этих приложений.
Конфигурация системы
На момент написания статьи было доступно немного мобильных устройств, в спецификации которых заявлялась поддержка JSR82, поэтому была сделана попытка эмулировать установление bluetooth-соединения средствами java-приложений с помощью двух ПК с установленными на них usb-донглами. Для этого использовался Rococosoft Impronto SDK [2], распространяемый на некоммерческой основе для ОС Linux. Средство разработки включает поддержку протоколов RFCOMM, L2CAP, SDP, OBEX. Базовая конфигурация системы представляла собой следующий набор ПО:
- ОС Fedora Core 3 Linux, ядро 2.6.9. При использовании некоторых дистрибутивов с более ранними версиями ядра (RedHat Linux, ASP Linux 9.0 – ядро 2.4.20) наблюдались устройчивые проблемы с инициализацией слушающих сокетов протоколом RFCOMM, что производится при регистрации службы и переходе в режим ожидания соединения демоном SDP. Также ранние версии данных ОС показали нестабильную работу с usb-устройствами под управлением OHCI контроллера при включенной конфигурации ACPI.
- J2SE SDK 1.4.2 for Linux. В профайл прописываются переменные
JAVA_HOME=/usr/java/директория установки j2sdk1.4.2> PATH=$PATH>:$JAVA_HOME>/bin export PATH JAVA_HOME
ANT_HOME=/usr/local/ant PATH=$PATH>:$ANT_HOME>/bin export ANT_HOME
Пакеты javax.bluetooth и javax.obex Impronto средства разработки SDK 1.3.1. В профайл прописываются пременные пути, где помимо все располагается лицензия на использование продукта
CLASSPATH=/usr/share/java PATH=$PATH>:$CLASSPATH> export CLASSPATH
Разработка приложений
Клиент-серверная архитектура построения соединения предполагает выполнение ряда действий со стороны как серверной, так и клиентской части ПО. Серверу необходимо
Класс серверной части наследуется от javax.obex.ServerRequestHandler.
import java.io.IOException;
import javax.bluetooth.BluetoothStateException;
import javax.bluetooth.DiscoveryAgent;
import javax.bluetooth.L2CAPConnection;
import javax.bluetooth.L2CAPConnectionNotifier;
import javax.bluetooth.LocalDevice;
import javax.microedition.io.Connection;
import javax.microedition.io.Connector;
import javax.obex.HeaderSet;
import javax.obex.Operation;
import javax.obex.ResponseCodes;
import javax.obex.ServerRequestHandler;
import javax.obex.SessionNotifier;
import javax.obex.ClientSession;
public class DB_BT_Server extends ServerRequestHandler String serviceURL = «btgoep://localhost:00B0D00154EF;name=DB_BT_OBEXServer» ;
Connection clientConn = null ;
LocalDevice localDevice = null ;
public void runServer () try clientConn = Connector.open ( serviceURL ) ;
>
catch ( IOException e ) System.exit ( 1 ) ;
>
try localDevice = LocalDevice.getLocalDevice () ;
localDevice.setDiscoverable ( DiscoveryAgent.GIAC ) ;
>
catch ( BluetoothStateException e ) System.exit ( 1 ) ;
>
if ( clientConn instanceof L2CAPConnectionNotifier ) L2CAPConnectionNotifier connListener = ( L2CAPConnectionNotifier ) clientConn;
L2CAPConnection openConn = null ;
try openConn = connListener.acceptAndOpen () ;
>
catch ( IOException e ) System.err.println ( e ) ;
>
>
else if ( clientConn instanceof SessionNotifier ) SessionNotifier session = ( SessionNotifier ) clientConn;
try session.acceptAndOpen ( this ) ;
>
catch ( IOException e ) System.err.println ( e ) ;
>
>
>
>
Клиентский модуль осуществляет
- поиск доступных серверов в зоне покрытия радиосвязи,
- получение данных о доступных службах, составление собственной базы
- поиск нужного сервера по имеющимся данным о службе
- запрос на соединение
Класс клиентской части реализует интерфейс javax.bluetooth.DiscoveryListener.
import java.io.IOException;
import java.util.Hashtable;
import javax.bluetooth.BluetoothStateException;
import javax.bluetooth.DeviceClass;
import javax.bluetooth.DiscoveryAgent;
import javax.bluetooth.DiscoveryListener;
import javax.bluetooth.LocalDevice;
import javax.bluetooth.RemoteDevice;
import javax.bluetooth.ServiceRecord;
import javax.bluetooth.UUID;
import javax.microedition.io.Connection;
import javax.microedition.io.Connector;
import javax.obex.ClientSession;
import javax.obex.HeaderSet;
import javax.obex.Operation;
public class DB_BT_Client implements DiscoveryListener
private DiscoveryAgent agent;
private LocalDevice localDevice;
UUID thatService = new UUID ( «00B0D00154EF » ,false ) ;
private Hashtable serviceSearchTransactions = new Hashtable () ;
public void runClient () agent = localDevice.getDiscoveryAgent () ;
try agent.startInquiry ( DiscoveryAgent.GIAC, this ) ;
> catch ( BluetoothStateException e ) System.exit ( 1 ) ;
>
>
public void deviceDiscovered ( RemoteDevice device, DeviceClass code ) startServiceDiscovery ( device ) ;
>
private void startServiceDiscovery ( RemoteDevice device ) UUID [] services = new UUID [ 1 ] ;
services [ 0 ] = thatService;
DiscoveryAgent agent = localDevice.getDiscoveryAgent () ;
try int transaction = agent.searchServices ( args, services, device, this ) ;
serviceSearchTransactions.put ( new Integer ( transaction ) , device ) ;
> catch ( BluetoothStateException e ) >
public void servicesDiscovered ( int transaction, ServiceRecord [] services ) for ( int ctr = 0 ; ctr < services.length; ctr++ ) Connection conn = null ;
try conn = Connector.open ( services [ ctr ] .getConnectionURL (
ServiceRecord.NOAUTHENTICATE_NOENCRYPT, false )) ;
if ( conn instanceof ClientSession ) ClientSession session = ( ClientSession ) conn;
>
> catch ( IOException e ) >
>
>
>
>
Сборка апплетов
Для получения jar с байткодами классов можно использовать мейкфайл в формате xml и сборщик Ant. Примерное содержание приводится далее.
name="client" default="all"> name="all" depends="package"/> name="compile"> dir="_classes"/> destdir="_classes" srcdir="./../../"> location="/usr/share/java/idev_bluez.jar"/> name="WCCj2se/**"/> name="WirelessCommonComponents/**"/> name="./**"/> name="package" depends="compile"> dir="_lib"/> basedir="_classes" jarfile="_lib/client.jar"/> name="clean"> includeEmptyDirs="yes"> dir="."> name="_classes/**"/> name="_lib/**"/>
Запуск приложений
Перед запуском необходимо привести usb-донглы в активное состояние, например с помощью следующей команды консоли
Запуск приложений можно осуществить с помощью скрипта
$/bin/java -cp /usr/share/java:/usr/share/java/idev_bluez.jar: /WirelessImagingToolsSuite/_build/client/_lib/client.jar: classes .
Заключение
В данной статье был рассмотрен вариант эмуляции беспроводного соединения bluetooth на основе двух ПК под управлением java-приложений, использующих методы классов интерфейса JSR82 – Java API for Bluetooth Wireless Technology. В дальнейших публикациях планируется более подробно рассмотреть вопросы использования протокола OBEX и классов пакетов javax.bluetooth и javax.obex.
Ссылки
Автор выражает признательность Lars Kirkhus и Anders R. Sveen за тот вклад, который они сделали в деле исследования аспектов разработки приложений для работы с Bluetooth в мобильных устройствах.
A может Вас также заинтересует что-нибудь из этого:
Saved searches
Use saved searches to filter your results more quickly
You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session.
android-bluetooth
Here are 32 public repositories matching this topic.
dariuszseweryn / RxAndroidBle
An Android Bluetooth Low Energy (BLE) Library with RxJava3 interface
harry1453 / android-bluetooth-serial
A library for Android to simplify basic serial communication over Bluetooth, for example when communicating with Arduinos.
DeveloperPaul123 / SimpleBluetoothLibrary
Android library for simplifying bluetooth usage.
MFori / Android-Bluetooth-Printer
Android java class for printing via bluetooth
devyok / OkBluetooth
dan3143 / android-bluetooth-plugin
Plugin for Unity that enables Bluetooth communication in Android devices.
Joy-Whale / BluetoothProfile
android 经典Bluetooth Profile连接及使用实例
RideBeeline / android-bluetooth-current-time-service
An implementation of the Bluetooth Current Time Service (CTS) for Android applications communicating with a Bluetooth peripheral
ani8897 / BLE-Packet-Sniffer
An android application which is useful in capturing BLE advertisement packets and storing the data collected in the phone storage as a csv file.
SSSDNSY / bluecar
android bluetooth app ,control a smart C51 robot
traviho / CodeRCCar
A programmable RC car, bluetooth, and a Blockly interface to teach Computer Science.
ayvazj / retrotooth
Retrofit inspired Bluetooth LE library
neXenio / RxAndroidBleServer
An Android Bluetooth Low Energy GATT Server Library with RxJava3 interface
MFori / Bluetooth-Flashlight
kcy1019 / AndroidWerableMessagingAPI-Tutorial
A minmal tutorial on communication between Android Wearable and Android Handheld(Mobile).
MakerStation / FabCatApp
pranav-gargeshwari / Rpi-RGB_LEDControl-AndroidApp
The idea is to provide the infrastructure to transmit/receive data from Rpi to Android Phone and viceversa. Following items are built as two different project, Android App to run on phone and bin to run on raspberry Pi. The project controls a RGB LED using an android phone.
owalid / Horaflex
Android application communicating using bluetooth with protocol SPP (Serial Port Profile)
Tomiwa-Ot / obd
Android library for getting vehicle diagnostics from ELM327 (USB/Bluetooth) connector over OBD protocol
parmi93 / STxMReader
Android App that connects via USB/UART, Bluetooth or TCP/IP to a device to configure it via AT commands.
Improve this page
Add a description, image, and links to the android-bluetooth topic page so that developers can more easily learn about it.
Add this topic to your repo
To associate your repository with the android-bluetooth topic, visit your repo’s landing page and select «manage topics.»