当前位置: 首页 > article >正文

Android基础回顾】六:安卓显示机制Surface 、 SurfaceFlinger、Choreographer

在 Android 系统中,Surface 和 SurfaceFlinger 是图形渲染系统的核心组件,负责屏幕显示内容的合成与管理。它们协同工作,使各种 App 和系统界面能够高效地显示在屏幕上。

1 Surface 是什么?

Surface 是一个抽象的图形缓冲区接口,允许应用程序或系统组件将图像内容绘制进去,并最终显示在屏幕上。
我们可以把它理解为“一个可以绘图的画布”,在内部由一系列 GraphicBuffer 组成(通常是3个),用于支持双缓冲/三缓冲机制。

1.1 典型使用场景

应用界面绘制(由 SurfaceView, TextureView 或 SurfaceHolder 提供)

视频播放(如 MediaPlayer 或 ExoPlayer 会使用 Surface)

摄像头预览

游戏引擎的 OpenGL 渲染输出

1.2 工作方式

Surface 提供 Canvas 或 OpenGL 接口供应用绘制。绘制完成后通过 unlockCanvasAndPost() 或 eglSwapBuffers() 提交 buffer。

提交的 buffer 会被传递给系统的 SurfaceFlinger 进行合成显示。

2 SurfaceFlinger 是什么?

SurfaceFlinger 是 Android 系统中的 系统服务(native daemon),负责合成所有应用窗口、系统窗口、状态栏、导航栏等图层,然后交由显示驱动(HWComposer)将最终图像送到屏幕。

它运行在 system_server 之外的 native 层(C++ 实现),是 Android 图形系统的大脑。

2.1 SurfaceFlinger 会做什么?

管理所有 Layer(每个应用窗口对应一个 Layer)

合成 Layer(可以用 GPU 或 HWC:Hardware Composer)

控制 VSYNC(垂直同步信号)

最终输出帧到显示屏幕

2.2 SurfaceFlinger 工作流程是什么样的?

在这里插入图片描述

3 Surface 与 SurfaceFlinger是怎么交互的?

这里重点是BufferQueue 机制,因为Surface 和 SurfaceFlinger 之间就是通过 BufferQueue 共享 buffer 数据的。

Producer:App 侧绘制内容,生产图像数据。
Consumer:SurfaceFlinger 侧消费图像数据,合成显示。

而BufferQueue 内部包含多缓冲机制,确保数据同步和绘制不卡顿。

从生产-消费角度看,整体流程是这样的:
在这里插入图片描述

4 Choreographer

Choreographer 是 Android 提供的一个类,用于监听 VSYNC 信号,并在合适的时机调度你的绘制、布局和动画操作。

它属于 Android 中非常关键的 帧调度器,负责协调应用绘制的时机,确保每一帧的动画或 UI 绘制都和 VSYNC 同步,从而实现流畅的用户体验。

整体流程
在这里插入图片描述

Q&A

Canvas 是什么?

Canvas 是 Android 提供的一套 2D 绘图 API,它允许开发者使用 Java/Kotlin 或 native C++ 来绘制图形,如线条、文字、图片、矩形、圆等。

可以把 Canvas 理解为一个“画布”,你用画笔(Paint)在上面画图,最终会显示在屏幕上。

OpenGL 是什么?

OpenGL(Open Graphics Library) 是一个跨平台的 3D 图形绘制 API,Android 使用的是 OpenGL ES(嵌入式版本),用于实现更复杂、高性能的图形渲染,尤其是 3D 游戏和图形动画。

双缓冲/三缓冲机制是怎么样的?

显示系统绘制画面不是直接在屏幕上画,而是先画在内存中的缓冲区里,画完了再显示。这是为了避免中间画一半被用户看到(就是所谓的撕裂)。

什么是双缓冲,双缓冲 = 使用两个缓冲区来交替绘制和显示图像。

缓冲区用途
前缓冲区(Front Buffer)正在被显示器显示
后缓冲区(Back Buffer)正在被应用绘制新的一帧

具体流程是这样的:
在这里插入图片描述
而三缓冲呢?

缓冲区用途
Front Buffer正在显示
Back Buffer等待显示
Draw Buffer正在绘制

流程:
在这里插入图片描述

VSYNC 信号是什么?有什么用?

VSYNC(Vertical Synchronization)信号 是显示器在每次刷新屏幕内容时发出的一个时钟信号,用来告诉图形系统:

“我马上要开始绘制下一帧了,你现在可以把新的画面准备好。”

假设如果没有 VSYNC(非同步),GPU 正在往屏幕写入新图像时,显示器可能已经开始显示帧A的一部分内容。下一帧B又来了,结果就是“撕裂(tearing)”,屏幕上半部分显示的是上一帧,下半部分是下一帧。

有了 VSYNC(同步),系统所有绘制流程都会和显示器“节奏一致”;画面更新整齐,滚动、动画更平滑。
但如果处理慢,可能会“掉帧(frame drop)”

在这里插入图片描述
持续更新中。。。

http://www.lryc.cn/news/2402904.html

相关文章:

  • SpringBoot核心注解详解及3.0与2.0版本深度对比
  • 敏捷开发中如何避免过度加班
  • 深入浅出多路归并:原理、实现与实战案例解析
  • Java八股文——集合「Map篇」
  • 第1章_数据分析认知_知识点笔记
  • 111页可编辑精品PPT | 华为业务变革框架及战略级项目管理华为变革管理华为企业变革华为的管理模式案例培训
  • Python使用总结之Mac安装docker并配置wechaty
  • html文字红色粗体,闪烁渐变动画效果
  • 进阶配置与优化:配置 HTTPS 以确保数据安全传输
  • Python使用clickhouse-local和MySQL表函数实现从MySQL到ClickHouse数据同步
  • 解锁Java线程池:性能优化的关键
  • 如何自定义一个 Spring Boot Starter?
  • Linux文件系统详解:从入门到精通
  • Electron Fiddle使用笔记
  • 【PhysUnits】16.1 完善Var 结构体及其运算(variable.rs)
  • 企业培训学习考试系统源码 ThinkPHP框架+Uniapp支持多终端适配部署
  • C++ if语句完全指南:从基础到工程实践
  • SpringBoot手动实现流式输出方案整理以及SSE规范输出详解
  • 深入解析I²C总线接口:从基础到应用
  • Sklearn 机器学习 缺失值处理 检测数据每列的缺失值
  • Unity基于GraphView的可视化关卡编辑器开发指南
  • STL解析——list的使用
  • 华为大规模——重塑生产力
  • 【Go面试陷阱】对未初始化的chan进行读写为何会卡死?
  • SpringBoot自动化部署实战技术文章大纲
  • 软件项目管理(3) 软件项目任务分解
  • MQTTX连接阿里云的物联网配置
  • 20250606-C#知识:匿名函数、Lambda表达式与闭包
  • 数字证书_CA_详解
  • 衡量嵌入向量的相似性的方法