[009]SurfaceFlinger是什么东西

2020-06-08 10:45:47 浏览数 (1)

前言

很多人都听过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,你会感叹发明图形计算机的人是真的牛逼。

0 人点赞