手機藍(lán)牙app開發(fā)教程(藍(lán)牙app制作教程)
今天給各位分享手機藍(lán)牙app開發(fā)教程的知識,其中也會對藍(lán)牙app制作教程進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關(guān)注本站,現(xiàn)在開始吧!
微信小程序藍(lán)牙教程--完整版親測
#使用mpvue 開發(fā)小程序過程中 簡單介紹一下微信小程序藍(lán)牙連接過程
#在藍(lán)牙連接的過程中部分api需要加定時器延時1秒到2秒左右再執(zhí)行,原因為何不知道,小程序有這樣的要求
#1.首先是要初始化藍(lán)牙:openBluetoothAdapter()
```js
if (wx.openBluetoothAdapter) {
wx.openBluetoothAdapter({
? ? ? ? success: function(res) {
????????????/* 獲取本機的藍(lán)牙狀態(tài) */
? ? ? ? ? ? setTimeout(() = {
????????????????getBluetoothAdapterState()
????????????}, 1000)
????????},
? ? ? ? fail: function(err) {
????????????// 初始化失敗
????????}
????})
????} else {????
????}
```
#2.檢測本機藍(lán)牙是否可用:
#? 要在上述的初始化藍(lán)牙成功之后回調(diào)里調(diào)用
```js
getBluetoothAdapterState() {
? ? var that= this;
? ? that.toastTitle= '檢查藍(lán)牙狀態(tài)'
wx.getBluetoothAdapterState({
? ? ? ? success: function(res) {
startBluetoothDevicesDiscovery()
},
? ? ? ? fail(res) {
? ? ? ? ? ? console.log(res)
}
})
}
```
#3. 開始搜索藍(lán)牙設(shè)備:
```js
startBluetoothDevicesDiscovery() {
? ? var that= this;
? ? setTimeout(() = {
wx.startBluetoothDevicesDiscovery({
? ? ? ? ? ? success: function(res) {
/* 獲取藍(lán)牙設(shè)備列表 */
? ? ? ? ? ? ? ? that.getBluetoothDevices()
},
? ? ? ? ? ? fail(res) {
}
})
}, 1000)
}
```
#4. 獲取搜索到的藍(lán)牙設(shè)備列表
# /* that.deviceName 是獲取到的藍(lán)牙設(shè)備的名稱, 因為藍(lán)牙設(shè)備在安卓和蘋果手機上搜到的藍(lán)牙地址顯示是不一樣的,所以根據(jù)設(shè)備名稱匹配藍(lán)牙*/
```js
getBluetoothDevices() {
? ? var that= this;
? ? setTimeout(() = {
wx.getBluetoothDevices({
? ? ? ? ? ? services: [],
? ? ? ? ? ? allowDuplicatesKey: false,
? ? ? ? ? ? interval: 0,
? ? ? ? ? ? success: function(res) {
? ? ? ? ? ? ? ? if (res.devices.length 0) {
? ? ? ? ? ? ? ? ? ? if (JSON.stringify(res.devices).indexOf(that.deviceName) !== -1) {
? ? ? ? ? ? ? ? ? ? ? ? for (let i = 0; i res.devices.length; i++) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? if (that.deviceName === res.devices[i].name) {
/* 根據(jù)指定的藍(lán)牙設(shè)備名稱匹配到deviceId */
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? that.deviceId = that.devices[i].deviceId;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setTimeout(() = {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? that.connectTO();
}, 2000);
};
};
} else {
}
} else {
}
},
? ? ? ? ? ? fail(res) {
? ? ? ? ? ? ? ? console.log(res, '獲取藍(lán)牙設(shè)備列表失敗=====')
}
})
}, 2000)
},
```
#5.連接藍(lán)牙
# 匹配到的藍(lán)牙設(shè)備ID 發(fā)送連接藍(lán)牙的請求, 連接成功之后 應(yīng)該斷開藍(lán)牙搜索的api,然后去獲取所連接藍(lán)牙設(shè)備的service服務(wù)
```js
connectTO() {
wx.createBLEConnection({
? ? ? ? deviceId: deviceId,
? ? ? ? success: function(res) {
? ? ? ? ? ? that.connectedDeviceId = deviceId;
/* 4.獲取連接設(shè)備的service服務(wù) */
that.getBLEDeviceServices();
wx.stopBluetoothDevicesDiscovery({
? ? ? ? ? ? ? ? success: function(res) {
? ? ? ? ? ? ? ? ? ? console.log(res, '停止搜索')
},
? ? ? ? ? ? ? ? fail(res) {
}
})
},
? ? ? ? fail: function(res) {
}
})
}
```
#6. 獲取藍(lán)牙設(shè)備的service服務(wù),獲取的serviceId有多個要試著連接最終確定哪個是穩(wěn)定版本的service 獲取服務(wù)完后獲取設(shè)備特征值
```js
getBLEDeviceServices() {
? ? setTimeout(() = {
wx.getBLEDeviceServices({
? ? ? ? ? ? deviceId: that.connectedDeviceId,
? ? ? ? ? ? success: function(res) {
? ? ? ? ? ? ? ? that.services= res.services
/* 獲取連接設(shè)備的所有特征值 */
that.getBLEDeviceCharacteristics()
},
? ? ? ? ? ? fail: (res) = {
}
})
}, 2000)
},
```
#7.獲取藍(lán)牙設(shè)備特征值
# 獲取到的特征值有多個,最后要用的事能讀,能寫,能監(jiān)聽的那個值的uuid作為特征值id,
```js
getBLEDeviceCharacteristics() {
? ? ? ? ? ? setTimeout(() = {
wx.getBLEDeviceCharacteristics({
? ? ? ? ? ? ? ? ? ? deviceId: connectedDeviceId,
? ? ? ? ? ? ? ? ? ? serviceId: services[2].uuid,
? ? ? ? ? ? ? ? ? ? success: function(res) {
? ? ? ? ? ? ? ? ? ? ? ? for (var i = 0; i res.characteristics.length; i++) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? if ((res.characteristics[i].properties.notify || res.characteristics[i].properties.indicate)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? (res.characteristics[i].properties.read res.characteristics[i].properties.write)) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? console.log(res.characteristics[i].uuid, '藍(lán)牙特征值 ==========')
/* 獲取藍(lán)牙特征值 */
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? that.notifyCharacteristicsId = res.characteristics[i].uuid
// 啟用低功耗藍(lán)牙設(shè)備特征值變化時的 notify 功能
that.notifyBLECharacteristicValueChange()
}
}
},
? ? ? ? ? ? ? ? ? ? fail: function(res) {
}
})
}, 1000)
},
```
#8.啟動notify 藍(lán)牙監(jiān)聽功能 然后使用 wx.onBLECharacteristicValueChange用來監(jiān)聽藍(lán)牙設(shè)備傳遞數(shù)據(jù)
#接收到的數(shù)據(jù)和發(fā)送的數(shù)據(jù)必須是二級制數(shù)據(jù), 頁面展示的時候需要進行轉(zhuǎn)換
```js
notifyBLECharacteristicValueChange() { // 啟用低功耗藍(lán)牙設(shè)備特征值變化時的 notify 功能
? ? ? ? ? ? var that= this;
? ? ? ? ? ? console.log('6.啟用低功耗藍(lán)牙設(shè)備特征值變化時的 notify 功能')
wx.notifyBLECharacteristicValueChange({
? ? ? ? ? ? ? ? state: true,
? ? ? ? ? ? ? ? deviceId: that.connectedDeviceId,
? ? ? ? ? ? ? ? serviceId: that.notifyServicweId,
? ? ? ? ? ? ? ? characteristicId: that.notifyCharacteristicsId,
? ? ? ? ? ? ? ? complete(res) {
/*用來監(jiān)聽手機藍(lán)牙設(shè)備的數(shù)據(jù)變化*/
wx.onBLECharacteristicValueChange(function(res) {
/**/
? ? ? ? ? ? ? ? ? ? ? ? that.balanceData += that.buf2string(res.value)
? ? ? ? ? ? ? ? ? ? ? ? that.hexstr += that.receiveData(res.value)
})
},
? ? ? ? ? ? ? ? fail(res) {
? ? ? ? ? ? ? ? ? ? console.log(res, '啟用低功耗藍(lán)牙設(shè)備監(jiān)聽失敗')
? ? ? ? ? ? ? ? ? ? that.measuringTip(res)
}
})
},
/*轉(zhuǎn)換成需要的格式*/
buf2string(buffer) {
? ? ? ? ? ? ? ? ? ? var arr = Array.prototype.map.call(new Uint8Array(buffer), x = x)
? ? ? ? ? ? ? ? ? ? return arr.map((char, i) = {
? ? ? ? ? ? ? ? ? ? ? ? return String.fromCharCode(char);
? ? ? ? ? ? ? ? ? ? }).join('');
},
receiveData(buf) {
return this.hexCharCodeToStr(this.ab2hex(buf))
},
/*轉(zhuǎn)成二進制*/
ab2hex (buffer) {
? ? ? ? ? ? ? var hexArr = Array.prototype.map.call(
? ? ? ? ? ? ? ? ? new Uint8Array(buffer), function (bit) {
? ? ? ? ? ? ? ? ? ? ? return ('00' + bit.toString(16)).slice(-2)
}
)
? ? ? ? ? ? ? return hexArr.join('')
},
/*轉(zhuǎn)成可展會的文字*/
hexCharCodeToStr(hexCharCodeStr) {
? ? ? ? ? ? ? var trimedStr = hexCharCodeStr.trim();
? ? ? ? ? ? ? var rawStr = trimedStr.substr(0, 2).toLowerCase() === '0x' ? trimedStr.substr(2) : trimedStr;
? ? ? ? ? ? ? var len = rawStr.length;
? ? ? ? ? ? ? var curCharCode;
? ? ? ? ? ? ? var resultStr= [];
? ? ? ? ? ? ? for (var i = 0; i len; i = i+ 2) {
? ? ? ? ? ? ? ? ? curCharCode = parseInt(rawStr.substr(i, 2), 16);
? ? ? ? ? ? ? ? ? resultStr.push(String.fromCharCode(curCharCode));
}
? ? ? ? ? ? ? return resultStr.join('');
},
```
# 向藍(lán)牙設(shè)備發(fā)送數(shù)據(jù)
```js
sendData(str) {
? ? let that= this;
? ? let dataBuffer = new ArrayBuffer(str.length)
? ? let dataView = new DataView(dataBuffer)
? ? for (var i = 0; i str.length; i++) {
? ? ? ? dataView.setUint8(i, str.charAt(i).charCodeAt())
}
? ? let dataHex = that.ab2hex(dataBuffer);
? ? this.writeDatas = that.hexCharCodeToStr(dataHex);
wx.writeBLECharacteristicValue({
? ? ? ? deviceId: that.connectedDeviceId,
? ? ? ? serviceId: that.notifyServicweId,
? ? ? ? characteristicId: that.notifyCharacteristicsId,
? ? ? ? value: dataBuffer,
? ? ? ? success: function (res) {
? ? ? ? ? ? console.log('發(fā)送的數(shù)據(jù):' + that.writeDatas)
? ? ? ? ? ? console.log('message發(fā)送成功')
},
? ? ? ? fail: function (res) {
},
? ? ? ? complete: function (res) {
}
})
},
```
# 當(dāng)不需要連接藍(lán)牙了后就要關(guān)閉藍(lán)牙,并關(guān)閉藍(lán)牙模塊
```js
// 斷開設(shè)備連接
closeConnect() {
if (that.connectedDeviceId) {
wx.closeBLEConnection({
? ? ? ? ? ? deviceId: that.connectedDeviceId,
? ? ? ? ? ? success: function(res) {
that.closeBluetoothAdapter()
},
? ? ? ? ? ? fail(res) {
}
})
} else {
that.closeBluetoothAdapter()
}
},
// 關(guān)閉藍(lán)牙模塊
closeBluetoothAdapter() {
wx.closeBluetoothAdapter({
? ? ? ? success: function(res) {
},
? ? ? ? fail: function(err) {
}
})
},
```
#在向藍(lán)牙設(shè)備傳遞數(shù)據(jù)和接收數(shù)據(jù)的過程中,并未使用到read的API 不知道有沒有潛在的問題,目前線上運行為發(fā)現(xiàn)任何的問題
#今天的藍(lán)牙使用心得到此結(jié)束,謝謝
如何創(chuàng)建一個安卓手機的APP,用于模擬遙控器鍵盤,輸出藍(lán)牙信號?
我有做這樣的app, 也做過USB串口通信和通過藍(lán)牙控制單片機的程序, QQ2227421573
嵌入式linux 藍(lán)牙怎么開發(fā)
一.Linux對于藍(lán)牙的支持
在Linux 2.6內(nèi)核已經(jīng)實現(xiàn)如下協(xié)議。
串口形式藍(lán)牙設(shè)備驅(qū)動(HCI UART driver)
USB藍(lán)牙棒驅(qū)動(HCI USB driver)
內(nèi)核也實現(xiàn)了L2CAP,RFCOMM串口接口,以及SCO鏈路支持.
另外內(nèi)核也直接支持BNEP(Bluetooth Network Encapsulation Protocol ),即把藍(lán)牙網(wǎng)絡(luò)當(dāng)成一個無線局域網(wǎng)操作。
Linux也帶了藍(lán)牙輸入設(shè)備的相關(guān)支持。
需要打開 HIDP 和HID2HCI兩個選項都要打開.
DUND 把藍(lán)牙網(wǎng)絡(luò)當(dāng)成一個撥號網(wǎng)絡(luò)來處理。
2.藍(lán)牙協(xié)議棧
在實現(xiàn)了L2CAP后,也需要一個藍(lán)牙協(xié)議棧處理。它起什么作用呢? 我的理解是內(nèi)核封裝到RFCOMM的層次,即只負(fù)責(zé)的藍(lán)牙的包的封裝與收發(fā)。至于包收上來,在藍(lán)牙的四個階段,如何應(yīng)用的狀態(tài)影響,以及如何響應(yīng)正確的包,這一些事情由藍(lán)牙協(xié)議棧來完成的。
在Linux實現(xiàn)藍(lán)牙功能有多個互相競爭的藍(lán)牙協(xié)議棧,但是影響最大是bluez.幾乎已經(jīng)成為Linux下的標(biāo)準(zhǔn)協(xié)議棧的代名詞。
還有一個協(xié)議棧是Affix ?不過用的人比較少
在應(yīng)用程序級,它主要由兩部分組成,一個是bluez的應(yīng)用程序庫,主要負(fù)責(zé)與內(nèi)核的bluez通信,和bluez-util工具。即完成藍(lán)牙四階段處理的一些命令行工具。
3.藍(lán)牙的概念。
配對由一方發(fā)起即可,如果本設(shè)備需要被其它設(shè)備搜索,需要有被發(fā)現(xiàn)功能。
二.Linux關(guān)于藍(lán)牙命令
-------------------------------------------------
在Linux使用藍(lán)牙最方便是使用bluez-util自帶向個命令來測試。
我們這里采用市面最容易找到的藍(lán)牙棒來做物理層設(shè)備與手機進行通訊測試。把藍(lán)牙棒插LINUX下的USB口后,在dmesg我們會看到提示
表示USB藍(lán)牙棒已經(jīng)被識別了。如果
操作系統(tǒng)自帶HCI工具主要來自bluez-util.
/usr/sbin/hciattach?:?attach serial devices via UART HCI to BlueZ stack
/usr/sbin/hcid???? :Bluetooth Host Controller Interface Daemon
/usr/sbin/hciemu??? :HCI emulator
/usr/sbin/hciconfig?:??configure Bluetooth devices
/usr/sbin/hcidump? :?Parse HCI data
/usr/bin/hcitool?? :?configure Bluetooth connections
/usr/bin/sdptool??? :?control and interrogate SDP servers
hciconfig類似于 hciconfig.類似的操作可以參見官網(wǎng)(這里不方便留鏈接,自己去搜索下就可以了)
檢測USB設(shè)備,lsusb
2.查看hci設(shè)備,hciconfig
激活設(shè)備
hciconfig hci0 up
3.修改藍(lán)牙配置文件
藍(lán)牙采用/etc/bluetooth/
hcid.conf ?rfcomm.conf
其中hcid.conf有關(guān)配對信息。其中security user;表示每次配對詢問用戶對方PIN,而auto則直接采用passkey中的PIN碼。
4.重啟藍(lán)牙服務(wù)
如果修改了藍(lán)牙配置后,需要重啟藍(lán)牙服務(wù)
service bluetooth stop
service bluetooth start
5.掃描設(shè)備
6.增加自動配對設(shè)置
修改 /etc/bluetooth/rfcomm.conf
增加掃描藍(lán)牙地址
7.創(chuàng)建設(shè)備結(jié)點(只合適于第一次)
rfcomm create dev #它將創(chuàng)建于/dev/rfcomm0 設(shè)備結(jié)點
它等同于如下命令系列
mknod /dev/rfcomm0 c 216 1
chmod 666 /dev/rfcomm0
rfcomm bind /dev/rfcomm0 00:21:19:A4:E0:F1-1
8.增加SDP消息信息
為了減少麻煩,把所有支持的藍(lán)牙服務(wù)都加上.
sdptool add --channel=1 DID SP DUN LAN FAX OPUSH FTP HS HF SAP NAP GN PANU HID CIP CTP A2SRC A2SNK SYNCML NOKID PCSUITE SR1
9.增加藍(lán)牙串口綁定
rfcomm bind /dev/rfcomm0 00:21:19:A4:E0:F1 1
#rfcomm bind /dev/rfcomm0 藍(lán)牙設(shè)備地址 ?通道,這個命令可選
10.解除藍(lán)牙綁定
格式:rfcomm unbind /dev/rfcomm0 藍(lán)牙設(shè)備地址 ? 通道
11.聯(lián)接藍(lán)牙設(shè)備
hcitool cc 00:21:19:A4:E0:F1
三.關(guān)于藍(lán)牙配置文件
-------------------------------------------
藍(lán)牙的配置文件主要是 /etc/bluetooth目錄下的hcid.conf和rfcomm.conf.
這里的security 是表示配對的認(rèn)證模式,user表示由用戶輸入密碼。這個需要在后面用
pin_helper 指明用哪一個程序輸入密碼,這程序可以是圖形界面程序,或者是字符界面程序。
常見的pin_helper有
/usr/bin/bluez-pin : bluez自帶的pin輸入界面
kbluepin
passkey 配置項指明請求聯(lián)接的設(shè)備的pin碼。當(dāng)采用auto模式時,將采用這個密碼來聯(lián)接.
android藍(lán)牙開發(fā),PC端模擬串口接收字符,該如何編程?
您好,android藍(lán)牙這方面還是很好搞的,因為大家的方式都是差不多的。先說說如何開啟藍(lán)牙設(shè)備和設(shè)置可見時間:
private void search() {
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();
if (!adapter.isEnabled()) {
adapter.enable();
}
Intent enable = new Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);
enable.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, 3600); //3600為藍(lán)牙設(shè)備可見時間
startActivity(enable);
Intent searchIntent = new Intent(this, ComminuteActivity.class);
startActivity(searchIntent);
}
首先,需要獲得一個BluetoothAdapter,可以通過getDefaultAdapter()獲得系統(tǒng)默認(rèn)的藍(lán)牙適配器,當(dāng)然我們也可以自己指定,但這個真心沒有必要,至少我是不需要的。然后我們檢查手機的藍(lán)牙是否打開,如果沒有,通過enable()方法打開。接著我們再設(shè)置手機藍(lán)牙設(shè)備的可見,可見時間可以自定義。
完成這些必要的設(shè)置后,我們就可以正式開始與藍(lán)牙模塊進行通信了:
public class ComminuteActivity extends Activity {
private BluetoothReceiver receiver;
private BluetoothAdapter bluetoothAdapter;
private ListString devices;
private ListBluetoothDevice deviceList;
private Bluetooth client;
private final String lockName = "BOLUTEK";
private String message = "000001";
private ListView listView;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.search_layout);
listView = (ListView) this.findViewById(R.id.list);
deviceList = new ArrayListBluetoothDevice();
devices = new ArrayListString();
bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
bluetoothAdapter.startDiscovery();
IntentFilter filter = new IntentFilter(BluetoothDevice.ACTION_FOUND);
receiver = new BluetoothReceiver();
registerReceiver(receiver, filter);
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView? parent, View view, int position, long id) {
setContentView(R.layout.connect_layout);
BluetoothDevice device = deviceList.get(position);
client = new Bluetooth(device, handler);
try {
client.connect(message);
} catch (Exception e) {
Log.e("TAG", e.toString());
}
}
});
}
@Override
protected void onDestroy() {
unregisterReceiver(receiver);
super.onDestroy();
}
private final Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case Bluetooth.CONNECT_FAILED:
Toast.makeText(ComminuteActivity.this, "連接失敗", Toast.LENGTH_LONG).show();
try {
client.connect(message);
} catch (Exception e) {
Log.e("TAG", e.toString());
}
break;
case Bluetooth.CONNECT_SUCCESS:
Toast.makeText(ComminuteActivity.this, "連接成功", Toast.LENGTH_LONG).show();
break;
case Bluetooth.READ_FAILED:
Toast.makeText(ComminuteActivity.this, "讀取失敗", Toast.LENGTH_LONG).show();
break;
case Bluetooth.WRITE_FAILED:
Toast.makeText(ComminuteActivity.this, "寫入失敗", Toast.LENGTH_LONG).show();
break;
case Bluetooth.DATA:
Toast.makeText(ComminuteActivity.this, msg.arg1 + "", Toast.LENGTH_LONG).show();
break;
}
}
};
private class BluetoothReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (BluetoothDevice.ACTION_FOUND.equals(action)) {
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
if (isLock(device)) {
devices.add(device.getName());
}
deviceList.add(device);
}
showDevices();
}
}
private boolean isLock(BluetoothDevice device) {
boolean isLockName = (device.getName()).equals(lockName);
boolean isSingleDevice = devices.indexOf(device.getName()) == -1;
return isLockName isSingleDevice;
}
private void showDevices() {
ArrayAdapterString adapter = new ArrayAdapterString(this, android.R.layout.simple_list_item_1,
devices);
listView.setAdapter(adapter);
}
}
如何使用Android藍(lán)牙開發(fā)
Android平臺支持藍(lán)牙網(wǎng)絡(luò)協(xié)議棧,實現(xiàn)藍(lán)牙設(shè)備之間數(shù)據(jù)的無線傳輸。本文檔描述了怎樣利用android平臺提供的藍(lán)牙API去實現(xiàn)藍(lán)壓設(shè)備之間的通信。藍(lán)牙具有point-to-point 和 multipoint兩種連接功能。
使用藍(lán)牙API,可以做到:
* 搜索藍(lán)牙設(shè)備
* 從本地的Bluetooth adapter中查詢已經(jīng)配對的設(shè)備
* 建立RFCOMM通道
* 通過service discovery連接到其它設(shè)備
* 在設(shè)備之間傳輸數(shù)據(jù)
* 管理多個連接
基礎(chǔ)知識
本文檔介紹了如何使用Android的藍(lán)牙API來完成的四個必要的主要任務(wù),使用藍(lán)牙進行設(shè)備通信,主要包含四個部分:藍(lán)牙設(shè)置、搜索設(shè)備(配對的或可見的)、連接、傳輸數(shù)據(jù)。
所有的藍(lán)牙API在android.bluetooth包中。實現(xiàn)這些功能主要需要下面這幾個類和接口:
BluetoothAdapter
代表本地藍(lán)牙適配器(藍(lán)牙發(fā)射器),是所有藍(lán)牙交互的入口。通過它可以搜索其它藍(lán)牙設(shè)備,查詢已經(jīng)配對的設(shè)備列表,通過已知的MAC地址創(chuàng)建BluetoothDevice,創(chuàng)建BluetoothServerSocket監(jiān)聽來自其它設(shè)備的通信。
BluetoothDevice
代表了一個遠(yuǎn)端的藍(lán)牙設(shè)備, 使用它請求遠(yuǎn)端藍(lán)牙設(shè)備連接或者獲取 遠(yuǎn)端藍(lán)牙設(shè)備的名稱、地址、種類和綁定狀態(tài)。 (其信息是封裝在 bluetoothsocket 中) 。
BluetoothSocket
代表了一個藍(lán)牙套接字的接口(類似于 tcp 中的套接字) ,他是應(yīng)用程 序通過輸入、輸出流與其他藍(lán)牙設(shè)備通信的連接點。
BluetoothServerSocket
代表打開服務(wù)連接來監(jiān)聽可能到來的連接請求 (屬于 server 端) , 為了連接兩個藍(lán)牙設(shè)備必須有一個設(shè)備作為服務(wù)器打開一個服務(wù)套接字。 當(dāng)遠(yuǎn)端設(shè)備發(fā)起連 接連接請求的時候,并且已經(jīng)連接到了的時候,Blueboothserversocket 類將會返回一個 bluetoothsocket。
BluetoothClass
描述了一個設(shè)備的特性(profile)或該設(shè)備上的藍(lán)牙大致可以提供哪些服務(wù)(service),但不可信。比如,設(shè)備是一個電話、計算機或手持設(shè)備;設(shè)備可以提供audio/telephony服務(wù)等。可以用它來進行一些UI上的提示。
BluetoothProfile
BluetoothHeadset
提供手機使用藍(lán)牙耳機的支持。這既包括藍(lán)牙耳機和免提(V1.5)模式。
BluetoothA2dp
定義高品質(zhì)的音頻,可以從一個設(shè)備傳輸?shù)搅硪粋€藍(lán)牙連接。 “A2DP的”代表高級音頻分配模式。
BluetoothHealth
代表了醫(yī)療設(shè)備配置代理控制的藍(lán)牙服務(wù)
BluetoothHealthCallback
一個抽象類,使用實現(xiàn)BluetoothHealth回調(diào)。你必須擴展這個類并實現(xiàn)回調(diào)方法接收更新應(yīng)用程序的注冊狀態(tài)和藍(lán)牙通道狀態(tài)的變化。
BluetoothHealthAppConfiguration
代表一個應(yīng)用程序的配置,藍(lán)牙醫(yī)療第三方應(yīng)用注冊與遠(yuǎn)程藍(lán)牙醫(yī)療設(shè)備交流。
BluetoothProfile.ServiceListener
當(dāng)他們已經(jīng)連接到或從服務(wù)斷開時通知BluetoothProfile IPX的客戶時一個接口(即運行一個特定的配置文件,內(nèi)部服務(wù))。
藍(lán)牙權(quán)限
為了在你的應(yīng)用中使用藍(lán)牙功能,至少要在AndroidManifest.xml中聲明兩個權(quán)限:BLUETOOTH(任何藍(lán)牙相關(guān)API都要使用這個權(quán)限) 和 BLUETOOTH_ADMIN(設(shè)備搜索、藍(lán)牙設(shè)置等)。
為了執(zhí)行藍(lán)牙通信,例如連接請求,接收連接和傳送數(shù)據(jù)都必須有BLUETOOTH權(quán)限。
必須要求BLUETOOTH_ADMIN的權(quán)限來啟動設(shè)備發(fā)現(xiàn)或操縱藍(lán)牙設(shè)置。大多數(shù)應(yīng)用程序都需要這個權(quán)限能力,發(fā)現(xiàn)當(dāng)?shù)氐乃{(lán)牙設(shè)備。此權(quán)限授予其他的能力不應(yīng)該使用,除非應(yīng)用程序是一個“電源管理”,將根據(jù)用戶要求修改的藍(lán)牙設(shè)置
注釋:要請求BLUETOOTH_ADMIN的話,必須要先有BLUETOOTH。
在你的應(yīng)用manifest 文件中聲明藍(lán)牙權(quán)限。例如:
manifest ...
uses-permission android:name="android.permission.BLUETOOTH" /
...
/manifest
通過查看uses-permission資料來聲明應(yīng)用權(quán)限獲取更多的信息。
藍(lán)牙設(shè)置
在你的應(yīng)用通過藍(lán)牙進行通信之前,你需要確認(rèn)設(shè)備是否支持藍(lán)牙,如果支持,確信它被打開。
如果不支持,則不能使用藍(lán)牙功能。如果支持藍(lán)牙,但不能夠使用,你剛要在你的應(yīng)用中請求使用藍(lán)牙。這個要兩步完成,使用BluetoothAdapter。
手機藍(lán)牙app開發(fā)教程的介紹就聊到這里吧,感謝你花時間閱讀本站內(nèi)容,更多關(guān)于藍(lán)牙app制作教程、手機藍(lán)牙app開發(fā)教程的信息別忘了在本站進行查找喔。