Flutter 简述(1)

Flutter 简述

简述

Flutter是Google开源的应用框架,只要一套代码兼顾Android、iOS、Web、Windows、macOS和Linux六个平台,它的设计思路可以说更加先进,不像ReactNative每个组件都需要有对应的原生组件实现,而是通过skia或者其他的渲染引擎来直接渲染画面,Flutter使用dart虚拟机来实现跨平台管理UI。

在dart上,会通过Widget构建Element,然后Element会构建RendorObject,然后RendorObject渲染的时候通过canvas来调用底层渲染引擎做最终的绘制。

直接使用渲染引擎来实现跨平台UI渲染,当需要实现复杂定制化UI时,我们依旧只需要实现一套UI,不需要在每个平台使用一个原生组件单独实现,切在性能方面也会有更好的表现,相当于节约了原生层面UI管理的工作量。

框架结构

  • dart虚拟机
    Flutter的UI是使用dart实现的,也是通过dart来实现跨平台,dart语言和kotlin比较相似,所以对于Android应用开发的同学,上手Flutter还是比较简单的。
    dart语言可以编译成各个平台的二进制程序,也可以编译成各个JS。且dart即可以支持JIT编译模式,也支持AOT编译模式。JIT编译模式可以支撑Flutter热加载,而AOT可以编译成可预期高效的程序,作为UI渲染使用更多语言,可预期是很重要的,需要稳定,否则就会出现掉帧。
  • 渲染引擎
    早期的Flutter使用的渲染引起是skia,Android之前也是使用skia来处理2D渲染。后面Flutter推出了Impeller,Impeller是Flutter推出的渲染引擎。Impeller是专门为Flutter设计的渲染引擎,支持使用OpenGL和Vulkan,优化了渲染流程以及对GPU对使用效率。

涉及内容

Flutter的架构很简单,就是使用dart来统一语言平台,然后使用渲染引擎绘制UI,所以我们主要来研究一下dart层的逻辑,学习一下Flutter是怎么实现UI的管理,包括Touch事件传递,与其他模块交互等等。

  • Flutter 启动流程
  • Flutter UI构建
  • Flutter 渲染
  • Flutter Touch事件传递
  • 。。。
相关推荐
音视频牛哥1 小时前
大牛直播SDK(SmartMediaKit)Android平台Unity3D RTSP/RTMP播放器集成实践
android·unity3d·rtsp播放器·rtmp播放器·unity3d rtmp播放器·安卓unity rtsp播放器·安卓unity rtmp播放器
w1wi2 小时前
安卓抓包完全指南(一):从入门到 SSL Pinning 绕过
android·网络协议·ssl
程序员老刘3 小时前
跨平台开发地图:大厂统一底层,五月框架大乱斗谁在干实事?| 2026年5月
flutter·客户端
aqi003 小时前
一文理清 HarmonyOS 6.0.2 涵盖的十个升级点
android·华为·harmonyos·鸿蒙·harmony
赏金术士4 小时前
Jetpack Compose 状态提升(State Hoisting)完全指南
android·kotlin·compose
BoomHe5 小时前
git Rebase 为任意一笔提交补上 Change-Id
android·git·android studio
TDengine (老段)5 小时前
TDengine 超级表/子表/普通表 — 设计理念与内部表示
android·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
环信即时通讯云5 小时前
环信Flutter UIKit适配鸿蒙实战指南
flutter·华为·harmonyos
shuaiqinke5 小时前
【分享】Edge浏览器|内置扩展仓库|支持油猴|上网无限制
android·前端·人工智能·edge