|
|
|
@ -9,14 +9,20 @@
|
|
|
|
//#include "BLEScan.h"
|
|
|
|
//#include "BLEScan.h"
|
|
|
|
|
|
|
|
|
|
|
|
// The remote service we wish to connect to.
|
|
|
|
// The remote service we wish to connect to.
|
|
|
|
static BLEUUID serviceUUID("4fafc201-1fb5-459e-8fcc-c5c9c331914b");
|
|
|
|
//static BLEUUID serviceUUID("4fafc201-1fb5-459e-8fcc-c5c9c331914b");
|
|
|
|
// The characteristic of the remote service we are interested in.
|
|
|
|
// The characteristic of the remote service we are interested in.
|
|
|
|
static BLEUUID charUUID("beb5483e-36e1-4688-b7f5-ea07361b26a8");
|
|
|
|
//static BLEUUID charUUID("beb5483e-36e1-4688-b7f5-ea07361b26a8");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static BLEUUID serviceUUID("6e400001-b5a3-f393-e0a9-e50e24dcca9e");
|
|
|
|
|
|
|
|
static BLEUUID charReadUUID("6e400003-b5a3-f393-e0a9-e50e24dcca9e");
|
|
|
|
|
|
|
|
static BLEUUID charWriteUUID("6e400002-b5a3-f393-e0a9-e50e24dcca9e");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static boolean doConnect = false;
|
|
|
|
static boolean doConnect = false;
|
|
|
|
static boolean connected = false;
|
|
|
|
static boolean connected = false;
|
|
|
|
static boolean doScan = false;
|
|
|
|
static boolean doScan = false;
|
|
|
|
static BLERemoteCharacteristic* pRemoteCharacteristic;
|
|
|
|
static BLERemoteCharacteristic* pRemoteCharacteristicRead;
|
|
|
|
|
|
|
|
static BLERemoteCharacteristic* pRemoteCharacteristicWrite;
|
|
|
|
static BLEAdvertisedDevice* myDevice;
|
|
|
|
static BLEAdvertisedDevice* myDevice;
|
|
|
|
|
|
|
|
|
|
|
|
static void notifyCallback(
|
|
|
|
static void notifyCallback(
|
|
|
|
@ -24,9 +30,9 @@ static void notifyCallback(
|
|
|
|
uint8_t* pData,
|
|
|
|
uint8_t* pData,
|
|
|
|
size_t length,
|
|
|
|
size_t length,
|
|
|
|
bool isNotify) {
|
|
|
|
bool isNotify) {
|
|
|
|
Serial.print("Notify callback for characteristic ");
|
|
|
|
Serial.print("Notify callback for characteristic:");
|
|
|
|
Serial.print(pBLERemoteCharacteristic->getUUID().toString().c_str());
|
|
|
|
Serial.print(pBLERemoteCharacteristic->getUUID().toString().c_str());
|
|
|
|
Serial.print(" of data length ");
|
|
|
|
Serial.print("of data length:");
|
|
|
|
Serial.println(length);
|
|
|
|
Serial.println(length);
|
|
|
|
Serial.print("data: ");
|
|
|
|
Serial.print("data: ");
|
|
|
|
Serial.write(pData, length);
|
|
|
|
Serial.write(pData, length);
|
|
|
|
@ -69,24 +75,34 @@ bool connectToServer() {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Obtain a reference to the characteristic in the service of the remote BLE server.
|
|
|
|
// Obtain a reference to the characteristic in the service of the remote BLE server.
|
|
|
|
pRemoteCharacteristic = pRemoteService->getCharacteristic(charUUID);
|
|
|
|
pRemoteCharacteristicRead = pRemoteService->getCharacteristic(charReadUUID);
|
|
|
|
if (pRemoteCharacteristic == nullptr) {
|
|
|
|
if (pRemoteCharacteristicRead == nullptr) {
|
|
|
|
Serial.print("Failed to find our characteristic UUID: ");
|
|
|
|
Serial.print("Failed to find our characteristic UUID: ");
|
|
|
|
Serial.println(charUUID.toString().c_str());
|
|
|
|
Serial.println(charReadUUID.toString().c_str());
|
|
|
|
|
|
|
|
pClient->disconnect();
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Serial.println(" - Found our characteristic");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Obtain a reference to the characteristic in the service of the remote BLE server.
|
|
|
|
|
|
|
|
pRemoteCharacteristicWrite = pRemoteService->getCharacteristic(charWriteUUID);
|
|
|
|
|
|
|
|
if (pRemoteCharacteristicWrite == nullptr) {
|
|
|
|
|
|
|
|
Serial.print("Failed to find our characteristic UUID: ");
|
|
|
|
|
|
|
|
Serial.println(charWriteUUID.toString().c_str());
|
|
|
|
pClient->disconnect();
|
|
|
|
pClient->disconnect();
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Serial.println(" - Found our characteristic");
|
|
|
|
Serial.println(" - Found our characteristic");
|
|
|
|
|
|
|
|
|
|
|
|
// Read the value of the characteristic.
|
|
|
|
// Read the value of the characteristic.
|
|
|
|
if(pRemoteCharacteristic->canRead()) {
|
|
|
|
if(pRemoteCharacteristicRead->canRead()) {
|
|
|
|
std::string value = pRemoteCharacteristic->readValue();
|
|
|
|
std::string value = pRemoteCharacteristicRead->readValue();
|
|
|
|
Serial.print("The characteristic value was: ");
|
|
|
|
Serial.print("The characteristic value was: ");
|
|
|
|
Serial.println(value.c_str());
|
|
|
|
Serial.println(value.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(pRemoteCharacteristic->canNotify())
|
|
|
|
if(pRemoteCharacteristicRead->canNotify())
|
|
|
|
pRemoteCharacteristic->registerForNotify(notifyCallback);
|
|
|
|
pRemoteCharacteristicRead->registerForNotify(notifyCallback);
|
|
|
|
|
|
|
|
|
|
|
|
connected = true;
|
|
|
|
connected = true;
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
@ -114,6 +130,24 @@ class MyAdvertisedDeviceCallbacks: public BLEAdvertisedDeviceCallbacks {
|
|
|
|
} // onResult
|
|
|
|
} // onResult
|
|
|
|
}; // MyAdvertisedDeviceCallbacks
|
|
|
|
}; // MyAdvertisedDeviceCallbacks
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 使用工具函数发送16进制数据
|
|
|
|
|
|
|
|
void sendHexDataBle(String hexString) {
|
|
|
|
|
|
|
|
uint8_t data[hexString.length()/2];
|
|
|
|
|
|
|
|
// 将16进制字符串转换为字节数组
|
|
|
|
|
|
|
|
for(int i = 0; i < hexString.length(); i += 2) {
|
|
|
|
|
|
|
|
String byteString = hexString.substring(i, i+2);
|
|
|
|
|
|
|
|
data[i/2] = (uint8_t)strtol(byteString.c_str(), NULL, 16);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
pRemoteCharacteristicWrite->writeValue(data, sizeof(data));
|
|
|
|
|
|
|
|
Serial.println("Setting new characteristic value to \"" + hexString + "\"");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 使用工具函数发送字符串数据
|
|
|
|
|
|
|
|
void sendStringDataBle(String newValue) {
|
|
|
|
|
|
|
|
//Set the characteristic's value to be the array of bytes that is actually a string.
|
|
|
|
|
|
|
|
pRemoteCharacteristicWrite->writeValue(newValue.c_str(), newValue.length());
|
|
|
|
|
|
|
|
Serial.println("Setting new characteristic value to \"" + newValue + "\"");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void setup() {
|
|
|
|
void setup() {
|
|
|
|
Serial.begin(115200);
|
|
|
|
Serial.begin(115200);
|
|
|
|
@ -150,14 +184,35 @@ void loop() {
|
|
|
|
// If we are connected to a peer BLE Server, update the characteristic each time we are reached
|
|
|
|
// If we are connected to a peer BLE Server, update the characteristic each time we are reached
|
|
|
|
// with the current time since boot.
|
|
|
|
// with the current time since boot.
|
|
|
|
if (connected) {
|
|
|
|
if (connected) {
|
|
|
|
String newValue = "Time since boot: " + String(millis()/1000);
|
|
|
|
// String newValue = "VR";//读固件版本号 false
|
|
|
|
Serial.println("Setting new characteristic value to \"" + newValue + "\"");
|
|
|
|
String newValue = "BV ";//电量 false
|
|
|
|
|
|
|
|
// String newValue = "0B0B6300";//温度测量 //无响应数据 true
|
|
|
|
|
|
|
|
// String newValue = "4854";//温湿度测量 //无响应数据 true
|
|
|
|
|
|
|
|
// String newValue = "1F13";//位移测量 //无响应数据 true
|
|
|
|
|
|
|
|
// String newValue = "Time since boot: ";//
|
|
|
|
|
|
|
|
// String newValue = "Time since boot: ";//
|
|
|
|
|
|
|
|
// String newValue = "Time since boot: " + String(millis()/1000);//
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 方法2: 使用字符串转换
|
|
|
|
|
|
|
|
String hexString = "0B0B6300";//温度测量
|
|
|
|
|
|
|
|
// String hexString = "4854";//温湿度测量
|
|
|
|
|
|
|
|
// String hexString = "1F13";//位移测量
|
|
|
|
|
|
|
|
uint8_t data[hexString.length()/2];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 将16进制字符串转换为字节数组
|
|
|
|
|
|
|
|
for(int i = 0; i < hexString.length(); i += 2) {
|
|
|
|
|
|
|
|
String byteString = hexString.substring(i, i+2);
|
|
|
|
|
|
|
|
data[i/2] = (uint8_t)strtol(byteString.c_str(), NULL, 16);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//pRemoteCharacteristicWrite->writeValue(data, sizeof(data));
|
|
|
|
|
|
|
|
sendHexDataBle(hexString);
|
|
|
|
|
|
|
|
delay(2000);
|
|
|
|
|
|
|
|
sendStringDataBle(newValue);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Set the characteristic's value to be the array of bytes that is actually a string.
|
|
|
|
|
|
|
|
pRemoteCharacteristic->writeValue(newValue.c_str(), newValue.length());
|
|
|
|
|
|
|
|
}else if(doScan){
|
|
|
|
}else if(doScan){
|
|
|
|
BLEDevice::getScan()->start(0); // this is just example to start scan after disconnect, most likely there is better way to do it in arduino
|
|
|
|
BLEDevice::getScan()->start(0); // this is just example to start scan after disconnect, most likely there is better way to do it in arduino
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
delay(1000); // Delay a second between loops.
|
|
|
|
delay(10000); // Delay a second between loops.
|
|
|
|
} // End of loop
|
|
|
|
} // End of loop
|
|
|
|
|