提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
前言
提示:这里可以添加本文要记录的大概内容:
在做车载地图导航的时候,项目新增了U盘更新离线地图数据的功能。因为车机的特殊性,U盘插入车机的时候,电脑端不能查看车机的实时日志,代不方便代码调试。因此就想出把车机日志实时打印到车机上,便于观察。
提示:以下是本篇文章正文内容,下面案例可供参考
一、实现方案
思路:
此功能是基于Android悬浮窗实现,在Android系统中,每个窗口都对应一个Window对象,而悬浮窗就是一种特殊的Window。可以在其他应用程序的上层显示,可以随意拖动、缩放、关闭等操作,常用于提醒、通知、广告等。
步骤:
1.如何获取系统实时日志?
2.如何实现悬浮窗?
3.因为悬浮窗需要长期运行,不依赖于界面,所以放在服务里。
二、实现过程
1.获取系统日志
一般开发过程中可以使用cmd:
adb logcat
同样的方式也可以在代码中实现:
// 使用 adb 命令获取所有应用的 log 日志
var bufferedReader: BufferedReader? = null
try {
// 此处cmd就是我们平时常用的command命令
val cmd = "logcat -s ${
tag}"
// val cmd = "logcat com.kkw.floatlogger.*:V"
val process = Runtime.getRuntime().exec(cmd)
bufferedReader = BufferedReader(InputStreamReader(process.inputStream))
// line是每一条日志记录
var line: String?
do {
line = bufferedReader.readLine()
line?.let {
mHandler.sendMessage(Message.obtain(mHandler, 0, it))
}
} while (line != null)
} catch (e: IOException) {
e.printStackTrace()
} finally {
bufferedReader?.close()
}
使用方式:
mHandler = object : Handler(Looper.getMainLooper()) {
override fun handleMessage(msg: Message) {
super.handleMessage(msg)
mLogAdapter?.add(LogEntity(msg.obj as String?))
// 自动滚动到底部
mBinding.logList.smoothScrollToPosition(mLogAdapter?.itemCount?.minus(1) ?: 0)
}
}
2.实现Android悬浮窗
首先需要在AndroidManifest.xml中声明悬浮窗权限:
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
其次实现悬浮窗的方案有很多种,可以使用系统封装好的PopupWindow,也可以自定义配置WindowManager。
这里采用第二种方式:
/**
* 初始化悬浮窗
*/
private fun initWindow() {
// 获取WindowManager
windowManager = mContext.getSystemService(Context.WINDOW_SERVICE) as WindowManager
// 创建布局参数
layoutParams = WindowManager.LayoutParams()
//这里需要进行不同的设置
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
layoutParams?.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY
} else {
layoutParams?.type = WindowManager.LayoutParams.TYPE_PHONE
}
layoutParams?.apply {
// 设置内部视图对齐方式
gravity = Gravity.START or Gravity.TOP
// 设置窗口的宽高,这里为自动
width = WindowManager.LayoutParams.MATCH_PARENT
height = WindowManager.LayoutParams.</