Skia 图形引擎介绍
文章目录
- 一、Skia 的基本概念
- 1. 定位与作用
- 2. 历史背景
- 二、Skia 的核心架构
- 1. 模块化设计
- 2. 渲染流程
- 3. 跨平台适配
- 三、Skia 在 Flutter 中的角色
- 1. 自绘 UI 的核心依赖
- 2. 跨平台一致性
- 3. 性能优化
- 四、Skia 的性能优势
- 1. 高效的图形处理
- 2. 与原生渲染的对比
- 3. 性能瓶颈
- 五、Skia 的应用场景
- 六、与其他图形引擎的对比
- 七、未来发展方向
- 总结
Skia 是一个开源的 2D 图形渲染引擎,由 Google 主导开发和维护,广泛应用于 Android、Flutter、Chrome、Firefox 等项目中。它提供了高性能的图形绘制能力,支持跨平台硬件加速,是现代跨平台开发框架(如 Flutter)的核心底层依赖。
一、Skia 的基本概念
1. 定位与作用
- 核心能力:实现 2D 图形(如形状、文本、图像)的高效绘制,支持矢量图形和位图操作。
- 跨平台性:抽象底层图形 API(如 OpenGL、Vulkan、Metal),提供统一的接口,适配不同操作系统(Android、iOS、Windows、Linux、macOS)。
- 应用场景:UI 渲染、图表绘制、图像处理、动画合成等。
2. 历史背景
- 2005 年由 Skia Inc. 公司开发,后被 Google 收购并开源。
- 现为 Chromium 项目的默认图形引擎,也是 Android 系统的图形库(替代早期 Canvas 实现)。
二、Skia 的核心架构
1. 模块化设计
- Canvas:核心绘图接口,定义绘制命令(如
drawRect
,drawText
)。 - Shaders:处理渐变、纹理填充等复杂视觉效果。
- Path:定义矢量路径(贝塞尔曲线、几何形状)。
- Fonts:文本渲染,支持多种字体格式(如 TrueType、OpenType)。
- Image:位图解码与处理(支持 PNG、JPEG、WebP 等格式)。
- GPU 加速:通过 OpenGL、Vulkan 或 Metal 实现硬件加速渲染。
2. 渲染流程
- 命令记录:通过
SkCanvas
记录绘制操作(如画矩形、写文字)。 - 合成与优化:合并重复操作,减少 GPU 调用次数。
- 提交到 GPU:通过图形 API(如 OpenGL)将指令发送到 GPU 执行。
- 显示结果:将帧缓冲数据输出到屏幕。
3. 跨平台适配
- 后端支持:根据平台自动选择最佳图形 API:
- Android:OpenGL ES / Vulkan
- iOS/macOS:Metal
- Windows:Direct3D / ANGLE(OpenGL 兼容层)
- Web:WebGL / WebAssembly
- 平台抽象层:通过
GrContext
(GPU 上下文)隔离底层差异。
三、Skia 在 Flutter 中的角色
1. 自绘 UI 的核心依赖
- Flutter 的 Widget 树最终转换为 Skia 绘制指令,直接渲染到屏幕,绕过平台原生控件。
- 例如,Flutter 的
Text
Widget 通过 Skia 的文本渲染引擎绘制,而非调用 Android 的TextView
或 iOS 的UILabel
。
2. 跨平台一致性
- 通过 Skia 的统一渲染,确保 Android 和 iOS 的 UI 表现完全一致。
- 避免原生控件因平台差异导致的样式或行为问题(如滚动效果、动画曲线)。
3. 性能优化
- 硬件加速:Skia 自动启用 GPU 渲染,提升复杂 UI 的流畅度。
- 帧率控制:与 Flutter 引擎协作,支持 60/120 FPS 的高刷新率。
- 离屏渲染:通过
SkPicture
缓存静态 UI,减少重复计算。
四、Skia 的性能优势
1. 高效的图形处理
- 矢量图形优化:使用光栅化算法快速处理路径和曲线。
- 文本渲染加速:支持字形缓存(Glyph Cache),减少字体解析开销。
- 并行渲染:多线程提交 GPU 指令(如 Android 的 RenderThread)。
2. 与原生渲染的对比
场景 | Skia(Flutter) | 原生渲染 |
---|---|---|
UI 一致性 | 完全一致(跨平台) | 依赖平台控件,可能存在差异 |
复杂动画 | 需手动优化(如避免过度重绘) | 系统级优化(如 Core Animation) |
平台特性集成 | 需通过插件桥接 | 直接调用原生 API |
包体积 | 较大(包含引擎和 Skia 库) | 较小(仅平台必要组件) |
3. 性能瓶颈
- 首次启动延迟:需加载 Skia 库和初始化 GPU 上下文。
- 重度图形计算:如实时滤镜、3D 变换,性能弱于直接调用平台 API(如 Metal)。
五、Skia 的应用场景
-
移动应用
- Android 系统级绘图(如 View 的 Canvas)。
- Flutter 应用的跨平台 UI 渲染。
-
浏览器渲染
- Chromium 的 2D 图形绘制(如 HTML Canvas、CSS 样式)。
-
桌面应用
- 如 Google Earth 的界面渲染。
-
嵌入式设备
- 低功耗设备的图形显示(基于 Skia 的轻量级移植版)。
六、与其他图形引擎的对比
引擎 | 特点 | 典型应用 |
---|---|---|
Skia | 专注 2D,跨平台,开源 | Flutter, Android |
Core Graphics | iOS/macOS 原生 2D 引擎(Quartz 2D) | iOS 应用 |
Direct2D | Windows 原生 2D 引擎,深度集成 DX | Windows 桌面程序 |
Cairo | 开源 2D,多用于 Linux 桌面 | GTK, Firefox |
七、未来发展方向
- 更高效的 GPU 利用
- 增加对 Vulkan 的深度支持,替代 OpenGL 作为默认后端。
- 3D 扩展
- 实验性支持 3D 渲染(如与 Flutter 的 3D 插件结合)。
- WebAssembly 优化
- 提升 Skia 在 Web 端的性能(如 Flutter Web)。
总结
Skia 通过统一的 2D 图形抽象层,平衡了跨平台适配与渲染性能,成为 Flutter 等框架的核心支柱。尽管在极端场景下可能略逊于原生优化,但其灵活性、一致性和开源生态使其成为现代跨平台开发的首选图形引擎。
结束语
Flutter是一个由Google开发的开源UI工具包,它可以让您在不同平台上创建高质量、美观的应用程序,而无需编写大量平台特定的代码。我将学习和深入研究Flutter的方方面面。从基础知识到高级技巧,从UI设计到性能优化,欢饮关注一起讨论学习,共同进入Flutter的精彩世界!
相关文章:
Skia 图形引擎介绍
文章目录 一、Skia 的基本概念1. 定位与作用2. 历史背景 二、Skia 的核心架构1. 模块化设计2. 渲染流程3. 跨平台适配 三、Skia 在 Flutter 中的角色1. 自绘 UI 的核心依赖2. 跨平台一致性3. 性能优化 四、Skia 的性能优势1. 高效的图形处理2. 与原生渲染的对比3. 性能瓶颈 五、…...
构建高可靠NFS存储:自动化挂载保障机制的设计与优势
一、背景与需求场景 在分布式系统或集群架构中,NFS(Network File System)是跨节点共享存储的经典方案。然而,传统/etc/fstab配置的静态挂载方式存在明显缺陷: 服务启动顺序不可控,网络未就绪时挂载失败临…...
Spring Boot对接twilio发送邮件信息
要在Spring Boot应用程序中对接Twilio发送邮件信息,您可以使用Twilio的SendGrid API。以下是一个简单的步骤指南,帮助您完成这一过程: 1. 创建Twilio账户并获取API密钥 注册一个Twilio账户(如果您还没有的话)。在Twi…...
如何创建并保存HTML文件?零基础入门教程
原文:如何创建并保存HTML文件?零基础入门教程 | w3cschool笔记 本文将以Windows系统为例,教你用最简单的记事本创建并保存第一个HTML网页。 📝 第一步:准备工具 文本编辑器:使用系统自带的记事本ÿ…...
vue3 + css 列表无限循环滚动+鼠标移入停止滚动+移出继续滚动
1.动画文件.vue <template><div class"dashboard" click"setFullScreen"><div class"warp-box"><el-scrollbar ref"scrollRef" height"100%" scroll"handelScroll"><div class"…...
C#的简单工厂模式、工厂方法模式、抽象工厂模式
工厂模式是一种创建型设计模式,主要将对象的创建和使用分离,使得系统更加灵活和可维护。常见的工厂模式有简单工厂模式、工厂方法模式和抽象工厂模式,以下是 C# 实现的三个案例: 简单工厂模式 简单工厂模式通过一个工厂类来创建…...
Vue:Vue2和Vue3创建项目的几种常用方式以及区别
前言 Vue.js 和 Element UI 都是用 JavaScript 编写的。 1、Vue.js 是一个渐进式 JavaScript 框架。2、Element UI 是基于 Vue.js 的组件库。3、JavaScript 是这两个项目的主要编程语言。 而Element Plus是基于TypeScript开发的。 一、Vue2 1、基于vuecli工具创建 vue2 …...
C++ list类
C list类 目录 C list类引言1.list的使用1.1 list的构造1.2 list的iterator的使用1.3 list capacity1.4 list element acess1.5 list modifiers 2. list的迭代器失效3. list的模拟实现3.1 List.h文件3.2 List的反向迭代器 4.list与vector的对比 引言 在C标准库中,l…...
LeetCode 热题 100_跳跃游戏(78_55_中等_C++)(贪心算法)
LeetCode 热题 100_跳跃游戏(78_55) 题目描述:输入输出样例:题解:解题思路:思路一(贪心算法): 代码实现代码实现(思路一(贪心算法)&am…...
【Redis】Redis的数据删除(过期)策略,数据淘汰策略。
如果问到:假如Redis的key过期之后,会立即删除吗? 其实就是想问数据删除(过期)策略。 如果面试官问到:如果缓存过多,内存是有限的,内存被占满了怎么办? 其实就是问:数据的淘汰策略。…...
C++和标准库速成(八)——指针、动态数组、const、constexpr和consteval
目录 1. 指针和动态数组1.1 栈和自由存储区1.2 使用指针1.3 动态分配的数组1.4 空指针常量 2. const2.1 const修饰类型2.2 const与指针2.3 使用const保护参数2.4 const方法(建议) 3. constexpr4. consteval参考 1. 指针和动态数组 动态内存允许所创建的程序具有在编…...
深入解析 Spring Boot 中的 FailureAnalyzer
深入解析 Spring Boot 中的 FailureAnalyzer 在 Spring Boot 应用中,我们难免会遇到启动失败的情况,而默认的异常信息往往过于复杂,导致排查问题变得困难。Spring Boot 提供了一套强大的 FailureAnalyzer 机制,能够捕获常见的异常…...
20. Excel 自动化:Excel 对象模型
一 Excel 对象模型是什么 Excel对象模型是Excel图形用户界面的层次结构表示,它允许开发者通过编程来操作Excel的各种组件,如工作簿、工作表、单元格等。 xlwings 是一个Python库,它允许Python脚本与Excel进行交互。与一些其他Python库&#x…...
【Matlab GUI】封装matlab GUI为exe文件
注:封装后的exe还是需要有matlab环境才能运行 (1)安装MCRinstaller.exe文件,在matlab安装目录下的toolbox/compiler/deploy/win64文件夹里 (2)安装完MCRinstaller.exe,字命令窗口输入&#x…...
ModBus TCP/RTU互转(主)(从)|| Modbus主动轮询下发的工业应用 || 基于智能网关的串口服务器进行Modbus数据收发的工业应用
目录 前言 一、ModBus TCP/RTU互转(从)及应用|| 1.1 举栗子 二、ModBus TCP/RTU互转(主) 2.1 举栗子 三、ModBus 主动轮询 3.1 Modbus主动轮询原理 3.2 Modbus格式上传与下发 3.2.1.设置Modbus主动轮询指令 3.2.2 设…...
Linux top 命令详解:从入门到高级用法
Linux top 命令详解:从入门到高级用法 在 Linux 系统中,top 是一个强大的实时监控工具,用于查看系统资源使用情况和进程状态。它可以帮助你快速了解 CPU、内存、负载等信息,是系统管理员和开发者的日常利器。本文将从基本用法开始…...
【网络协议】基于UDP的可靠协议:KCP
TCP是为流量设计的(每秒内可以传输多少KB的数据),讲究的是充分利用带宽。而 KCP是为流速设计的(单个数据包从一端发送到一端需要多少时间),以10%-20%带宽浪费的代价换取了比 TCP快30%-40%的传输速度。TCP信…...
【Docker入门】构建推送第一个Docker映像
【Docker入门】构建推送第一个Docker映像 Build and Push the First Docker Image By JacksonML Docker的容器(Container)映像是轻量级的可执行独立包,包含代码、运行时、库、环境变量以及配置文件,它对于运行软件至关重要。注册表可在团队间分享映像。…...
Python----计算机视觉处理(Opencv:图像颜色替换)
一、开运算 开运算就是对图像先进行腐蚀操作, 然后进行膨胀操作。开运算可以去除二值化图中的小的噪点,并分离相连的物体。 其主要目的就是消除那些小白点 在开运算组件中,有一个叫做kernel的参数,指的是核的大小,通常…...
搭建自己的OCR服务
网上看到相关文章,这里整理记录一下,仅供学习。 搭建自己的OCR服务,第一步:选择合适的开源OCR项目 - PandaCode辉 - 博客园 一、OCR是什么? 光学字符识别(Optical Character Recognition, OCR)…...
vue:组件的使用
Vue:组件的使用 1、什么是组件 1.1、传统方式开发的应用 一个网页通常包括三部分:结构(HTML)、样式(CSS)、交互(JavaScript)。在传统开发模式下,随着项目规模的增大&a…...
leetcode日记(105)买卖股票的最佳时机Ⅱ
原本以为是一个很难想的动态规划,没想到是最简单的贪心…… 如果实在想不出就画个折线图,只买上涨的就行了,所有上涨的段都取到。 真的没想到会这么简单…… class Solution { public:int maxProfit(vector<int>& prices) {int …...
7种数据结构
7种数据结构 顺序表sqlite.hseqlite.c 单链表linklist.clinklist.h 双链表doulinklist.cdoulinklist.h 链式栈linkstack.clinkstack.h 队列SeqQueue.cSeqQueue.h 树tree.c 哈希表hash.c 顺序表 sqlite.h #ifndef __SEQLIST_H__ #define __SEQLIST_H__ typedef struct person…...
论文阅读:Deep Hybrid Camera Deblurring for Smartphone Cameras
今天介绍一篇 ACM SIGGRAPH 2024 的文章,关于手机影像中的去模糊的文章。 Deep Hybrid Camera Deblurring for Smartphone Cameras Abstract 手机摄像头尽管取得了显著的进步,但由于传感器和镜头较为紧凑,在低光环境下的成像仍存在困难&am…...
Redis 三主三从集群部署的完整方案
一、架构设计原理 分布式数据分片 哈希槽机制:Redis Cluster 将数据划分为 16384 个槽位,每个主节点负责部分槽位(如主节点1管理槽0-5460,主节点2管理5461-10922等)。 自动负载均衡:数据按哈希值分配…...
C++项目:高并发内存池_上
目录 1. 项目介绍 2. 内存池概念 2.1 池化技术 2.2 内存池和内存碎片 2.3 细看malloc 3. 定长内存池的实现 ObjectPool.hpp 4. 高并发内存池框架 5. thread cache测试 5.1 thread cache框架 5.2 ConcurrentAlloc.hpp 6. central cache测试 6.1 central cache框架 …...
『Plotly实战指南』--折线图绘制基础篇
在数据分析的世界中,折线图是一种不可或缺的可视化工具。 它能够清晰地展示数据随时间或其他变量的变化趋势,帮助我们快速发现数据中的模式、趋势和异常。 无论是金融市场分析、气象数据监测,还是业务增长趋势预测,折线图都能以直…...
【css酷炫效果】纯CSS实现波浪形分割线
【css酷炫效果】纯CSS实现波浪形分割线 缘创作背景html结构css样式完整代码效果图 想直接拿走的老板,链接放在这里:https://download.csdn.net/download/u011561335/90492023 缘 创作随缘,不定时更新。 创作背景 刚看到csdn出活动了&…...
【资料分享】全志科技T113-i全国产(1.2GHz双核A7 RISC-V)工业核心板规格书
核心板简介 创龙科技SOM-TLT113 是一款基于全志科技T113-i 双核ARM Cortex-A7 玄铁C906 RISC-V HiFi4 DSP 异构多核处理器设计的全国产工业核心板,ARM Cortex-A7 处理单元主频高达1.2GHz。核心板 CPU、ROM、RAM、电源、晶振等所有元器件均采用国产工业级方案&…...
Coco AI 智能检索 Hugo Blog 集成指南
在此前的文章中,我们介绍了如何使用 Coco Server 连接 Notion,实现智能内容检索。本次,我们将进一步探索如何在 Coco Server 最新版本 中集成 Hugo Site,以便对 Hugo 站点 进行高效检索。 Coco Server 部署方式 要在本地或服务器…...
【MySQL数据库】多表查询(笛卡尔积现象,联合查询、内连接、左外连接、右外连接、子查询)-通过练习快速掌握法
在DQL的基础查询中,我们已经学过了多表查询的一种:联合查询(union)。本文我们将系统的讲解多表查询。 笛卡尔积现象 首先,我们想要查询emp表和stu表两个表,按照我们之前的知识栈,我们直接使用…...
jmeter将返回的数据写入csv文件
举例说明,我需要接口返回体中的exampleid与todoid的数据信息(使用边界提取器先将其提取),并将其写入csv文件进行保存 使用后置处理器BeanShell 脚本实例如下 import java.io.*;// 设置要写入的文件路径 String filePath "…...
AI如何在财务工作中提升效率的一些看法
文章目录 1. 自动化重复性任务2. 财务预测与分析3. 欺诈检测与风险管理4. 智能报表与决策支持5. 税务管理优化6. 提升团队协作与客户体验未来的趋势与挑战结论 随着人工智能(AI)技术的迅猛发展,其正全方位地革新各行各业的运作模式࿰…...
OpenCV入门指南:从安装到基本操作
引言 OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库。它包含了数百种计算机视觉算法,广泛应用于图像处理、视频分析、物体检测、人脸识别等领域。本文将带你从安装OpenCV开始,逐步了解其基…...
简单以太网配置
display arp //查看路由器mac地址 交换机配置命令: system-view // 从用户视图进入系统视图 dis mac-address //查看mac地址表 路由器配置命令: system-view // 从用户视图进入系统视图 int GigabitEthernet 0/0/0 //进入G口 0/0/0 进入之后配置网关: ip addre…...
蓝桥杯嵌入式组第十四届省赛题目解析+STM32G431RBT6实现源码
文章目录 1.题目解析1.1 分而治之,藕断丝连1.2 模块化思维导图1.3 模块解析1.3.1 KEY模块1.3.2 LED模块1.3.3 LCD模块1.3.4 TIM模块1.3.4.1 频率变化处理1.3.4.1 占空比计算 1.3.5 ADC模块 2.源码2.1cubemx配置3.第十四届题目 前言:STM32G431RBT6实现嵌入…...
让双向链表不在云里雾里
又来博客留下我的足迹了,哈哈哈,这次是对于双向链表的理解 目录 创建双向链表: 申请结点: 双向链表初始化: 双向链表插入结点: 双向链表删除结点: 双向链表的打印: 双向链表…...
基于django+vue的购物商城系统
开发语言:Python框架:djangoPython版本:python3.8数据库:mysql 5.7数据库工具:Navicat11开发软件:PyCharm 系统展示 系统首页 热卖商品 优惠资讯 个人中心 后台登录 管理员功能界面 用户管理 商品分类管理…...
在Vue3中使用Echarts的示例
1.常用-引用ts文件方式 1.1 导出ts文件-一个简单的柱状图 export const baseBarChart (xdata: string[], data: number[][], legendData: string[]) > {if (data.length 0) {return noData;}// 定义颜色数组const color [#00CCCC,#FF9900,#1677DC,#FF6666,#B366FF,#666…...
TCP协议的多线程应用、多线程下的网络编程
DAY13.2 Java核心基础 多线程下的网络编程 基于单点连接的方式,一个服务端对应一个客户端,实际运行环境中是一个服务端需要对应多个客户端 创建ServerSocketNable类,多线程接收socket对象 public class ServerSocketNable implements Run…...
每日学习Java之一万个为什么(待补充)
Git分支操作 git branch 分支名 git branch -v git checkout -b 分支名 git checkout 分支名 git merge 分支名 git branch -d | -D 分支名Git冲突 git同名文件合并的最基本单位是行。同名文件同一行不同就会发生冲突。 解决办法:及时沟通,手动更改&…...
设计C语言的单片机接口
一、主要内容 (一)控制引脚 1、定义管脚 // 定义管脚的结构体 struct pin{ int id; // 管脚编号 int mode; // 模式,输入为1,输出为0 int pull; // 输入电阻 int driver; // 功率 } 2、输出电平 语法: void pin_output(s…...
博客迁移----宝塔面板一键迁移遇到问题
前景 阿里云轻量级服务器到期了,又免费领了个ESC, 安转了宝塔面板。现在需要迁移数据,使用宝塔面板一键迁移功能,完成了数据的迁移,改了域名的解析,现在进入博客是显示502 bad grateway 宝塔搬家参考链接…...
抽象工厂模式 (Abstract Factory Pattern)
抽象工厂模式 (Abstract Factory Pattern) 是一种创建型设计模式,它提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。 一、基础 1. 意图 提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。 2. …...
LeetCode 第14~16题
目录 LeetCode 第14题:最长公共前缀 LeetCode 第15题:三数之和 LeetCode 第16题:最接近的三数之和 LeetCode 第14题:最长公共前缀 题目描述 编写一个函数来查找字符数组中的最长公共前缀。如果不存在公共前缀,返回字符…...
深入了解Linux —— git三板斧
版本控制器git 为了我们方便管理不同版本的文件,就有了版本控制器; 所谓的版本控制器,就是能够了解到一个文件的历史记录(修改记录);简单来说就是记录每一次的改动和版本迭代的一个管理系统,同…...
再学:abi编码 地址类型与底层调用
目录 1.内置全局变量及函数 2.abi 3.地址类型 4.transfer 1.内置全局变量及函数 2.abi data就是abi编码 abi描述:以json格式表明有什么方法 3.地址类型 4.transfer x.transfer:合约转给x call 和 delegatecall 是 Solidity 中用于底层合约调用的函数࿰…...
Redis的消息队列是怎么实现的
Redis 本身并不是一个专门的消息队列系统,但它的 List、Pub/Sub 和 Stream 数据结构可以用来实现消息队列的功能。以下是 Redis 实现消息队列的几种常见方式: 1. 基于 List 实现消息队列 Redis 的 List 是一个双向链表,支持在头部和尾部进行高效的插入和删除操作,非常适合…...
图论入门【数据结构基础】:什么是树?如何表示树?
图论是计算机科学和数学中的一个重要分支,研究图的结构及其性质。之前我们介绍了图的基本概念和表示:图论入门【数据结构基础】:什么是图?如何表示图?,本文将介绍树的基本概念、性质及其在计算机科学中的应…...
微信小程序订阅消息发送消息,点击消息进入小程序页面
1、在小程序官网订阅消息选用或创建消息模板获取模板ID可多个 如图: 2、微信小程序前端页面发送请求订阅权限 请求模板id的权限可以是一个可以是多个,用户同意订阅,获取code传递给后端——后端拿到code生成唯一的openid用于发送订阅消息 注…...