AndroidStudio Kotlin 连接到蓝牙
创始人
2024-10-10 19:30:50
0

要在Android Studio中使用Kotlin连接到蓝牙设备,可以按照以下步骤进行操作:

  1. 添加权限和特征支持: 在AndroidManifest.xml文件中添加以下权限和特征支持:


  1. 创建蓝牙连接类: 创建一个BluetoothConnection.kt文件,并在其中添加以下代码:
import android.bluetooth.BluetoothAdapter
import android.bluetooth.BluetoothDevice
import android.bluetooth.BluetoothSocket
import java.io.IOException
import java.util.*

class BluetoothConnection(private val device: BluetoothDevice) {
    private val bluetoothAdapter: BluetoothAdapter? = BluetoothAdapter.getDefaultAdapter()
    private var bluetoothSocket: BluetoothSocket? = null

    fun connect(): Boolean {
        val uuid: UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB") // 需要匹配蓝牙设备的UUID
        return try {
            bluetoothSocket = device.createRfcommSocketToServiceRecord(uuid)
            bluetoothSocket?.connect()
            true
        } catch (e: IOException) {
            false
        }
    }

    fun disconnect() {
        try {
            bluetoothSocket?.close()
        } catch (e: IOException) {
            e.printStackTrace()
        }
    }
}
  1. 在MainActivity中进行蓝牙连接: 打开MainActivity.kt文件,并在其中添加以下代码:
import android.Manifest
import android.bluetooth.BluetoothAdapter
import android.bluetooth.BluetoothDevice
import android.content.Intent
import android.content.pm.PackageManager
import android.os.Bundle
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import androidx.core.app.ActivityCompat
import androidx.core.content.ContextCompat

class MainActivity : AppCompatActivity() {
    private val bluetoothAdapter: BluetoothAdapter? = BluetoothAdapter.getDefaultAdapter()
    private val REQUEST_ENABLE_BLUETOOTH = 1
    private val REQUEST_PERMISSION_ACCESS_COARSE_LOCATION = 2
    private lateinit var bluetoothConnection: BluetoothConnection

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        // 检查设备是否支持蓝牙
        if (bluetoothAdapter == null) {
            Toast.makeText(this, "设备不支持蓝牙", Toast.LENGTH_SHORT).show()
            return
        }

        // 请求打开蓝牙
        if (!bluetoothAdapter.isEnabled) {
            val enableBluetoothIntent = Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE)
            startActivityForResult(enableBluetoothIntent, REQUEST_ENABLE_BLUETOOTH)
        } else {
            setupBluetoothConnection()
            connectToBluetoothDevice()
        }

        // 检查定位权限
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION)
            != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(
                this,
                arrayOf(Manifest.permission.ACCESS_COARSE_LOCATION),
                REQUEST_PERMISSION_ACCESS_COARSE_LOCATION
            )
        }
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        if (requestCode == REQUEST_ENABLE_BLUETOOTH && resultCode == RESULT_OK) {
            setupBluetoothConnection()
            connectToBluetoothDevice()
        }
    }

    override fun onRequestPermissionsResult(
        requestCode: Int,
        permissions: Array,
        grantResults: IntArray
    ) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults)
        if (requestCode == REQUEST_PERMISSION_ACCESS_COARSE_LOCATION) {
            if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                setupBluetoothConnection()
                connectToBluetoothDevice()
            }
        }
    }

    private fun setupBluetoothConnection() {
        val pairedDevices: Set? = bluetoothAdapter?.bondedDevices
        val device: BluetoothDevice? = pairedDevices?.find { it.name == "Your Bluetooth Device Name" } // 替换为你的蓝牙设备名称
        device?.let {
            bluetoothConnection = BluetoothConnection(device)
        }
    }

    private fun connectToBluetoothDevice() {
        if (bluetoothConnection.connect()) {
            Toast.makeText(this, "蓝牙连接成功", Toast.LENGTH_SHORT).show()
        } else {
            Toast.makeText(this, "蓝牙连接失败", Toast.LENGTH_SHORT).show()
        }
    }

    override fun onDestroy() {
        super.onDestroy()
        bluetoothConnection.disconnect()
    }
}

请注意,上述代码中的“Your Bluetooth

相关内容

热门资讯

这一现象值得深思!we pok... 这一现象值得深思!we poker辅助器v3.3,impoker辅助,法门教程(真的有挂)-哔哩哔哩...
透视好牌!德普之星有辅助软件吗... 透视好牌!德普之星有辅助软件吗,德普之星怎么设置埋牌(透视)确实有挂(有挂教学)-哔哩哔哩1、德普之...
今日!广东雀神智能插件需要付费... 今日!广东雀神智能插件需要付费吗,小程序微乐斗地主辅助,办法教程(有挂方略)-哔哩哔哩1、广东雀神智...
透视透视挂!德普之星透视辅助软... 透视透视挂!德普之星透视辅助软件是真的吗,德普之星透视辅助软件(透视)竟然有挂(有挂教学)-哔哩哔哩...
据报道!天天贵阳破解版,wep... 据报道!天天贵阳破解版,wepoker插件功能辅助器,方式教程(果真有挂)-哔哩哔哩;在进入wepo...
透视中牌率!德普之星辅助器ap... 透视中牌率!德普之星辅助器app,德普之星的辅助工具介绍(透视)竟然是真的挂(有人有挂)-哔哩哔哩1...
截至发稿!丰城双剑辅助器,小程... 截至发稿!丰城双剑辅助器,小程序雀神雀神智能插件,总结教程(详细教程)-哔哩哔哩1、下载好小程序雀神...
透视脚本!德普辅助器怎么用,德... 透视脚本!德普辅助器怎么用,德普之星透视软件免费入口官网(透视)一直是有挂(有挂解密)-哔哩哔哩1、...
为了进一步!多乐破解游戏盒子破... 为了进一步!多乐破解游戏盒子破解版,微乐小程序自建房辅助下载,机巧教程(有挂秘笈)-哔哩哔哩1、微乐...
透视脚本!德普之星怎么开辅助,... 透视脚本!德普之星怎么开辅助,德普之星怎么开辅助(透视)竟然真的是有挂(有挂功能)-哔哩哔哩一、德普...