SerialPortUtil
介紹
SerialPortUtil 簡介
SerialPort 是一個開源的對 Android 藍牙串口通信的輕量封裝庫,輕鬆解決了構建自己的串口調試APP的複雜程度,讓人可以專注追求自己設計,不用爲考慮藍牙串口底層的配置。
- 集成搜索Activity,不用自己費力去實現
- 通過回調處理接收數據
- 異步處理髮送
- 接收與發送均可使用十六進制和字符串
- 內置普通按鍵和Toggle型按鍵Listener
最新版本 V0.1.0.200721_beta
該版本已經基本實現以上全部功能,可能會有部分Bug,但不會影響到核心功能。
開始
安裝
Gradle
根目錄 build.gradle 加入以下代碼:
allprojects {
repositories {
// 省略其代碼...
maven { url 'https://jitpack.io' }
}
}
app模塊的 build.gradle 加入以下代碼即可:
dependencies {
// 省略其代碼...
implementation 'androidx.core:core-ktx:1.3.0'
implementation 'com.gitee.Shanya:SerialPortUtil:V0.1.0.200721'
}
JDK版本
使用的時候需要把JDK版本調成1.8,在app模塊的 build.gradle 加入以下代碼即可:
compileOptions {
// 省略其代碼...
sourceCompatibility = 1.8
targetCompatibility = 1.8
}
使用
獲取 SerialPort 對象
SerialPort serialPort = new SerialPort.getInstance(this);
val serialPort = SerialPort.getInstance(this)
打開搜索頁面
serialPort.openSearchPage(MainActivity.this);
serialPort.openSearchPage(this)
設置接收數據類型
可選參數(默認是 字符類型) | |
---|---|
SerialPort.READ_DATA_TYPE_STRING | 字符類型 |
SerialPort.READ_DATA_TYPE_HEX | 十六進制 |
serialPort.setReadDataType(SerialPort.READ_DATA_TYPE_STRING);
serialPort.readDataType = SerialPort.READ_DATA_TYPE_STRING
設置發送數據類型
可選參數(默認是 字符類型) | |
---|---|
SerialPort.SEND_DATA_TYPE_STRING | 字符類型 |
SerialPort.SEND_DATA_TYPE_HEX | 十六進制 |
serialPort.setSendDataType(SerialPort.SEND_DATA_TYPE_STRING);
serialPort.sendDataType = SerialPort.SEND_DATA_TYPE_STRING
接收數據
serialPort.getReceivedData(new Function1<String, Unit>() {
@Override
public Unit invoke(String s) {
// s 就是收到的數據
return null;
}
});
serialPort.getReceivedData{it
// it 就是收到的數據
}
發送數據
- 發送字符型
serialPort.sendData("Hello World!");
serialPort.sendData("Hello World!")
- 發送十六進制
//發送 0xAA 0xDD 0xFF
serialPort.sendData("AADDFF");
//發送 0xAA 0xDD 0xFF
serialPort.sendData("AADDFF")
使用普通按鍵Listener
- 設置每個按鍵發送的內容
serialPort.setButtonSendData(R.id.button,"button");
serialPort.setButtonSendData(R.id.button1,"button1");
serialPort.setButtonSendData(button.id,"button")
serialPort.setButtonSendData(button1.id,"button1")
- 綁定Listener
button.setOnTouchListener(serialPort.getSendButtonListener());
button1.setOnTouchListener(serialPort.getSendButtonListener());
button.setOnTouchListener(serialPort.sendButtonListener)
button1.setOnTouchListener(serialPort.sendButtonListener)
使用Toggle按鍵Listener
- 設置每個Toggle按鍵打開時發送的內容
serialPort.setSwitchSendData(R.id.button,"button");
serialPort.setSwitchSendData(R.id.button1,"button1");
serialPort.setSwitchSendData(button.id,"button")
serialPort.setSwitchSendData(button1.id,"button1")
- 設置每個Toggle按鍵打開時顯示的文本
serialPort.getSwitchOnTextHashMap().put(R.id.button, "on");
serialPort.getSwitchOnTextHashMap().put(R.id.button1, "on");
serialPort.switchOnTextHashMap[button.id] = "on"
serialPort.switchOnTextHashMap[button1.id] = "on"
- 設置每個Toggle按鍵關閉時顯示的文本
serialPort.getSwitchOffTextHashMap().put(R.id.button, "off");
serialPort.getSwitchOffTextHashMap().put(R.id.button1, "off");
serialPort.switchOffTextHashMap[button.id] = "off"
serialPort.switchOffTextHashMap[button1.id] = "off"
- 綁定Listener
button.setOnClickListener(serialPort.getSendSwitchListener());
button.setOnClickListener(serialPort.sendSwitchListener)
獲取掃描狀態
serialPort.getScanStatus(new Function1<Boolean, Unit>() {
@Override
public Unit invoke(Boolean aBoolean) {
//aBoolean 就是掃描狀態
System.out.println(aBoolean);
return null;
}
});
serialPort.getScanStatus { it
//it 就是掃描狀態
}
獲取連接狀態
serialPort.getConnectionResult(new Function1<Boolean, Unit>() {
@Override
public Unit invoke(Boolean aBoolean) {
//aBoolean 就是連接狀態
System.out.println(aBoolean);
return null;
}
});
serialPort.getConnectionResult { it
//it 就是連接狀態
}
獲取已配對設配列表
ArrayAdapter<String> arrayAdapter = serialPort.getPairedDevicesArrayAdapter();
val arrayAdapter = serialPort.pairedDevicesArrayAdapter
獲取未配對設備列表
ArrayAdapter<String> arrayAdapter = serialPort.getUnPairedDevicesArrayAdapter();
val arrayAdapter = serialPort.unPairedDevicesArrayAdapter
Tips:
未配對設置列表只能在搜索完成後才能獲取到內容