[009]SurfaceFlinger是什么东西

前言

很多人都听过SurfaceFlinger,但是不清楚Surfaceflinger到底是一个什么东西,我接下来用直白的语言讲述一下SurfaceFlinger,这里更多的讨论是大体框架,而不是代码,我一直觉得首先看懂框架,才能去猜测写代码的人写什么东西。

SurfaceFlinger = Surface + Flinger

SurfaceFlinger是一个特殊进程,主要负责合成所有Surface到Framebuffer,然后屏幕去读取这个Framebuffer,然后显示给用户看。

举个栗子

王老师每天要完成一幅美术作品,美术作品包含三个部分,一个房子,一条小河,一座山,他手下有三个学生A,B,C,王老师给了一个空白的贴纸给A让他去画一个房子,给了一个空白的贴纸给B让他去画一条河,给了一个空白的贴纸给C让他去画一座山。并且通知他们每天12点准时上交贴纸,然后由王老师临摹三个贴纸上房子,小河,山到了一张固定尺寸的白纸上,每天将当天画的美术作品给美术馆,让其展览。

故事中的角色在Android手机中代表什么

学生A,B,C

学生A,B,C对应到Android系统上就是Activity,悬浮窗口,壁纸,导航栏,通知栏。我们可以简称一个Window

空白的贴纸

空白的贴纸代表一个Surface,代表一块可以通过OpenGL或者skia的方式进行绘制的buffer,就是一个内存,或者理解为一个bitmap

每天12点

每天12点就是Vsync信号,所有绘制和合成的时间点,手机里一般是16毫秒一次,因为手机的帧率是60hz

美术作品

美术作品就是FrameBuffer,一块内存

王老师

王老师就是SurfaceFlinger,负责用OpenGL的将所有的Surface重新绘制到FrameBuffer

美术馆

美术馆就是手机屏幕,每天展示SurfaceFlinger准备好的FrameBuffer

看下面一个图

屏幕快照 2019-08-09 下午1.54.50.png

深入思考一个问题

如何实现锤子手机到TNT上,类似PC桌面一样的系统

这个问题其实并没有想象中那么难,只要我们去修改SurfaceFlinger合成所有Surface的方案,按照PC桌面的样子合成不就好了嘛,也就是王老师将房子,河,山,按照PC桌面的样子临摹最后的白纸上。

如何实现大屏的单手模式,就是把整个屏幕按比例缩小到屏幕的左下角,或者右下角

这个问题也只需要我们去修改SurfaceFlinger合成所有Surface的方案就好了,但是这里可能不是简单的改一下位置,也就是王老师需要按照比例缩小房子,河,山之后再临摹到到白纸上。PS:但是这仅仅解决了显示的问题,单手模式还得考虑触控的问题,需要将坐标点等比放大,这里就不仔细深入探讨了。

APP和SurfaceFlinger之间是怎么跨进程传递Surface

大家都知道一次Binder通信不能传递大于1M-8K的数据,如果不清楚,可以先学习一下[007]一次Binder通信最大可以传输多大的数据?,所有采用的是匿名共享内存和Binder结合的方式传递Surface,如果不清楚匿名共享内存,可以学习一下[006]匿名共享内存(Ashmem)的使用

总结

SurfaceFlinger是一个很有意思进程,如果看过了SurfaceFlinger,你会感叹发明图形计算机的人是真的牛逼。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容