Android蓝牙通信总结
BluetoothAdapter- Represents the local Bluetooth adapter (Bluetooth radio). The
BluetoothAdapteris the entry-point for all Bluetooth interaction. Using this, you can discover other Bluetooth devices, query a list of bonded (paired) devices, instantiate aBluetoothDeviceusing a known MAC address, and create aBluetoothServerSocketto listen for communications from other devices.
BluetoothDevice- Represents a remote Bluetooth device. Use this to request a connection with a remote device through a
BluetoothSocketor query information about the device such as its name, address, class, and bonding state.
BluetoothSocket- Represents the interface for a Bluetooth socket (similar to a TCP
Socket). This is the connection point that allows an application to exchange data with another Bluetooth device via InputStream and OutputStream.
private class ConnectThread extends Thread {
private final BluetoothSocket mmSocket ;
private final BluetoothDevice mmDevice ;
public ConnectThread(BluetoothDevice device, boolean secure) {
mmDevice = device;
BluetoothSocket tmp = null ;
// Get a BluetoothSocket for a connection with the
// given BluetoothDevice
try {
tmp = device.createRfcommSocketToServiceRecord( MY_UUID );
} catch (IOException e) {
Log. e( TAG,e);
}
mmSocket = tmp;
}
public void run() {
// Always cancel discovery because it will slow down a connection
mAdapter.cancelDiscovery();
try {
mmSocket .connect();
} catch (IOException e) {
// Close the socket
try {
mmSocket .close();
} catch (IOException e2) {
Log. e( TAG,e2);
}
connectionFailed();
return ;
}
synchronized (BluetoothService. this ) {
mConnectThread = null ;
}
// Start the connected thread
connected(mmSocket);
}
public void cancel() {
try {
mmSocket .close();
} catch (IOException e) {
Log. e( TAG, "close() of connect " + mSocketType + " socket failed", e);
}
}
}
BluetoothServerSocket- Represents an open server socket that listens for incoming requests (similar to a TCP
ServerSocket). In order to connect two Android devices, one device must open a server socket with this class. When a remote Bluetooth device makes a connection request to the this device, theBluetoothServerSocketwill return a connectedBluetoothSocketwhen the connection is accepted.

public class MainActivity extends Activity implements View.OnClickListener {
private BluetoothAdapter mBluetoothAdapter = null;
private BluetoothService mService = null;
private BluetoothDevice mOnePairedDevice;
private final String DeviceName = "LILEI" ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout. activity_main);
mBluetoothAdapter = BluetoothAdapter. getDefaultAdapter();
if ( mBluetoothAdapter == null ) {
Toast.makeText(this, "Bluetooth is not available", Toast.LENGTH_LONG ).show();
finish();
}
....
}
@Override
public void onStart() {
super.onStart();
if (! mBluetoothAdapter.isEnabled()) {
// Enable Bluetooth function
Intent enableIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE );
startActivityForResult(enableIntent, REQUEST_ENABLE_BT);
} else if (mService == null) {
setupBluetoothService();
}
}
@Override
public void onResume() {
super.onResume();
// Performing this check in onResume() covers the case in which BT was
// not enabled during onStart(), so we were paused to enable it...
// onResume() will be called when ACTION_REQUEST_ENABLE activity returns.
if ( mService != null ) {
// Only if the state is STATE_NONE, do we know that we haven't started already
if ( mService.getState() == BluetoothService.STATE_NONE) {
if (mOnePairedDevice == null) {
mOnePairedDevice = getASpecificPairedDevice(DeviceName );
}
if (mOnePairedDevice != null) {
mService.start(mOnePairedDevice );
} else {
Toast. makeText(this, "Not Found the paired Device." , Toast.LENGTH_LONG ).show();
}
}
}
}
@Override
public void onDestroy() {
super.onDestroy();
if ( mService != null ) {
mService.stop();
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode) {
case REQUEST_ENABLE_BT:
// When the request to enable Bluetooth returns
if (resultCode == Activity.RESULT_OK) {
setupBluetoothService();
} else {
// User did not enable Bluetooth or an error occurred
Log. d(TAG, "BT not enabled");
Toast. makeText(this, R.string. bt_not_enabled_leaving, Toast.LENGTH_SHORT ).show();
finish();
}
}
}
public void setupBluetoothService() {
mService = new BluetoothService(mHandler );
}
private BluetoothDevice getASpecificPairedDevice(String name) {
Set<BluetoothDevice> pairedDevices = mBluetoothAdapter.getBondedDevices();
// If there are paired devices
if (pairedDevices.size() > 0) {
// Loop through paired devices
for (BluetoothDevice device : pairedDevices) {
if (name.equals(device.getName())) {
return device;
}
}
}
return null;
}
...
}
public class BluetoothService {
private static final String TAG = "BluetoothService" ;
private static final UUID MY_UUID = UUID.fromString( "00001101-0000-1000-8000-00805F9B34FB");
// Constants that indicate the current connection state
public static final int STATE_NONE = 0; // we're doing nothing
public static final int STATE_LISTEN = 1; // now listening for incoming connections
public static final int STATE_CONNECTING = 2; // now initiating an outgoing connection
public static final int STATE_CONNECTED = 3; // now connected to a remote device
private final BluetoothAdapter mAdapter ;
private Handler mHandler ;
private ConnectThread mConnectThread ;
private ConnectedThread mConnectedThread ;
private int mState ;
public BluetoothService(Handler handler) {
mAdapter = BluetoothAdapter.getDefaultAdapter();
mHandler = handler;
mState = STATE_NONE ;
}
public void setHandler(Handler handler) {
mHandler = handler;
}
public void start(BluetoothDevice remoteDevice) {
connect(remoteDevice, false );
}
public int getState() {
return mState ;
}
public void stop() {
Log. d( TAG, "stop" );
if (mConnectThread != null) {
mConnectThread .cancel();
mConnectThread = null ;
}
if (mConnectedThread != null) {
mConnectedThread .cancel();
mConnectedThread = null ;
}
setState( STATE_NONE );
}
/**
* This thread runs while attempting to make an outgoing connection with a device. It runs
* straight through; the connection either succeeds or fails.
*/
private class ConnectThread extends Thread {
private final BluetoothSocket mmSocket;
private final BluetoothDevice mmDevice;
private String mSocketType ;
public ConnectThread(BluetoothDevice device, boolean secure) {
mmDevice = device;
BluetoothSocket tmp = null ;
mSocketType = secure ? "Secure" : "Insecure";
// Get a BluetoothSocket for a connection with the
// given BluetoothDevice
try {
tmp = device.createRfcommSocketToServiceRecord( MY_UUID );
} catch (IOException e) {
Log. e( TAG, "Socket Type: " + mSocketType + "create() failed", e);
}
mmSocket = tmp;
}
public void run() {
Log. i( TAG, "BEGIN mConnectThread SocketType:" + mSocketType );
setName( "ConnectThread" + mSocketType );
// Always cancel discovery because it will slow down a connection
mAdapter .cancelDiscovery();
// Make a connection to the BluetoothSocket
try {
// This is a blocking call and will only return on a
// successful connection or an exception
mmSocket .connect();
} catch (IOException e) {
// Close the socket
try {
mmSocket .close();
} catch (IOException e2) {
Log. e( TAG, "unable to close() " + mSocketType
+ " socket during connection failure" , e2);
}
connectionFailed();
return ;
}
// Reset the ConnectThread because we're done
synchronized (BluetoothService. this) {
mConnectThread = null ;
}
// Start the connected thread
connected( mmSocket , mmDevice , mSocketType );
}
public void cancel() {
try {
mmSocket .close();
} catch (IOException e) {
Log. e( TAG, "close() of connect " + mSocketType + " socket failed", e);
}
}
}
/**
* Indicate that the connection attempt failed and notify the UI Activity.
*/
private void connectionFailed() {
// Send a failure message back to the Activity
Message msg = mHandler .obtainMessage(Constants. MESSAGE_TOAST);
Bundle bundle = new Bundle();
bundle.putString(Constants. TOAST , "Unable to connect device" );
msg.setData(bundle);
mHandler .sendMessage(msg);
}
/**
* Set the current state of the chat connection
*
* @param state An integer defining the current connection state
*/
private synchronized void setState( int state) {
Log. d( TAG, "setState() " + mState + " -> " + state);
mState = state;
// Give the new state to the Handler so the UI Activity can update
mHandler .obtainMessage(Constants. MESSAGE_STATE_CHANGE, state, -1).sendToTarget();
}
/**
* Start the ConnectedThread to begin managing a Bluetooth connection
*
* @param socket The BluetoothSocket on which the connection was made
* @param device The BluetoothDevice that has been connected
*/
public synchronized void connected(BluetoothSocket socket, BluetoothDevice device,
final String socketType) {
Log. d( TAG, "connected, Socket Type:" + socketType);
// Cancel the thread that completed the connection
if (mConnectThread != null) {
mConnectThread .cancel();
mConnectThread = null ;
}
// Cancel any thread currently running a connection
if (mConnectedThread != null) {
mConnectedThread .cancel();
mConnectedThread = null ;
}
// Start the thread to manage the connection and perform transmissions
mConnectedThread = new ConnectedThread(socket, socketType);
mConnectedThread .start();
// Send the name of the connected device back to the UI Activity
Message msg = mHandler .obtainMessage(Constants. MESSAGE_DEVICE_NAME);
Bundle bundle = new Bundle();
bundle.putString(Constants. DEVICE_NAME , device.getName());
msg.setData(bundle);
mHandler .sendMessage(msg);
setState( STATE_CONNECTED );
}
/**
* This thread runs during a connection with a remote device. It handles all incoming and
* outgoing transmissions.
*/
private class ConnectedThread extends Thread {
private final BluetoothSocket mmSocket;
private final InputStream mmInStream;
private final OutputStream mmOutStream;
public ConnectedThread(BluetoothSocket socket, String socketType) {
Log. d( TAG, "create ConnectedThread: " + socketType);
mmSocket = socket;
InputStream tmpIn = null ;
OutputStream tmpOut = null ;
// Get the BluetoothSocket input and output streams
try {
tmpIn = socket.getInputStream();
tmpOut = socket.getOutputStream();
} catch (IOException e) {
Log. e( TAG, "temp sockets not created" , e);
}
mmInStream = tmpIn;
mmOutStream = tmpOut;
}
public void run() {
Log. i( TAG, "BEGIN mConnectedThread" );
byte [] buffer = new byte[3024];
int bytes;
// Keep listening to the InputStream while connected
while (true ) {
try {
// Read from the InputStream
bytes = mmInStream .read(buffer);
// Send the obtained bytes to the UI Activity
mHandler .obtainMessage(Constants. MESSAGE_READ, bytes, -1, buffer)
.sendToTarget();
} catch (IOException e) {
Log. e( TAG, "disconnected" , e);
connectionLost();
break ;
}
}
}
/**
* Write to the connected OutStream.
*
* @param buffer The bytes to write
*/
public void write( byte[] buffer) {
try {
mmOutStream .write(buffer);
// Share the sent message back to the UI Activity
mHandler .obtainMessage(Constants. MESSAGE_WRITE, -1, -1, buffer).sendToTarget();
} catch (IOException e) {
Log. e( TAG, "Exception during write" , e);
}
}
public void writeFileMessage( byte[] buffer) {
try {
mmOutStream .write(buffer);
} catch (IOException e) {
Log. e( TAG, "Exception during write" , e);
}
}
public void writeFileStream (InputStream input) {
byte [] buffer = new byte[1024];
int readLengh;
try {
while ((readLengh = input.read(buffer)) != -1) {
mmOutStream .write(buffer, 0, readLengh);
}
mHandler
.obtainMessage(Constants. MESSAGE_WRITE , -1, -1,
"Finish send file to remoteDevice." )
.sendToTarget();
} catch (IOException e) {
Log. e( TAG, "Exception during write" , e);
mHandler .obtainMessage(Constants. MESSAGE_WRITE, -1, -1,
"Error when send file to remoteDevice").sendToTarget();
}
}
public void cancel() {
try {
mmSocket .close();
} catch (IOException e) {
Log. e( TAG, "close() of connect socket failed" , e);
}
}
}
/**
* Indicate that the connection was lost and notify the UI Activity.
*/
private void connectionLost() {
// Send a failure message back to the Activity
Message msg = mHandler .obtainMessage(Constants. MESSAGE_TOAST);
Bundle bundle = new Bundle();
bundle.putString(Constants. TOAST , "Device connection was lost" );
msg.setData(bundle);
mHandler .sendMessage(msg);
// Start the service over to restart listening mode
}
/**
* Start the ConnectThread to initiate a connection to a remote device.
*
* @param device The BluetoothDevice to connect
* @param secure Socket Security type - Secure (true) , Insecure (false)
*/
public synchronized void connect(BluetoothDevice device, boolean secure) {
Log. d( TAG, "connect to: " + device);
// Cancel any thread attempting to make a connection
if (mState == STATE_CONNECTING) {
if (mConnectThread != null) {
mConnectThread .cancel();
mConnectThread = null ;
}
}
// Cancel any thread currently running a connection
if (mConnectedThread != null) {
mConnectedThread .cancel();
mConnectedThread = null ;
}
// Start the thread to connect with the given device
mConnectThread = new ConnectThread(device, secure);
mConnectThread .start();
setState( STATE_CONNECTING );
}
/**
* Write to the ConnectedThread in an unsynchronized manner
*
* @param out The bytes to write
* @see ConnectedThread#write(byte[])
*/
public void write( byte[] out, boolean isFile) {
// Create temporary object
ConnectedThread r;
// Synchronize a copy of the ConnectedThread
synchronized (this ) {
if (mState != STATE_CONNECTED)
return ;
r = mConnectedThread ;
}
// Perform the write unsynchronized
if (isFile) {
r.writeFileMessage(out);
} else {
r.write(out);
}
}
public void write(InputStream in) {
// Create temporary object
ConnectedThread r;
// Synchronize a copy of the ConnectedThread
synchronized (this ) {
if (mState != STATE_CONNECTED)
return ;
r = mConnectedThread ;
}
// Perform the write unsynchronized
r. writeFileStream(in);
}
}
Android蓝牙通信总结的更多相关文章
- Qt on Android 蓝牙通信开发
版权声明:本文为MULTIBEANS ORG研发跟随文章,未经MLT ORG允许不得转载. 最近做项目,需要开发安卓应用,实现串口的收发,目测CH340G在安卓手机上非常麻烦,而且驱动都是Java版本 ...
- Android蓝牙通信具体解释
蓝牙通信的大概过程例如以下: 1.首先开启蓝牙 2,搜索可用设备 3,创建蓝牙socket.获取输入输出流 4,读取和写入数据 5.断开连接关闭蓝牙 还要发送配对码发送进行推断! 以下是全部的源码:不 ...
- Android蓝牙通信
Android为蓝牙设备之间的通信封装好了一些调用接口,使得实现Android的蓝牙通信功能并不困难.可通过UUID使两个设备直接建立连接. 具体步骤: 1. 获取BluetoothAdapter实例 ...
- (转)android 蓝牙通信编程
转自:http://blog.csdn.net/pwei007/article/details/6015907 Android平台支持蓝牙网络协议栈,实现蓝牙设备之间数据的无线传输. 本文档描述了怎样 ...
- Android蓝牙通信功能开发
1. 概述 Bluetooth 是几乎现在每部手机标准配备的功能,多用于耳机 mic 等设备与手机的连接,除此之外,还可以多部手机之间建立 bluetooth 通信,本文就通过 SDK 中带的一个聊天 ...
- android 蓝牙通信编程讲解
以下是开发中的几个关键步骤: 1,首先开启蓝牙 2,搜索可用设备 3,创建蓝牙socket,获取输入输出流 4,读取和写入数据 5,断开连接关闭蓝牙 下面是一个demo 效果图: SearchDevi ...
- android 蓝牙 通信 bluetooth
此例子基于 android demo Android的蓝牙开发,虽然不多用,但有时还是会用到, Android对于蓝牙开发从2.0版本的sdk才开始支持,而且模拟器不支持,测试需要两部手机: ...
- Android 蓝牙通信——AndroidBluetoothManager
转载请说明出处! 作者:kqw攻城狮 出处:个人站 | CSDN To get a Git project into your build: Step 1. Add the JitPack repos ...
- Android BLE设备蓝牙通信框架BluetoothKit
BluetoothKit是一款功能强大的Android蓝牙通信框架,支持低功耗蓝牙设备的连接通信.蓝牙广播扫描及Beacon解析. 关于该项目的详细文档请关注:https://github.com/d ...
随机推荐
- mysql 复杂查询
1.同一个表下多次查询: sql语句: select b.* ,(select name from exh_common.medicine_type a where b.p_id = a.id) as ...
- 无法启动此程序,因为计算机中丢失 zlibd.dll【OSG】
在配置OSG的过程中遇到了这个问题.记录一下. zlibd.dll这个DLL可以在第三方库3rdParty里面找到.找到之后复制到OSG的bin目录下即可.
- AppScan工作原理&操作教程
一.AppScan的工作原理 对一个综合性的大型网站来说,可能存在成千上万的页面.以登录界面为例,至少要输入用户名和密码,即该页面存在两个字段,当提交了用户名和密码等登录信息,网站需要检查是否正确,这 ...
- 第一次通过CLR Profile解决内存占用过高的问题
炮哥:"嘿,哥们,忙啥呢,电脑卡成这逼样." 勇哥:"在用CLR Profile工具分析下FlexiPrint的内存占用情况." 炮哥:“哎哟,不错啊,玩高级的 ...
- SQL SERVER技术内幕之4 子查询
最外层查询的结果集会返回给调用者,称为外部查询.内部查询的结果是供外部查询使用的,也称为子查询.子查询可以分成独立子查询和相关子查询两类.独立子查询不依赖于它所属的外部查询,而相关子查询则须依赖它所属 ...
- 如何在存储过程中执行set命令 我来答
1.EXEC使用EXEC命令两种用种执行存储程另种执行态批处理所讲都第二种用 面先使用EXEC演示例,代码1DECLARE @TableName VARCHAR(50),@Sql NVARCHAR ( ...
- P3385 【模板】负环
题目描述 暴力枚举/SPFA/Bellman-ford/奇怪的贪心/超神搜索 输入输出格式 输入格式: 第一行一个正整数T表示数据组数,对于每组数据: 第一行两个正整数N M,表示图有N个顶点,M条边 ...
- 2018牛客多校第六场 G.Pikachu
题意: 给出一棵n个点的树,每条边有边权.对这个树加边变成一个完全图.新加的边的权值为边上两点在树上的距离.求完全图上任意两点的最大流之和. 题解: 一共有C(n,2)个点对.假设当前求s到t之间的最 ...
- [bzoj4391] [Usaco2015 dec]High Card Low Card 贪心 线段树
---题面--- 题解: 观察到以决策点为分界线,以点数大的赢为比较方式的游戏都是它的前缀,反之以点数小的赢为比较方式的都是它的后缀,也就是答案是由两段答案拼凑起来的. 如果不考虑判断胜负的条件的变化 ...
- [SDOI2014]数表 莫比乌斯反演
---题面--- 题解: 设$f(d)$表示数$d$的约数和,那么$(i, j)$中的数为$f(gcd(i, j))$,那么有2种枚举方法.1,枚举每一格看对应的$f(d)$是几.$$ans = \s ...