卡顿分析

FPS帧率统计评测应用流畅度并不准确

系统获取FPS的原理:手机屏幕显示的内容是通过Android系统的SurfaceFlinger类,把当前系统里所有进程需要显示的信息合成一帧,然后提交到屏幕上显示,FPS就是1秒内SurfaceFlinger提交到屏幕的帧数,SurfaceFlinger目前的启动方式是做为init进程中的一个Service来启动。

App停止操作后,FPS还是在一直变化,这种情况是否会影响到FPS的准确度?

有的时候FPS很低,APP看起来却很流畅,是因为当前界面在1秒内只需要10帧的显示需求,当然不会卡顿,此时FPS只要高于10就可以了,如果屏幕根本没有绘制需求,那FPS的值就是0。

Vsync(垂直同步)指的是显卡的输出帧数和屏幕的垂直刷新率相同。

垂直同步的含义我们可以理解为,使得显卡生成帧的速度和屏幕刷新的速度的保持一致。举例来说,如果屏幕的刷新率为60Hz,那么生成帧的速度就应该被固定在1/60 s。

Android 4.1引入了VSync机制可以通过其Loop来了解当前App最高绘制能力。

Choreographer接收显示系统的时间脉冲(垂直同步信号-VSync信号),在下一个frame渲染时控制执行这些操作,控制同步处理输入(Input)、动画(Animation)、绘制(Draw)三个UI操作。

Choreographer类的构造方法:

1.初始化FrameHandler。接收处理消息。

2.初始化FrameDisplayEventReceiver。FrameDisplayEventReceiver用来接收垂直同步脉冲,就是VSync信号,VSync信号是一个时间脉冲,一般为60HZ,用来控制系统同步操作,怎么同ChoreoGrapher一起工作的,将在下文介绍。

3.初始化mLastFrameTimeNanos(标记上一个frame的渲染时间)以及mFrameIntervalNanos(帧率,fps,一般手机上为1s/60)。

4.初始化CallbackQueue,callback队列,将在下一帧开始渲染时回调。

FrameHandler

一个简单的handler,处理3个类型的消息。

MSG_DO_FRAME:开始渲染下一帧的操作

MSG_DO_SCHEDULE_VSYNC:请求Vsync信号

MSG_DO_SCHEDULE_CALLBACK:请求执行callback

FrameDisplayEventReceiver

FrameDisplayEventReceiver继承自DisplayEventReceiver接收底层的VSync信号开始处理UI过程。VSync信号由SurfaceFlinger实现并定时发送。FrameDisplayEventReceiver收到信号后,调用onVsync方法组织消息发送到主线程处理。这个消息主要内容就是run方法里面的doFrame了,源码中mTimestampNanos是信号到来的时间参数。

1.PostCallBack,发起添加回调,这个FrameCallBack将在下一帧被渲染时执行。

2.AddToCallBackQueue,将FrameCallBack添加到回调队列里面,等待时机执行回调。每种类型的callback按照设置的执行时间(dueTime)顺序排序分别保存在一个单链表中。

3.判断FrameCallBack设定的执行时间是否在当前时间之后,若是,发送MSG_DO_SCHEDULE_CALLBACK消息到主线程,安排执行doScheduleCallback,安排执行CallBack。否则直接跳到第4步。

4.执行scheduleFrameLocked,安排执行下一帧。

5.判断上一帧是否已经执行,若未执行,当前操作直接结束。若已经执行,根据情况执行以下6、7步。

6.若使用垂直同步信号进行同步,则执行7.否则,直接跳到9。

7.若当前线程是UI线程,则通过执行scheduleVsyncLocked请求垂直同步信号。否则,送MSG_DO_SCHEDULE_VSYNC消息到主线程,安排执行doScheduleVsync,在主线程调用scheduleVsyncLocked。

8.收到垂直同步信号,调用FrameDisplayEventReceiver.onVsync(),发送消息到主线程,请求执行doFrame。

9.执行doFrame,渲染下一帧。

Choreographer中可以实现FrameCallback接口,然后实现里边的doFrame方法,可以获取到帧率等信息,通过Choreographer.getInstance().postFrameCallback(new MyFPSFrameCallback());

把你的回调添加到Choreographer之中,那么在下一个frame被渲染的时候就会回调你的callback,执行你定义的doFrame操作,这时候你就可以获取到这一帧的开始渲染时间并做一些自己想做的事情了。

开源组件Tiny Dancer就是根据这个原理获取每一帧的渲染时间,继而分析实现获取设备的当前帧率的。有兴趣的人可以查看。friendlyrobotnyc/TinyDancer​github.com

private long mLastFrameTimeNanos=0; //实际执行当前frame的时间

private long mFrameIntervalNanos;

public FpsInfo(long lastFrameTimeNanos){

mLastFrameTimeNanos=lastFrameTimeNanos;

mFrameIntervalNanos=(long)(1000000000 / 60.0); // 帧率,也就是渲染一帧的时间,getRefreshRate是刷新率,一般是60

}

@Override

public void doFrame(long frameTimeNanos) { //Vsync信号到来的时间frameTimeNanos

if(mLastFrameTimeNanos==0){

mLastFrameTimeNanos=frameTimeNanos;

}

final long jitterNanos=frameTimeNanos-mLastFrameTimeNanos;

if(jitterNanos>=mFrameIntervalNanos){

final long skippedFrames=jitterNanos/mFrameIntervalNanos;

//Log.i("Testing","Skipped "+skippedFrames+" frames!");

if(skippedFrames>60){ //设定丢帧率 60

Log.i("Testing","Skipped "+skippedFrames+" frames!");

}

}

mLastFrameTimeNanos=frameTimeNanos;

//注册下一帧的回调

Choreographer.getInstance().postFrameCallback(this);

}

尽量避免在执行动画或渲染操作之后在主线程执行操作,在之前或之后都应该尽量避免发送消息到主线程looper。

流畅度衡量指标:

1.帧率FPS

2.丢帧SF(Skipped frame)

3.流畅度SM(SMoothness)。

优化流程:

1.UI层级嵌套绘制

2.静态代码扫描工具配合

3.Traceview定位主线程卡顿问题

4.Systrace分析

5.Strictmode严苛模式主线程耗时操作

6.Blockcanary非侵入式自动检测卡顿

android动画帧率_Android帧率、卡顿详解及使用相关推荐

  1. android动画帧率_Android性能测试帧率、卡顿详解及分析使用

    卡顿分析 FPS帧率统计评测应用流畅度并不准确 系统获取FPS的原理:手机屏幕显示的内容是通过Android系统的SurfaceFlinger类,把当前系统里所有进程需要显示的信息合成一帧,然后提交到 ...

  2. nvidia-smi卡顿详解

    如果显卡数量在4张以上,在nvidia-smi信息后会非常的慢,非常的卡.尤其在只在乎计算量服务器的时候. 我试过把8张卡 tesla K80 显卡一个个拆下来 8张.7张 6/5/4/3/2/1 试 ...

  3. 如何应对CPU帧率瓶颈和卡顿?腾讯游戏学院专家带你剖析

    CPU上帧率低和卡顿是性能优化中最易出现的一部分,尤其对于手游,提到卡,就大概率是在CPU上出现的问题,CPU上的卡顿一般是卡逻辑或是卡渲染,本篇将详细系统的介绍基于UE的手游对CPU瓶颈的剖析方法. ...

  4. Android 流畅度评估及卡顿定位、优化

    转载:在路上的博客:Android 流畅度评估及卡顿优化 导言:本文主要是关于 Android 流畅度和卡顿优化的全方位介绍,算是对 2020 部分工作的总结. 文章目录 1.渲染和流畅概念 (1)为 ...

  5. Android NFC卡实例详解

    Android NFC卡实例详解 公司最近在做一个NFC卡片的工程,经过几天的时间,终于写了一个Demo出来,在此记录下在此过程中遇到的问题.由于之前本人是做iOS的,Android写起来并不是那么的 ...

  6. Android 各大厂面试题汇总与详解(持续更新)

    介绍 目前网络中出现了好多各种面试题的汇总,有真实的也有虚假的,所以今年我将会汇总各大公司面试比较常见的问题,逐一进行解答.会一直集成,也会收集大家提供的面试题,如有错误,请大家指出,经过排查存在,会 ...

  7. 【转】Android APK反编译就这么简单 详解(附图)

     转自:http://blog.csdn.net/vipzjyno1/article/details/21039349/ [置顶] Android APK反编译就这么简单 详解(附图) 分类: and ...

  8. Android性能优化之APK瘦身详解(瘦身73%)

    image 公司项目在不断的改版迭代中,代码在不断的累加,终于apk包不负重负了,已经到了八十多M了.可能要换种方式表达,到目前为止没有正真的往外推过,一直在内部执行7天讨论需求,5天代码实现的阶段. ...

  9. Android 8.0学习(32)---Android 8.0源码目录结构详解

    Android 8.0源码目录结构详解 android的移植按如下流程:     (1)android linux 内核的普通驱动移植,让内核可以在目标平台上运行起来.     (2)正确挂载文件系统 ...

最新文章

  1. 【组队学习】【28期】基于Python的会员数据化运营
  2. 做项目需要使用的工具类
  3. 清华大学首批研究生学术与职业发展能力提升项目评估交流会举行
  4. 404.2错误解决方案
  5. 债券指数(Bond Index)
  6. 爱情是一出未经排练的戏
  7. 微软开源可扩展存储引擎Extensible Storage Engine
  8. 【渝粤教育】国家开放大学2019年春季 2080现代教育思想 参考试题
  9. java什么时候创建进程,Java创建进程
  10. 安装rtx时报错因计算机中丢失lo,policy.3.1.IntervalZero.RTX64.dll
  11. iOS-OC-APP热更新,动态更新(仿QQ打开或关闭某个功能)
  12. linux popen管道,linux进程通信之标准流管道popen
  13. go interface转int_Go 中 slice 的 In 功能实现探索
  14. svn st 的状态说明
  15. 将Python文件打包成so文件
  16. 回归 ----一元线性回归
  17. linux测试硬盘读写速度
  18. STC15单片机使用AT命令的C语言编程
  19. MATLAB中有关矩阵特征值和特征向量的计算
  20. 学Maven,看这一篇就够了!(视频|资料,建议收藏!)

热门文章

  1. 目标检测YOLO实战应用案例100讲-小麦麦穗的目标检测与杂草分类识别研究
  2. IDEA MAVEN项目中导入jar包not found
  3. flutter 页面加载动画_十、Flutter加载动画
  4. 重温数据结构:哈希 哈希函数 哈希表
  5. 个人数字助理,平板与智能手机走近
  6. declared implicitly
  7. 应急响应-----Windows系统排查(学习笔记)
  8. windows下dirsearch安装
  9. 【ORACLE】Oracle提高篇之WITH AS
  10. 【Python基础】parse_args()的使用