Android 藍牙串口通信工具類 SerialPortUtil SerialPortUtil

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:

未配對設置列表只能在搜索完成後才能獲取到內容

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章