android蓝牙通信连上但是不能通信也不能使用

商品名称:
京东价:暂无报价
评价得分:
咨询内容:
为什么我的灯泡打开有声音
蓝牙能搜索到,配对的时候总是显示&无法与LED-DQ001进行通信&
京东回复:
您好!像您这种情况还未出现过,您先把灯取下来,把您手机里面的蓝牙关掉清除历史连接记录,然后重新试一下,感谢您对京东的支持!祝您购物愉快!
发表咨询:
声明:您可在购买前对产品包装、颜色、运输、库存等方面进行咨询,我们有专人进行回复!因厂家随时会更改一些产品的包装、颜色、产地等参数,所以该回复仅在当时对提问者有效,其他网友仅供参考!咨询回复的工作时间为:周一至周五,9:00至18:00,请耐心等待工作人员回复。
咨询类型:
库存及配送
发票及保修
促销及赠品
京东承诺:商品均为原装正品行货,自带机打发票,严格执行国家三包政策,享受全国联保服务。
功能咨询:咨询商品功能建议您拨打各品牌的官方客服电话,以便获得更准确的信息。
发货时间:现货:下单后一日内即可发货;在途:一般1-2天发货; 预订:一般1-6天可发货;无货:已售完,相应物流中心覆盖地区内的用户不能购买
运&&&&费:如需查看快递运输收费标准及免运费规则,
货到付款:如需查看开通货到付款地区及运费,
上门自提:上门自提不收取运费,如需查看全部自提点位置、地图、注意事项,
物流中心:京东商城拥有北京、上海、广州三个物流中心,各物流中心覆盖不同的城市,
限&&&&额:如需查看各银行在线支付限额,
大额支付:快钱支付中的招行、工行、建行、农行、广发支持大额支付,最高单笔一次支付10000元
分期付款:单个商品价格在500元以上,可使用中国银行、招商银行发行的信用卡申请分期付款,
货到付款:如需查看开通货到付款地区及运费,
京东承诺:商品均为原装正品行货,自带机打发票,严格执行国家三包政策,享受全国联保服务。
发票类型:京东商城所售商品均自带机打发票,在提供相关企业资料证明后,可申请开取增值税发票。
退 换 货:京东商城为您提供完善的退换货服务,
咨询内容:
多品类齐全,轻松购物
快多仓直发,极速配送
好正品行货,精致服务
省天天低价,畅选无忧蓝牙连接技术在物联网设计中的应用-通信/网络-与非网
嵌入式系统的发展推动了现在物联网的兴起,越来越多的B2B和B2C企业正积极将产品设计云端化,而无线技术在其中起到了至关重要的作用。在现阶段的物联网系统中,有很多都建立了自己的网关平台,旨在本地节点网络和云端远程连接中提供一定的本地存储空间和计算机智能,Wi-Fi通常运用于远程通信,而则是传感器、交换机以及家电这些边缘节点的首选协议。
低功耗蓝牙
2010年,蓝牙技术初入4.X时代,低功耗蓝牙也适时出现,其对用于物联网的传感器和控制软件来说意义非凡。低功耗蓝牙顾名思义是将低能耗作为主要目标,而非高数据速率,它的能耗降低方式有很多,例如减少无线接收装置使用时间、减少广告扫描(在打开网页过程中)渠道、只在开机状态下发送和接受小数据包等等,因此,低功耗蓝牙协议可以快速设立网络连接,而能耗通常是使用传统蓝牙版本的百分之一。然而,低功耗蓝牙也同时存在一些弊端,例如,其最大短脉冲群数据率仅为100千位/秒,而传统蓝牙最大可达3兆比特/秒(v2.0版本加上增强数据率)。因此,当数据量主导对高数据率的需求时,使用传统蓝牙协议会更加适合。
嵌入式系统设计者可以自行决定应用软件所需的蓝牙协议,然后将其与主处理系统集成。设计独有的分离无线接收装置是一个十分有突破性的想法,但是完成这个装置需要花费大量的时间。还有一种选择是采用一款已经有合格资质的蓝牙模块,将其与已有的设计相整合,不需要很高的价格就能将所有的蓝牙栈嵌入接收器主机的微控制器中,用一组与接口总线相连的简易应用程序接口,轻松地设置链接和传输数据。
图1&微芯模块&RN4020
图1为低功耗蓝牙模块&微芯RN4020.它适用于工业控制系统、物联网传感器标签和医学设备。这个模块是由一个简单的UART接口控制的。配置为应用美国信息交换标准代码指令的应用程序接口,它提供链接设置、睡眠模式切换和所有的低能耗蓝牙协议管理这些功能。RN4020模块运转时最大电流为16毫安,睡眠模式下的最小电流为5微安,关机时电流值可达1.5微安以下。与低功耗蓝牙v4.1规格相一致,RN4020模块包括了所有必需嵌入式蓝牙协议栈外形,因此应用程序微程序控制器就不需要任何堆栈来操作。
图二&RN4020框图
图二中我们可以看到RN4020模块包含了3x10比特模拟转换器频道,有多达7个通用输入输出接口,其中一些可用于操纵模块模式状态发光二极管,以显示连接状态、运转指示以及微芯的低能耗数据图是否开启。
满足多连接和应用用户界面需求的蓝牙
如果在物联网设计中需要更多的连接选择和应用软件用户界面支持,那么松下公司的PAN1740模块将是一个理想的选择。与Bluetooth Smart v4.1蓝牙低能耗规格一样,松下这款迷你的模块尺寸为:9 x 9.5 x 1.8毫米,运转时电流为5毫安。专为嵌入式应用软件设计,例如健康监测仪和运动传感器。这个模块拥有无线接收装置,Cortex-M0主机微控制器,集成式天线和内嵌式低能耗蓝牙栈。
图3&松下低能耗蓝牙模块
关注与非网微信 ( ee-focus )
限量版产业观察、行业动态、技术大餐每日推荐
享受快时代的精品慢阅读
初入职场,需要小心翼翼?工程师的职场“纸婚年”究竟是怎样的呢……
旗下网站:
与非门科技(北京)有限公司 All Rights Reserved.
京ICP证:070212号
北京市公安局备案编号: 京ICP备:号手机无法连接蓝牙耳机?
& & & 小编知道在使用蓝牙的过程中难免会出现这样或是那样的问题,蓝牙耳机无法连接是我们最常见的一个问题之一。不要轻易的以为你的蓝牙耳机坏掉了,小编前段时间第一次使用蓝牙耳机,有一次开机总是没有反应,总以为自己的蓝牙耳机坏掉了,其实就像很多人说的&电子产品没有那么脆弱!放心的使用就是了!&
& & & 一般的情况下出现这种问题的原因有两种:1、蓝牙耳机内部电池电量不足;2、蓝牙耳机的内部记忆功能失效。
怎么才能解决蓝牙耳机无法连接手机的问题呢?解决方法其实也是很简单的!
1、如果是因电量的问题而无法连接的话,我们只要充满电就可以了。
2、如果是蓝牙耳机的内部记忆功能失效的话我们要重新启动蓝牙耳机和手机的蓝牙功能。
&&&&重新配对的时候还要重新输入配对密码,小编要跟大家说的是,有可能是一次配对不成功。如果是一次不成功的话,就要重新对配几次,蓝牙耳机配对不成功是很正常的,不要急躁!
特别提示:本信息由相关企业自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。其他帐号一键登录:
& 为什么连不上wifi,也不能跟别的手机连蓝牙?
查看: 4007|回复: 4
手机看此贴:
用得意APP扫一扫
微信扫一扫 转发至朋友圈
UID269409&好友&帖子&主题&精华0&小红花0 &积分153&在线时间60 小时&注册时间&阅读权限35&最后登录&
UID269409&帖子&精华0&金币33 &威望0 &注册时间&
请高手帮忙解答,我的HTC G12突然连不上wifi了,每次连了都显示已断开。前几天本来准备传几张照片别人手机,结果蓝牙打开后别人搜不到我,我也搜不到别人。
UID164969&好友&帖子&主题&精华0&小红花13 &积分2621&在线时间427 小时&注册时间&阅读权限75&最后登录&
UID164969&帖子&精华0&金币1767 &威望0 &注册时间&
求解,我的手机在一个地方连不上。别的地方可以连上去,跟你的一样,连上去显示断开
UID333743&好友&帖子&主题&精华0&小红花0 &积分5&在线时间2 小时&注册时间&阅读权限10&最后登录&
UID333743&帖子&精华0&金币1 &威望0 &注册时间&
每次连了都显示已断开
UID257710&好友&帖子&主题&精华0&小红花8 &积分936&在线时间372 小时&注册时间&阅读权限50&最后登录&
UID257710&帖子&精华0&金币192 &威望0 &注册时间&
同样求解。。。我也是一样的问题
寂寞来袭..我的心.应该放在哪里?
UID334752&好友&帖子&主题&精华0&小红花7 &积分192&在线时间50 小时&注册时间&阅读权限1&最后登录&
UID334752&帖子&精华0&金币92 &威望0 &注册时间&
提示: 作者被禁止或删除 内容自动屏蔽
版权所有& Powered by关于Android蓝牙串口通信那点破事
Android蓝牙串口通讯
闲着无聊玩起了Android蓝牙模块与单片机蓝牙模块的通信,简单思路就是要手机通过蓝牙发送控制指令给单片机,并作简单的控制应用。单片机的蓝牙模块连接与程序暂且略过,此文主要描述Android手机蓝牙客户端遇到的那点破事。进入正题:
连接蓝牙设备——蓝牙客户端:
Android手机一般以客户端的角色主动连接SPP协议设备(接上蓝牙模块的数字传感器),客户端连接流程是:
1.使用registerReceiver注册BroadcastReceiver来获取蓝牙状态、搜索设备等消息;
private BroadcastReceiver searchDevices = new BroadcastReceiver() {&
public void onReceive(Context context, Intent intent) {
&&&&&&&&&&
String action = intent.getAction();
&&&&&&&&&&
Bundle b = intent.getExtras();
&&&&&&&&&&
Object[] lstName = b.keySet().toArray();&
&&&&&&&&&&
显示所有收到的消息及其细节
&&&&&&&&&&
for (int i =
0; i & lstName.length;
&&&&&&&&&&&&&
String keyName = lstName[i].toString();
&&&&&&&&&&&&&
Log.e(keyName,
String.valueOf(b.get(keyName)));
&&&&&&&&&&
&&&&&&&&&&
//搜索设备时,取得设备的MAC地址
&&&&&&&&&&
if (BluetoothDevice.ACTION_FOUND.equals(action)) {
&&&&&&&&&&&&&
BluetoothDevice device = intent
&&&&&&&&&&&&&&&&&&&&
.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
&&&&&&&&&&&&&
String str= device.getName() + "|" +
device.getAddress();
&&&&&&&&&&&&&
&&&&&&&&&&&&&
if (lstDevices.indexOf(str) == -1)//
防止重复添加
&&&&&&&&&&&&&&&&&
lstDevices.add(str); //
获取设备名称和mac地址
&&&&&&&&&&&&&
adtDevices.notifyDataSetChanged();
&&&&&&&&&&
2.使用BlueAdatper的搜索:
btAdapt.startDiscovery();
& & 3.在BroadcastReceiver的onReceive()里取得搜索所得的蓝牙设备信息(如名称,MAC,RSSI);
& & 4.通过设备的MAC地址来建立一个BluetoothDevice对象;
5.由BluetoothDevice衍生出BluetoothSocket,准备SOCKET来读写设备;
6.通过BluetoothSocket的createRfcommSocketToServiceRecord()方法来选择连接的协议/服务,这里用的
是SPP(UUID:0-805F9B34FB);
try {&&&&&
btSocket =
btDev.createRfcommSocketToServiceRecord(uuid);
} catch (IOException e) {
// TODO Auto-generated catch block
Log.e(TAG, "Low: Connection failed.",
成功后进行连接:
btSocket.connect();&&&&&&&&&&&&
Log.e(TAG, " BT connection established, data transfer link
;//自定义函数进行蓝牙通信处理
} catch (IOException e) {
Log.e(TAG, " Connection failed.", e);&
setTitle("连接失败..");
7.Connect之后(如果还没配对则系统自动提示),使用
&&BluetoothSocket的getInputStream()和getOutputStream()来读写蓝牙设备。
&读写可以归到一个独立线程去实现~
注意:读时必须一直循环读取串口缓冲区,写可以不需要。&
按以上7步逐次走过后,你就会发现Android蓝牙模块是多么的坑爹了。
出现问题:
在第6步一般初学者都会报错:
执行.connect()发生Connection refused
& 此时执行不下去咯,怎么办怎么办呢?
& & 于是边debug边网上找攻略,总算在Google出老外的一些做法,尝试了下,貌似还可行。也即把
btSocket的建立方法采用另一种方法替代,这里都使用端口1
btDev.getClass().getMethod("createRfcommSocket", new Class[] {int.class});
btSocket =
(BluetoothSocket) m.invoke(btDev, Integer.valueOf(1));
&&&&&&&&&&&&&
} catch (SecurityException e1) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e1.printStackTrace();
&&&&&&&&&&&&&
} catch (NoSuchMethodException e1) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e1.printStackTrace();
&&&&&&&&&&&&&
} catch (IllegalArgumentException e) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e.printStackTrace();
&&&&&&&&&&&&&
} catch (IllegalAccessException e) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e.printStackTrace();
&&&&&&&&&&&&&
} catch (InvocationTargetException e) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e.printStackTrace();
&&&&&&&&&&
至此,这个问题貌似倒也解决了,程序继续往下跑。
但这里请记住之前的异常,先别急着抛开~人家不一定一直都是异常哦
接下来的任务是,让手机通过蓝牙跟单片机的蓝牙模块通信,并发送数据,通过电脑串口调试助手显示出来。具体实现,在mangeConnectedSocket(btSocket)方法中实现,里面通过启动另一个Activity实现。不是重点,略过。
直到这里,我们都只是把手机蓝牙模块充当客户端来使用,那什么时候会用到服务端呢?其实,之前手机蓝牙与单片机蓝牙模块的通信,单片机蓝牙模块就充当了服务端(处于监听状态,被手机蓝牙连接)。为了更好地搞清楚Android蓝牙通信,我们接下来使用2个手机的蓝牙进行通信。简单地说,就是做一个“手机蓝牙扣扣”,⊙﹏⊙b汗
一开始就想天真地把之前的程序同时烧到2部手机中,发现只有一部手机能正常建立socket连接(主动连接的那台),而另一部却迟迟没有响应。原因很简单,服务端的程序还没有编写!&
于是,开始服务端程序:开辟一个新的线程实现
连接蓝牙设备——蓝牙服务端:
class AcceptThread extends Thread {
private final BluetoothServerSocket serverSocket;
public AcceptThread() {
// Use a temporary object that is later assigned
to mmServerSocket,
// because mmServerSocket is
BluetoothServerSocket tmp=null;
btAdapt.listenUsingRfcommWithServiceRecord("MyBluetoothApp",
Log.e(TAG, "++BluetoothServerSocket
established!++");
& Method listenMethod =
&btAdapt.getClass().getMethod("listenUsingRfcommOn",
&&Class[]{int.class});
= ( BluetoothServerSocket) listenMethod.invoke(btAdapt,
&&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&
Integer.valueOf( 1));
&&&&&&&&&&
} catch (SecurityException e) {
&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&
e.printStackTrace();
} catch (IllegalArgumentException e) {
&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&
e.printStackTrace();
} catch (NoSuchMethodException e) {
&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&
e.printStackTrace();
} catch (IllegalAccessException e) {
&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&
e.printStackTrace();
} catch (InvocationTargetException e) {
&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&
e.printStackTrace();
serverSocket=
&& public void run() {
// Keep listening until exception occurs or a
socket is returned
& //mState!=STATE_CONNECTED
&& while(true)
{//这里是一直循环监听,也可以设置mState来判断
&&&&&&&&&&
socket = serverSocket.accept();
&&&&&&&&&&
Log.e(TAG, "++BluetoothSocket established! DataLink
open.++");
&&&&&&&&&&&
} catch (IOException e) {
&&&&&&&&&&&&&&&
&&&&&&&&&&&
&&&&&&&&&&&
// If a connection was accepted
&&&&&&&&&&&
if (socket != null)
&&&&&&&&&&&&&&&
// Do work to manage the connection (in a separate
&&&&&&&&&&&&&&&
manageConnectedSocket();&&&&
&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&
serverSocket.close();
&&&&&&&&&&&&&
} catch (IOException e) {
&&&&&&&&&&&&&&&&&
// TODO Auto-generated catch block
&&&&&&&&&&&&&&&&&
e.printStackTrace();
&&&&&&&&&&&&&
&&&&&&&&&&&&&&&
&&&&&&&&&&&
public void cancel() {
&&&&&&&&&&&
serverSocket.close();
} catch (IOException e) { }
安装测试:当2部手机都装上并打开同样的程序后,通过蓝牙检索并连接,经测试可以成功连接上,双双进入“聊天界面”,嘿嘿
注意,这时候重新拾回之前那个异常,把socket连接建立的方法重新改为
btSocket =
btDev.createRfcommSocketToServiceRecord(uuid);//客户端
对应的服务端程序:
btAdapt.listenUsingRfcommWithServiceRecord("MyBluetoothApp",
uuid);//服务端
这样继续重新运行安装测试,在2部手机上运行发现之前那个bug消失了~2部手机又双双进入聊天界面。
任一一部手机都只能成功启动一次作为客户端的主动连接,当退出聊天界面回到主界面时(服务端的AcceptThread还在继续运行着),可再次主动连接另一部手机时就又报异常Connection refused。也就是说
客户端的蓝牙套接字2次连接时出错~哎(注意我的客户端蓝牙连接程序是没有放到一个独立线程,而是放到一个按钮监听事件中)&
又折腾了好久,没发现个所以然来,看来连完一次退出再连时就只好重启程序咯。有哪位大神知道为什么的麻烦告知下哈!
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

我要回帖

更多关于 蓝牙通信 的文章

 

随机推荐