【Android】性能监控之帧率检测Tinydancer

git地址

使用

增加依赖

 dependencies {
   debugCompile "com.github.brianPlummer:tinydancer:0.1.2"
   releaseCompile "com.github.brianPlummer:tinydancer-noop:0.1.2"
   testCompile "com.github.brianPlummer:tinydancer-noop:0.1.2"
 }

在Application中初始化

public class DebugApplication extends Application {

  @Override public void onCreate() {
   TinyDancer.create()
             .show(context);
  }
}

运行App,给予窗口权限。

进入App后,右上角可以看到一个数字,代表当前的帧率。
【Android】性能监控之帧率检测Tinydancer_第1张图片
如果帧率低于60,表明主线程执行了耗时操作,影响了界面的更新。

此时,我们就要去分析造成耗时的原因,提升应用性能。

定位掉帧位置:Profiler分析函数执行时间

个性化设置


   TinyDancer.create()
   //红色警告百分比
      .redFlagPercentage(.1f)
      //窗口在界面上的初始位置 
      .startingXPosition(200)
      .startingYPosition(600)
      .show(context);


   TinyDancer.create()
       .addFrameDataCallback(new FrameDataCallback() {
          @Override
          public void doFrame(long previousFrameNS, long currentFrameNS, int droppedFrames) {
             //添加自定义回调
          }
        })
        .show(context);

原理

屏幕每秒向系统发送60次刷新信号。

系统每接收到一次信号,就准备好绘制内容交给屏幕展现。

帧与帧的时间间隔正是留给系统准备内容的时间,约等于16ms。

如果准备时间超过16ms,屏幕没有收到下一帧的内容,就产生了所谓的丢帧。

丢帧严重时,用户会感觉到App卡顿。

关于系统是如何更新界面的,可以看这里:界面是如何刷新的流程

Choreographer是绘制流程的核心类,官方的文档这样描述:

协调动画、输入和绘图的时间。
Choreographer接收定时脉冲(如垂直同步),然后为下一帧部分渲染安排工作

理所应当,Choreographer具有帧回调接口。

回调返回的是帧开始渲染的时间。

public interface FrameCallback {
    public void doFrame(long frameTimeNanos);
}

TinydancerFPSFrameCallback实现了FrameCallback接口。

public class FPSFrameCallback implements Choreographer.FrameCallback{
	
	@Override
    public void doFrame(long frameTimeNanos)
    {
		...
    	Choreographer.getInstance().postFrameCallback(this);
    }

}

Tinydancer的核心原理就是接收每次的绘制信号,实时计算两次绘制之间的间隔,转换成帧率。

你可能感兴趣的:(android,App优化,android,java)