flutter学习-day2-认识flutter

这篇具有很好参考价值的文章主要介绍了flutter学习-day2-认识flutter。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文学习和引用自《Flutter实战·第二版》:作者:杜文

1. 简介

Flutter 是 Google 推出并开源的移动应用开发框架,主打跨平台、高保真、高性能。开发者可以通过 Dart 语言开发 App,一套代码同时运行在 iOS 和 Android平台。 Flutter 提供了丰富的组件、接口,开发者可以很快地为 Flutter 添加 Native扩展。

2. 特点

  • 跨平台自绘引擎

    • Flutter 既不使用 WebView,也不使用操作系统的原生控件。 相反,Flutter 使用自己的高性能渲染引擎来绘制 Widget(组件)。这样不仅可以保证在 Android 和iOS 上 UI 的一致性,也可以避免对原生控件依赖而带来的限制及高昂的维护成本。
    • Flutter 底层使用 Skia 作为其 2D 渲染引擎,Skia 是 Google的一个 2D 图形处理函数库,包含字型、坐标转换,以及点阵图,它们都有高效能且简洁的表现。Skia 是跨平台的,并提供了非常友好的 API,目前 Google Chrome浏览器和 Android 均采用 Skia 作为其 2D 绘图引擎。
  • 高性能

    • Flutter App 采用 Dart 语言开发。Dart 在 JIT(即时编译)模式下,执行速度与 JavaScript 基本持平。但是 Dart 支持 AOT,当以 AOT模式运行时,JavaScript 便远远追不上了。执行速度的提升对高帧率下的视图数据计算很有帮助。
    • Flutter 使用自己的渲染引擎来绘制 UI ,布局数据等由 Dart 语言直接控制,所以在布局过程中不需要像 RN 那样要在 JavaScript 和 Native 之间通信,这在一些滑动和拖动的场景下具有明显优势。
  • 采用Dart语言开发

    • Flutter 在开发阶段采用 JIT 模式(动态解释),这样就避免了每次改动都要进行编译,极大地节省了开发时间。
    • Flutter 在发布时可以通过 AOT(提前编译) 生成高效的机器码以保证应用性能,而 Dart 支持 AOT。
    • Dart 语言的静态类型检查,可以有效避免运行时错误,减少崩溃率。
    • 类型安全和空安全+快速内存分配

3. 架构

Flutter 从上到下可以分为三层:框架层、引擎层和嵌入层。

3-1. 框架层

框架层Flutter Framework,这是一个纯 Dart实现的 SDK,它实现了一套基础库,自底向上。

  • dart UI层(Foundation 和 Animation、Painting、Gestures):

    • 对应的是Flutter中的dart:ui包,它是 Flutter Engine 暴露的底层UI库,提供动画、手势及绘制能力。
  • 渲染层Rendering:

    • 这一层是一个抽象的布局层,它依赖于 Dart UI 层,渲染层会构建一棵由可渲染对象组成的渲染树,当动态更新这些对象时,渲染树会找出变化的部分,然后调用底层 dart:ui,进行坐标变换、绘制,更新渲染。
  • 组件层Widgets:

    • Flutter 提供的一套基础组件库,在基础组件库之上,Flutter 还提供了 Material 和 Cupertino 两种视觉风格的组件库,它们分别实现了 Material 和 iOS 设计规范。

Flutter 框架相对较小,因为一些开发者可能会使用到的更高层级的功能已经被拆分到不同的软件包中,使用 Dart 和 Flutter 的核心库实现,其中包括平台插件,例如 camera (opens new window)和 webview (opens new window),以及和平台无关的功能,例如 animations (opens new window)。

3-2. 引擎层

引擎层Flutter Engine,这是 Flutter 渲染和计算的核心。该层主要是 C++ 实现,其中包括了 Skia 引擎、Dart 运行时(Dart runtime)、文字排版引擎等。在代码调用 dart:ui库时,调用最终会走到引擎层,然后实现真正的绘制和显示。

3-3. 嵌入层

嵌入层Flutter Embedding,这是 Flutter 实现与平台无关的关键,它提供了 Flutter 与平台交互的接口,包括创建 Flutter 线程、线程间通信、渲染 Surface 等。嵌入层主要是将 Flutter 引擎 ”安装“ 到特定平台上。嵌入层采用了当前平台的语言编写,例如 Android 使用的是 Java 和 C++, iOS 和 macOS 使用的是 Objective-C 和 Objective-C++,Windows 和 Linux 使用的是 C++。Flutter 代码可以通过嵌入层,以模块方式集成到现有的应用中,也可以作为应用的主体。


本次分享就到这儿啦,我是鹏多多,如果您看了觉得有帮助,欢迎评论,关注,点赞,转发,我们下次见~

往期文章

  • Vue2全家桶+Element搭建的PC端在线音乐网站
  • vue3+element-plus配置cdn
  • 助你上手Vue3全家桶之Vue3教程
  • 助你上手Vue3全家桶之VueX4教程
  • 助你上手Vue3全家桶之Vue-Router4教程
  • 超详细!Vue的九种通信方式
  • 超详细!Vuex手把手教程
  • 使用nvm管理node.js版本以及更换npm淘宝镜像源
  • vue中利用.env文件存储全局环境变量,以及配置vue启动和打包命令
  • 超详细!Vue-Router手把手教程

个人主页文章来源地址https://www.toymoban.com/news/detail-756053.html

  • CSDN
  • GitHub
  • 简书
  • 博客园
  • 掘金

到了这里,关于flutter学习-day2-认识flutter的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【cs61b】学习笔记day2

    【cs61b】学习笔记day1 思考下面两个代码分别输出什么 从下图可以看出,a和b指向的同一个实例,而x和y是两个独立的 在计算机中,数字72和大写字母H都是以01001000来存储,那么java是如何区分他们的? 答: 以类型区分 在Java, 有8 八种基本类型: byte, short, int, long, float, double, b

    2024年02月13日
    浏览(26)
  • Vue3 学习笔记(Day2)

    「写在前面」 本文为尚硅谷禹神 Vue3 教程的学习笔记。本着自己学习、分享他人的态度,分享学习笔记,希望能对大家有所帮助。推荐先按顺序阅读往期内容: 1. Vue3 学习笔记(Day1) 目录 3 Vue3 核心语法 3.1 选项式API 与 组合式API 3.2 setup 3.3 ref 和 reactive 3.4 computed 3.5 watch 3.

    2024年02月22日
    浏览(39)
  • 【Node.js学习 day2——预备知识】

    1、概念 Buffer是一个类似于数组的对象,用于表示固定长度的字节序列 Buffer本质是一段内存空间,专门用来处理二进制数据 2、特点 Buffer大小规定且无法调整 Buffer性能较好,可以直接对计算机内存进行操作 每个元素的大小为1字节(byte) 3、使用 创建Buffer(3种方式) 4、 B

    2024年01月25日
    浏览(33)
  • MetaGPT-打卡-day2,MetaGPT框架组件学习

    今天是第二天的打卡~昨天是关于一些概念的大杂烩,今天的话,就来到了Hello World环节。 从单个Agnet到多个Agent,再到组合更复杂的工作流来解决问题。 虽然看过了一些资料,但是还是有些不知道该怎么去理解Agent的概念。从单词本身的翻译来看,很多都是经纪人、代理人的

    2024年01月19日
    浏览(37)
  • Verilog语法-模块module[Day2学习笔记]

    1概述 Verilog HDL是一种用于数字逻辑电路设计的硬件描述语言,可用来进行数字电路的仿真验证、时序分析、逻辑综合。 用Verilog HDL描述的电路设计就是该电路的Verilog HDL模型。 Verilog HDL既是一种 行为 描述语言,也是一种 结构 描述语言。 既可以用电路的功能描述,也可以用

    2024年02月15日
    浏览(28)
  • [github-100天机器学习]day2 simple linear regression

    https://github.com/LiuChuang0059/100days-ML-code/blob/master/Day2_SImple_Linear_regression/README.md 使用单一特征预测响应值。基于自变量X来预测因变量Y的方法,假设两者线性相关,寻找一种根据特征或自变量X的线性函数来预测Y。 目标 找最佳拟合线,最小化预测误差(最小化观测值 Y i Y_i Y i ​

    2024年02月12日
    浏览(34)
  • Unity从0到放弃的学习之路day2——导入PMX模型,下载资源导入

    ​                                                                                          ——倚东风,一笑嫣然,转盼万花羞落。         什么!辛辛苦苦码了许久竟然被吞了!!!!又卑微的重新写了一遍,!这未保存的内容也太多了!放弃放弃!必

    2024年02月07日
    浏览(85)
  • flutter学习-day9-基础组件

    本文学习和引用自《Flutter实战·第二版》:作者:杜文 Text:用于显示简单样式文本,它包含一些控制文本显示样式的一些属性: TextStyle:用于指定文本显示的样式如颜色、字体、粗细、背景等: TextSpan:代表文本的一个片段,可对一个 Text 内容的不同部分按照不同的样式显

    2024年02月04日
    浏览(29)
  • ARM day2、day3 汇编

    @ 注释 # 注释(放在行首表示注释一行) /*    */ 注释 #+数字 立即数 : 一种标号(比如main:        loop:) .text        .end+换行 固定格式 ARM指令构成 ARM 指令包含操作码和一些其他的信息,只剩下8 位存放数据 具体来说,一个 ARM 指令通常由以下部分组成: 操作码(Opcode)

    2024年01月19日
    浏览(36)
  • flutter学习-day22-使用GestureDetector识别手势事件

    在 flutter 中,GestureDetector 是手势识别的组件,可以识别点击、双击、长按、拖动、缩放等手势事件,并且可以与子组件进行交互,构造函数属性如下: GestureDetector 内部封装了 Listener,用以识别语义化的手势。 当同时监听 onTap 和 onDoubleTap 事件时,当用户触发 tap 事件时,会

    2024年02月03日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包