frameworks 之 Winscope 工具

frameworks 之 Winscope 工具

  • [1. 手机端开启](#1. 手机端开启)
  • [2. 加载追踪的文件](#2. 加载追踪的文件)
    • [2.1 Android12](#2.1 Android12)
  • [3. 分析文件](#3. 分析文件)

Winscope 是一款 Web 工具,可以让用户在动画和转换期间和之后记录、重放和分析多个系统服务的状态。Winscope 将所有相关的系统服务状态记录在一个跟踪文件中。使用带有跟踪文件的 Winscope 界面,您可以通过重放、单步执行和调试转换来针对每个动画帧检查这些服务的状态

1. 手机端开启

  1. 进入设置 -> 系统 -> 开发者选项 -> 快捷设置开发者模块
  2. 勾选 winscope 追踪
  3. 下拉状态栏菜单点击即启动,再次点击即暂停

记录下的文件夹在 /data/misc/wmtrace 下,文件如下

名称 意义
ime_trace_clients.winscope 输入法相关
ime_trace_managerservice.winscope 输入法相关
ime_trace_service.winscope 输入法相关
layers_trace.winscope SurfaceFlinger 图层相关
wm_log.winscope
wm_trace.winscope WindowManager相关

运行后 可通过 拉到电脑下

bash 复制代码
adb pull /data/misc/wmtrace

2. 加载追踪的文件

2.1 Android12

对应 html 路径如下
prebuilts/misc/common/winscope 点击下面的Index.html 用google浏览器打开。

3. 分析文件

一般导入 layers_trace.winscopewm_trace.winscope 查看黑屏问题。

字段 意义
Simplify names 显示简短的名称
Only visible 显示可见的
Flat 折叠
Show Diff 表示与上一帧的差别
下方进度条 表示对应的进度,左右代表前进后退
Properties 选中图层的属性

选择勾选 diff

  • 绿色的 表示 新增
  • 红色的 表示 删除当带标签move的时候表示 当前图层移动到 另外图层 如584 移动到 600下面的

    查看黑屏可以选择 flat 跟 Only visible这样留意哪个图层消失并且过一会重新出现
    如下图 ,这时候 586 图层可见

    下一帧 消失 并且持续好多帧不可见

    最后 重新添加了 604图层 可知是中间丢失了导致黑屏
相关推荐
程序员码歌26 分钟前
短思考第263天,每天复盘10分钟,胜过盲目努力一整年
android·前端·后端
安卓兼职framework应用工程师41 分钟前
Android 10.0 按键智能机按键连续响两次的异常处理
android·audio·audioservice·按键音·按键声音
studyForMokey1 小时前
【Android 项目】个人学习demo随笔
android
吃喝不愁霸王餐APP开发者1 小时前
利用责任链模式解耦多平台(美团/饿了么)霸王餐接口的适配逻辑
android·责任链模式
百***78751 小时前
Step-Audio-2 轻量化接入全流程详解
android·java·gpt·php·llama
yangpipi-3 小时前
《C++并发编程实战》第5章 C++内存模型和原子操作
android·java·c++
云水木石5 小时前
Android 的下一个战场:Windows 应用与游戏?
android·windows·游戏
雨声不在6 小时前
Android文字渐变的实现
android·textview
GoldenPlayer6 小时前
KTS语法
android
GoldenPlayer6 小时前
后台服务Service销毁逻辑+单例造成的内存泄露
android