Flutter系列(三)-整体架构(1)

您好,欢迎关注我的专栏,本篇是关于 Flutter 系列的第三篇,从简单的 Flutter 介绍开始,一步步带你了解进入 Flutter 的世界。你最好有一定的移动开发经验,如果没有也不要担心,在我的专栏底部给我留言,我会尽我的能力给你解答。

上篇文章我们介绍了用 Flutter 开发第一个跨平台应用程序,相信大家一定印象深刻,本篇文章介绍 Flutter 平台的整体架构。

##一.核心原则
之前专栏有提到过,Flutter 的SDK中包括一个现代的响应式框架、一个2D渲染引擎、现成的widget和开发工具。这些组件可以帮助您快速地设计、构建、测试和调试应用程序。
####一切皆 Widget
在Flutter中,所有的界面元素全部是Widget,不管是View也好,容器也好,窗体也好,还是布局也好,全部都是Wiget!
####组合大于继承
还是那句话,在Flutter中,所有的界面元素全部是Widget。无论多复杂的Widget都是由无数个子Widget构成。你可以任意搭配Widget从而组装成强大的Widget。
####分层的框架
Flutter框架是一个分层的结构,每个层都建立在前一层之上。

##二.整体架构
###引擎层
Flutter引擎层由Skia/Dart/Text三个部分构成,这一块使用C++开发。
Skia
skia是个2D向量图形处理函数库,包含字型、坐标转换,以及点阵图都有高效能且简洁的表现。不仅用于Google Chrome浏览器,新兴的Android开放手机平台也采用skia作为绘图处理,搭配OpenGL/ES与特定的硬件特征,强化显示的效果。

Dart
引擎层的Dart包括Dart运行时环境和垃圾回收(GC),以及JIT(Just In Time)。

Text
文本渲染,采用libtxt库实现文本的渲染。

###框架层
Flutter框架层由Dart实现,简单的分为四个部分,从下至上分别是dart:ui层/Rendering层/Widgets层和Material(Cupertino)层。

dart:ui
提供Flutter框架和引擎层之间的接口。

Rendering
渲染/动画/手势处理

Widgets
文本/图片/按钮的基础控件

Material/Cupertino

系统预制的Android/iOS风格控件。

这些层级为构建应用提供了很多种选择。使用自定义的方式构建应用可以使用框架的所有功能,或者使用 Widget 层的控件可以实现 UI 效果。 可以直接使用 Flutter 提供的 Widget 也可以自定义各种 Widget。如果上层实现不满足你的要求,你可以直接使用更底层的功能来自定义。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值