返回
顶部

修改密码

android设备连接蓝牙外设导致activity重启(recreate)的问题

+1

-1

收藏

+1

-1

点赞0

评论0

最近遇到个bug,在android连接蓝牙设备后,程序异常退出(仅在部分nexus设备上出现)。从logcat发现在JNI层报了一个错(我的程序使用了JNI),一路追上去发现程序的异常是因为activity的onDestroy被调用了。这就好办了,肯定是因为设备连接后,触发了configChange,而程序又…

最近遇到个bug,在android连接蓝牙设备后,程序异常退出(仅在部分nexus设备上出现)。

从logcat发现在JNI层报了一个错(我的程序使用了JNI),

一路追上去发现程序的异常是因为activity的onDestroy被调用了。

这就好办了,肯定是因为设备连接后,触发了configChange,而程序又没有正常处理这种情况。

检查了一下AndroidManifest.xml,发现activity的configChanges属性为


[plain]
android:configChanges="fontScale|keyboard|keyboardHidden|locale|orientation|screenLayout|uiMode|screenSize" 

android:configChanges="fontScale|keyboard|keyboardHidden|locale|orientation|screenLayout|uiMode|screenSize"几乎包含了所有的configChanges,除了mcc, mnc, touchscreen, navigation, smallestScreenSize和layoutDirection。

其中mcc和mnc理论上不可能发生变化,因为我压根儿就没挪地儿;

touchscreen和navigation在android doc中都标识为“This should never normally happen”,所以暂时也不考虑;

而smallestScreenSize和layoutDirection理论上也不可能出现。

但除了configChanges导致activity重启,实在想不到其他的可能性了。

于是将这几个configChange逐一加入进行问题排查,最终发现是navigation导致的。

回想一下,我连接的是蓝牙键盘,连接后确实导致了navigation的类型发生变化

因为连接蓝牙键盘后,我可以使用方向键来navigate了。

让人大跌眼镜啊,实践出真知,文档不可信(android的文档尤其如此)。

不过,这个问题只出现在手头的部分nexus设备上,

还是可以理解的,毕竟设备的定位摆在那里。

但鉴于nexus的设备普及率还是有一些的,仍然无法忍受这种碎片化的问题。

 

扫一扫在手机打开

评论
已有0条评论
0/150
提交
热门评论
相关推荐
Android蓝牙开发
  • 近场通信
  • 2022-05-20 18:30
  • 5 0 0
+1
android 蓝牙分析
  • 近场通信
  • 2022-05-20 18:30
  • 10 0 0
+1
android4.0蓝牙使能的详细解析
  • 近场通信
  • 2022-05-20 18:30
  • 2 0 0
+1
Android 蓝牙API 之 BluetoothAdapter 类
  • 近场通信
  • 2022-05-20 18:30
  • 1 0 0
+1
android蓝牙源码分析
  • 近场通信
  • 2022-05-20 18:30
  • 5 0 0
+1
今日要闻
换一批
热点排行