VSYNC on Android N

2024-01-28 20:58
文章标签 android vsync

本文主要是介绍VSYNC on Android N,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VSYNC on Android N

1.      什么是VSYNC

当屏幕从缓冲区扫描完一帧到屏幕上之后,开始扫描下一帧之前,发出的一个同步信号,该信号用来切换前缓冲区和后缓冲区。

2.      HWComposer、SurfaceFlinger和VSYNC

HWComposer封装了显示设备,而SurfaceFlinger用于合成显示图层,再将其刷入到HWComposer封装的显示设备中。

当显示驱动支持时,VSYNC由硬件定时发送到HWComposer中;否则HWComposer会新起一个线程模拟发送VSYNC信号,其原理也十分简单,就是定期唤起线程发送信号。

HWComposer每次收到VSYNC信号,都会触发SurfaceFlinger中的回调onVSyncReceived()

VSYNC信号的初始化和发送如下图所示:


a. HAL层的VSYNCenable后,会不断发送VSYNC信号,并触发HWC的回调函数hook_vsync(),继而调用到SFonVSyncReceived()

b. systrace里有两个HW_VSYNC,一个叫HW_VSYNC_ON_0,其实就是记录的0 display的硬件VSYNC打开或关闭事件。记录点在HWComposer::eventControl()中,每当设置的enable与之前的enable状态不一致时(即enable->disable,disable->enable)记录。

另外一个叫HW_VSYNC_0,记录的是0 display的硬件VSYNC事件,记录点在HWComposer::vsync()中,即每当HALVSYNC事件发生,并回调到HWC的回调函数vsync()时记录。

c. 可以看出SFmEventControlThread线程用于控制HWCVSYNC信号的开关:通过调用EventControlThread::setVsyncEnabled()打开或关闭HWCVSYNC信号;SFonVSyncReceived()代表接收到了HWC层的VSYNC信号。

3.      SurfaceFlingerDispSync

SF的成员变量mPrimaryDispSync,引用一个DispSync对象。

DispSync可以理解为SF层的sync信号。APPSF自身会监听该信号,用于控制App绘制UISF合成显示图层的节奏。

DispSync中有一个成员变量DispSyncThread,该线程的threadLoop()为一个无限循环:

a. 首先判断mPeriod是否等于0

b. 不为0的话计算下个唤醒时间,继续3, 4, 5,否则挂在mCond上;

c. 在唤醒时间点,判断是否有注册的mEventListeners

d. 有的话则依次调用监听者的回调函数onDispSyncEvent()

e. 继续循环进入步骤1

系统只有一个DispSync,有两个EventListerner注册在它的mThread中,分别为appsfDispSyncSource对应的EventListener

SurfaceFlinger::init()中会层层调用到DispSync::setPeriod(),继而触发DispSyncmThread开始定期发送sync信号,并且调用监听者的回调。

4.      VSYNC-sf

VSYNC-sf用于控制SF合成Layer的节奏,可以理解为sf对应的DispSyncSource发出的sync信号,再触发EventThread的回调并转换成事件写入写端,最后触发读端的回调MessageQueue::cb_eventReceiver()SF开始合成显示图层。

DispSyncSource其实就是DispSync的监听者,通过DispSync再转发出自己所需的sync信号。

其流程图如图所示:


a. EventThread::threadLoop()发现有Connection注册了才会调用成员函数enableVSyncLocked():注册自己为CallbackDispSyncSource中,并且调用DispSyncSource::setVSyncEnabled()DispSyncSource注册为监听者到DispSync中;

b. DispSyncThread::threadLoop()只要DispSyncThread::mPeriod被设置,则开始定期发送信号。信号流为DispSyncSource::onDispSyncEvent()-->EventThread::onVSyncEvent()EventThread::threadLoop()收到事件后,再通过EventThread::Connection::postEvent()在写端写数据;对于sfEventThread来说,读端读到数据,则触发回调MessageQueue::cb_eventReceiver(),继而调用SFdispatchInvalidate(),开始合成显示图层。

5.      VSYNC-app

VSYNC-app用于控制APP绘制UI的节奏,类似4,其实就是SFapp-DispSyncSource根据自己需要,转发DispSyncsync信号。

4不同的是,SFinit()函数就已经创建了Connection,并注册在sf-EventThread中,而APP是后续有应用有需要了才会创建Connection并注册到SFapp-EventThread中。

APP中和VSYNC-app打交道的类为ChoreographerChoreographer的成员属性mDisplayEventReceiver:FrameDisplayEventReceiver用于接收SF端的VSYNC-app信号,其原理和4类似,最后就是通过native层的DisplayEventReceiver,创建并注册一个ConnectionSFsf-EventThread中,native层的DisplayEventDispatcher再将Connection的读端和自己通过addFd注册到mLooper中,后续VSYNC-app信号会触发DisplayEventDispatcherhandleEvent(),继而调用到FrameDisplayEventReceiveronVsync()

6.      总体类图

见下图,绿色的类代表有一个独立的线程,对于硬件支持VSYNC的情况下,一共有四个线程。

 

   参考文档:

a.http://windrunnerlihuan.com/2017/05/25/Android-SurfaceFlinger-%E5%AD%A6%E4%B9%A0%E4%B9%8B%E8%B7%AF-%E4%BA%94-VSync-%E5%B7%A5%E4%BD%9C%E5%8E%9F%E7%90%86/

b.https://blog.csdn.net/jinzhuojun/article/details/17293325

c.https://blog.csdn.net/sosesoA/article/details/51087639

d.https://blog.csdn.net/a740169405/article/details/70548443#t6

 

 

 

 

 

 


这篇关于VSYNC on Android N的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/654757

相关文章

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤