2016年8月9日 星期二

Ionic2 藍芽傳輸

目前藍芽推出BLE低功率的傳輸模式,當然對藍芽有興趣的朋友們,可以一起來研究看看喔,和傳統藍芽不一樣的是採用藍芽4.0的標準,以傳統藍芽更省電,更有延展性傳輸多樣化的訊息,距離也比傳統藍芽更遠,其他就自已有空去GOOLE~

一、加入BLE的套件

$ ionic plugin add cordova-plugin-ble-central

二、搜尋藍芽的硬體

home.html
<ion-navbar *navbar>
<ion-title>藍芽裝置</ion-title>
</ion-navbar>

<ion-content padding class="home">
<ion-nav #mycontent [root]="rootPage"></ion-nav>
<ion-list inset>
<ion-item-sliding *ngFor="let device of devices" #slidingItem>
<button ion-item (click)="connectToDevice(device)">
<h2>{{device.name}}</h2>
<p>{{device.id}}</p>
<p>{{device.rssi}}</p>
</button>
</ion-item-sliding>
</ion-list>
<button full (click)="startScanning()">開始掃瞄</button>
</ion-content>


Home.ts
import {Component} from '@angular/core';
import {Page, NavController} from 'ionic-angular';
import {Device} from './device'; //呼叫元件
import {BLE} from 'ionic-native';

@Component({
templateUrl: 'build/pages/home/home.html'
})

export class HomePage {
private devices;
private isScanning = false;
constructor(public navController: NavController) {
this.navController = navController;
this.devices = [];
}

startScanning() {
console.log("Scanning Started");
this.devices = [];
this.isScanning = true;
BLE.enable(); //開啟藍芽的授權
BLE.startScan([]).subscribe(device => {
this.devices.push(device);
});

setTimeout(() => {
BLE.stopScan().then(() => {
console.log("Scanning has stopped");
console.log(JSON.stringify(this.devices))
this.isScanning = false;
});
}, 3000);
}

connectToDevice(device) {
console.log("Connect To Device");
console.log(JSON.stringify(device))
this.navController.push(Device, {
device: device
}); //轉頁到device的頁面
}
}

設定3秒後自動停止搜尋,如果有搜尋到配對的藍芽裝置就加入device的陣列中

Device.html
<ion-navbar *navbar>
<ion-title>{{device.name}}</ion-title>
</ion-navbar>
<ion-content>
<ion-list inset>
<ion-item-sliding *ngFor="let characteristic of characteristics" #slidingItem>
<button ion-item (click)="connectToCharacteristic(device.id,characteristic)">
<h2>{{characteristic.characteristic}}</h2>
<p>{{characteristic.properties}}</p>
<p>{{characteristic.isNotifying}}</p>
<p>{{characteristic.service}}</p>
</button>
</ion-item-sliding>
</ion-list>
<ion-spinner *ngIf="connecting ==true" name="circles"></ion-spinner>
</ion-content>

點選配對的藍芽裝置後,導到Device.html的頁面,並顯示藍芽配備的相關屬性

Device.ts

import {Page, NavController, NavParams} from "ionic-angular";
import {BLE} from "ionic-native";
import {Component} from '@angular/core';
@Component({
templateUrl: "build/pages/home/device.html"
})

export class Device {
static get parameters() {
return [[NavParams], [NavController]];
}
private nav;
private navParams;
private device;
private connecting;
private characteristics;
constructor(navParams, nav) {
this.nav = nav;
this.navParams = navParams;
this.device = this.navParams.get("device");
this.connecting = true;
this.connect(this.device.id);
}

connect(deviceID) {
this.characteristics = [];
BLE.connect(deviceID).subscribe(peripheralData => {
console.log(peripheralData.characteristics);
this.characteristics = peripheralData.characteristics;
this.connecting = false;
},
peripheralData => {
console.log("disconnected");
});
}

stringToBytes(string) {
var array = new Uint8Array(string.length);
for (var i = 0, l = string.length; i < l; i++) {
array[i] = string.charCodeAt(i);
}
return array.buffer;
}

bytesToString(buffer) {
return String.fromCharCode.apply(null, new Uint8Array(buffer));
}

connectToCharacteristic(deviceID, characteristic) {
alert(deviceID + "_" + characteristic);
console.log("Connect To Characteristic");
console.log(deviceID);
console.log(characteristic);
//you can write or read message
}
}



BLE的屬性如下所示:

"characteristics":
[
{ "service": "1800",
"characteristic": "2a00",
"properties": [ "Read" ]
}
]

如果要傳輸或接受藍芽的訊息,必需要取得deviceID, serviceID, characteristicID,而有些屬性只允許【唯讀】、【唯寫】,必需先瞭解裝備的的屬性。

write(deviceId, serviceUUID, characteristicUUID, value)

read(deviceId, serviceUUID, characteristicUUID)



參考文件
  1. https://ionicallyspeaking.com/2016/05/06/connecting-to-a-bluetooth-smart-sensor-with-ionic-2/
  2. http://ionicframework.com/docs/v2/native/ble/