Flutter2.0原理解析

Flutter2.0原理解析



前言

因个人水平有限,对Flutter2.0的底层原理的认知不全,便于刚接触Flutter的同学理解 文章没有涉及源码的解释。


一、UI显示系统

Flutter和AndroidUI显示系统的区别(举例)

Android UI显示系统

在这里插入图片描述
几乎所有用于开发GUI程序的编程语言都会在操作系统上再封装一层,将操作系统原生API封装在一个编程框架和模型中,然后定义一种简单的开发规则来开发GUI应用系统
例如

  • AndroidSDK是封装Android操作系统API,提供了一个“UI描述文件XML + java操作DOM”的UI系统
  • IOS的UIKit对View的抽象也是一样的,他们都将操作系统API抽象成一个基础对象(如用于2D图形绘制的Canvas)然后在定义一套规则来描述UI,如UI树结构,UI操作的单线程原则等

Flutter UI显示系统

无论是Android SDK 还是IOS的UIKit,它们只是语言载体和底层的系统不同而已,哪如果存在一种UI系统,可以用同一种语言开发,然后针对不同操作系统的API接口,一个对上接口一致、对下适配不同操作系统的中间层,打包编译使用想应的中间层代码。如果能满足这些条件,那么我们就可以使用同一套代码编写跨平台的应用。
所以Flutter的原理正是如此,它提供了一套Dart API ,然后在底层通过Skia这种跨平台的绘制库(内部会调用操作系统API)实现了一套代码跨多端

在这里插入图片描述
在这里插入图片描述

二、为什么Flutter无限接近于原生

一.为什么Android不是无限接近于原生(举例)

在这里插入图片描述
从流程图就可以看出 为什么Android和原生搭不上边,所以说android的UI系统是通过xml层层封装调用Skia的API来实现的

二.为什么Flutter是无线接近原生

在这里插入图片描述
在这里插入图片描述
Flutter通过Dart代码再用Flutter解析直接向Skia调用API,那么显而易见就相当于直接调用了Skia去完成UI的渲染,相比Android来说流程少了不止一步两步

为什么Flutter可以运行在多个平台中

是因为Skia在各个平台有各个的版本 ,不是Flutter跨平台 而是Skia跨平台Flutter只是调用的SkiaAPI接口。


结尾

祝大家乘风破浪

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值