Android学习Bluetooth总结

本文详细介绍了如何使用Android进行蓝牙开发,包括客户端和服务端的实现过程。客户端和服务端通过UUID建立连接,实现数据传输。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

蓝牙是API level 5 就有的一个技术 由于我对这个技术感兴趣 就学习了下 将学到的知识和大家分享下

客户端
private static final UUID MY_UUID_SECURE = UUID.fromString("fa87c0d0-afac-11de-8a39-0800200c9a66"); //安全的
private static final UUID MY_UUID_INSECURE = UUID.fromString("8ce255c0-200a-11e0-ac64-0800200c9a66"); //不安全的


首先我们先将蓝牙的权限加上
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>
<uses-permission android:name="android.permission.BLUETOOTH"/>

要想扫描到蓝牙 蓝牙对方必须是可见的
通过intent 启动 BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE 就可以将蓝牙可见

蓝牙可见了我们就获取获取蓝牙的适配器

BluetoothAdapter.getDefaultBluetoothAdapter();

在通过蓝牙适配器的startDiscovery() 方法开始扫描周边可见的蓝牙 通过绑定广播过滤 new IntentFilter(BluetoothDevice.ACTION_FOUND) //代表找到了蓝牙

BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); //获取到蓝牙的驱动 根据驱动来获取 地址及其相关信息
if (device.getBondState() != BluetoothDevice.BOND_BONDED) {
}

也可以通过getBondedDevices() 获取驱动 这个方法返回的是一个集合

要想连接服务器 我们通过驱动获取地址 通过getRemoteDevice(address); 获取到指定蓝牙的驱动

在通过这个驱动的 createInsecureRfcommSocketToServiceRecord(MY_UUID_INSECURE); //这个是不安全的是不需要验证的

createRfcommSocketToServiceRecord(MY_UUID_SECURE); //这个是安全的需要验证的


他俩都会返回一个BluetoothSocket 对象 我们通过他调用 connect() 和服务器端连接

如果连接成功 就可以通过他获取input 或 output 流 来写去和读取


服务器端

我们通过 BlueAdapter的 listenUsingInsecureRfcommWithServiceRecord(NAME_INSECURE,MY_UUID_INSECURE);//不安全的 这俩个方法 是与客户端的俩个方法对应的

listenUsingRfcommWithServiceRecord(NAME_SECURE, MY_UUID_SECURE); //安全的


他们会返回一个BluetoothServerSocket 对象 在通过这个对象的 accpet()方法(注意这个方法是会阻塞主线程的 我们要将他放到子线程 ) 返回一个BluetoothSocket 对象

在通过socket对象 获取input或output流来传输数据

蓝牙讲解完毕,第一次写博客还望大牛指教

转载于:https://www.cnblogs.com/dsy1243996554/p/5665573.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值