Flutter鸿蒙next 布局架构原理详解

✅近期推荐:求职神器

https://bbs.csdn.net/topics/619384540


🔥欢迎大家订阅系列专栏:flutter_鸿蒙next
💬淼学派语录:只有不断的否认自己和肯定自己,才能走出弯曲不平的泥泞路,因为平坦的大路,太tm无趣了!

目录

写在前面

一、Flutter 布局的基本概念

二、主要布局 Widget 详解

1. Row 布局

使用示例

关键属性

布局原理

2. Column 布局

使用示例

关键属性

布局原理

3. Stack 布局

使用示例

关键属性

布局原理

4. Container

使用示例

关键属性

布局原理

5. ListView 和 GridView

ListView 示例

GridView 示例

布局原理

三、布局优化技巧

写在最后


写在前面

在 Flutter 中,布局是构建用户界面的核心部分。Flutter 提供了丰富的布局组件,能够灵活地组合和排列 Widget,创建出多种多样的界面效果。本文将详细介绍 Flutter 中的主要布局方式,包括 RowColumnStack 和其他布局 Widget 的架构原理及使用场景。

一、Flutter 布局的基本概念

在深入布局 Widget 之前,了解 Flutter 布局的基本概念非常重要。

  • Widget:Flutter 的基本构件,所有 UI 元素都是 Widget,分为无状态 Widget(Stateless)和有状态 Widget(Stateful)。
  • 约束 (Constraints):Flutter 的布局是基于约束的,父 Widget 将约束传递给子 Widget,决定子 Widget 的大小和位置。
  • 布局过程:布局过程分为两个阶段:布局阶段和绘制阶段。在布局阶段,Widget 根据约束计算自己的大小;在绘制阶段,Widget 被绘制到屏幕上。

二、主要布局 Widget 详解

1. Row 布局

Row 是 Flutter 中用于水平排列子 Widget 的布局组件。它允许将多个 Widget 水平放置,并支持各种对齐和间距设置。

使用示例
Row(
  mainAxisAlignment: MainAxisAlignment.spaceAround,
  children: [
    Icon(Icons.star),
    Text('Star'),
    Icon(Icons.star),
  ],
)
关键属性
  • mainAxisAlignment:主轴对齐方式,如 MainAxisAlignment.startMainAxisAlignment.centerMainAxisAlignment.spaceBetween 等。
  • crossAxisAlignment:交叉轴对齐方式,如 CrossAxisAlignment.startCrossAxisAlignment.center 等。
  • children:子 Widget 列表。
布局原理

在布局过程中,Row 接收来自父 Widget 的约束,并将其分发给每个子 Widget。根据设定的对齐方式,Row 会自动计算每个子 Widget 的位置。

2. Column 布局

Column 用于垂直排列子 Widget,工作原理与 Row 类似,但方向不同。

使用示例
Column(
  mainAxisAlignment: MainAxisAlignment.center,
  children: [
    Text('Hello'),
    Text('World'),
  ],
)
关键属性
  • mainAxisAlignment:主轴对齐方式,类似于 Row
  • crossAxisAlignment:交叉轴对齐方式,控制子 Widget 的水平对齐。
  • children:子 Widget 列表。
布局原理

Column 将父 Widget 的约束传递给每个子 Widget,并根据主轴和交叉轴的对齐属性计算它们的大小和位置。

3. Stack 布局

Stack 允许多个 Widget 重叠显示,适合用于需要图层叠加的场景,比如图片上叠加文字或图标。

使用示例
Stack(
  alignment: Alignment.center,
  children: [
    Image.network('https://example.com/image.png'),
    Text('Overlay Text', style: TextStyle(color: Colors.white)),
  ],
)
关键属性
  • alignment:决定子 Widget 的对齐方式。
  • children:子 Widget 列表。
布局原理

Stack 不会对子 Widget 的大小施加约束,所有子 Widget 都会被放置在同一位置上。可以使用 Positioned Widget 来设置子 Widget 的具体位置。

4. Container

Container 是一个功能强大的 Widget,常用于控制大小、边距、填充、背景和边框等。

使用示例
Container(
  width: 100,
  height: 100,
  padding: EdgeInsets.all(8.0),
  decoration: BoxDecoration(
    color: Colors.blue,
    borderRadius: BorderRadius.circular(8.0),
  ),
  child: Center(child: Text('Container')),
)
关键属性
  • width 和 height:设置容器的宽高。
  • padding:内边距。
  • margin:外边距。
  • decoration:用于设置背景、边框等样式。
布局原理

Container 会根据父 Widget 的约束计算自己的大小。它会优先使用传入的宽高参数,然后根据子 Widget 的大小进行调整。

5. ListView 和 GridView

这两个组件用于创建可滚动的列表和网格布局。

ListView 示例
ListView(
  children: [
    ListTile(title: Text('Item 1')),
    ListTile(title: Text('Item 2')),
  ],
)
GridView 示例
GridView.count(
  crossAxisCount: 2,
  children: [
    Container(color: Colors.red, height: 100),
    Container(color: Colors.green, height: 100),
  ],
)
布局原理
  • ListView:通过懒加载机制,只渲染当前可见的部分,提升性能。
  • GridView:根据列数 (crossAxisCount) 将 Widget 布局成网格。

三、布局优化技巧

在 Flutter 中,优化布局可以显著提高应用的性能,以下是一些常用的布局优化技巧:

  1. 使用 const 构造函数:如果 Widget 不会变化,可以使用 const 构造函数来减少重建的开销。
  2. 避免过度嵌套:复杂的 Widget 树会影响性能,尽量减少 Widget 的层级。
  3. 使用 LayoutBuilder:根据父 Widget 的约束动态构建子 Widget,避免不必要的重绘。

写在最后

Flutter 的布局架构灵活而强大,通过组合使用各种布局 Widget,可以轻松构建出复杂的用户界面。了解各个布局 Widget 的原理及其适用场景,将帮助开发者在构建 Flutter 应用时更加高效和灵活。希望这篇博客能为你在 Flutter 布局方面的学习提供帮助!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/901419.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【计网】从零开始认识IP协议 --- 认识网络层,认识IP报头结构

从零开始认识IP协议 1 网络层协议1.1 初步认识IP协议1.2 初步理解IP地址 2 IP协议报头3 初步理解网段划分 1 网络层协议 1.1 初步认识IP协议 我们已经熟悉了传输层中的UDP和TCP协议,接下来我们来接触网络层的协议: 网络层在计算机网络中的意义主要体现…

线段树

文章目录 1 线段树概念2 线段树操作2.1 建树2.2 区间修改2.3 区间查询2.4 练习题目 3 线段树进阶3.1 乘法线段树 * 补充:快读快写4 End 1 线段树概念 线段树 ( S e g m e n t T r e e ) (Segment\ Tree) (Segment Tree) 是 O I OI OI 中的常用算法。线段树是一种…

PHP-FPM 性能配置优化

4 核 8 G 服务器大约可以开启 500 个 PHP-FPM,极限吞吐量在 580 qps (Query Per Second 每秒查询数)左右。 Nginx php-fpm 是怎么工作的? php-fpm 全称是 PHP FastCGI Process Manager 的简称,从名字可得知&#xff…

基于SSM的冰淇淋在线购买网站【附源码】

基于SSM的冰淇淋在线购买网站 效果如下: 系统首页界面 用户登录界面 冰淇淋页面 每日秒杀页面 个人中心界面 管理员登录界面 管理员功能界面 口味管理界面 冰淇淋管理界面 每日秒杀管理界面 视频教学管理界面 研究背景 近些年,随着中国经济发展&#…

订购 Claude AI 的第二天 它独自完成 文字转语音 flask应用

图二里,删除几个无关的 chats 全程我做的工作:向 AI 提要求,copy / paste 代码,在venv验证运行,向 AI 反馈,总共用了3个 chats.(图中的只有一个 Chat, 删掉的另外两个: Python 库安…

海外云手机实现高效的海外社交媒体营销

随着全球化的深入发展,越来越多的中国企业走向国际市场,尤其是B2B外贸企业,海外社交媒体营销已成为其扩大市场的重要手段。在复杂多变的海外市场环境中,如何有效提高营销效率并降低运营风险,成为了众多企业的首要任务。…

计算机网络(十二) —— 高级IO

#1024程序员节 | 征文# 目录 一,预备 1.1 重新理解IO 1.2 五种IO模型 1.3 非阻塞IO 二,select 2.1 关于select 2.2 select接口参数解释 2.3 timeval结构体和fd_set类型 2.4 socket就绪条件 2.5 select基本工作流程 2.6 简单select的服务器代…

【mysql进阶】4-8 临时表空间

临时表空间 - Temporary Tablespaces 1 什么是临时表? ✅ 解答问题 临时表存储的是临时数据,不能永久的存储数据,⼀般在复杂的查询或计算过程中⽤来存储过渡的中间结果,MySQL在执⾏查询与计算的过程中会⾃动⽣成临时表&#xff0c…

C++ 抛异常

目录 一.抛异常与运行崩溃的区别 1.运行崩溃 2.抛异常 二.抛异常机制存在的意义 1.清晰的处理错误 2.结构化的错误管理 3.跨函数传递错误信息 4.异常对象多态性 三.抛异常的使用方法 1.抛出异常 (throw) 2.捕获异常 (catch) 3.标准异常类 四.抛异常的处理机制 1.抛…

2024“源鲁杯“高校网络安全技能大赛-Misc-WP

Round 1 hide_png 题目给了一张图片,flag就在图片上,不过不太明显,写个python脚本处理一下 from PIL import Image ​ # 打开图像并转换为RGB模式 img Image.open("./attachments.png").convert("RGB") ​ # 获取图像…

rabbitmq 使用注意事项

1,注意开启的端口号,一共四个端口号,1883是mqtt连接的端口号,如果没开,是连接不上的需要手动起mqtt插件。 //开始mqtt插件服务 rabbitmq-plugins enable rabbitmq_mqtt 2,15672端口是http网页登录的管理后…

Next Stack技术联盟成立:打造新一代基础软件技术栈

北京,2024 年 10 月 —— 在全球数字化浪潮的推动下,中国基础软件产业迎来了前所未有的创新机遇与挑战。为应对这一时代任务并推动中国基础软件的全球化进程,观测云携手多家领先技术企业正式宣布成立 Next Stack 技术联盟。这一联盟旨在汇聚国…

接口测试(五)jmeter——get请求

一、get请求——短信验证码(示例仅供参考) 1. get请求:传参数据直接拼接在地址后面,jmeter不需要设置请求头content-type 注:短信验证码接口,返回结果中不会返回短信验证码,是存在数据库表中&a…

Maven项目管理工具-初始+环境配置

1. Maven的概念 1.1. 什么是Maven Maven是跨平台的项目管理工具。主要服务于基于Java平台的项目构建,依赖管理和项目信息管理。 理想的项目构建:高度自动化,跨平台,可重用的组件,标准化的流程 maven能够自动下载依…

Mybatis-plus-入门

Mybatis-plus-入门 1&#xff1a;介绍 mybatis-plus的官网&#xff1a;MyBatis-Plus &#x1f680; 为简化开发而生 2: 快速入门 步骤&#xff1a; 1&#xff1a;引入依赖&#xff1a; <dependency><groupId>com.baomidou</groupId><artifactId>my…

STM32使用硬件I2C读写AT24C02 EEPROM(一)

文章目录 一、软件准备配置I2C接口&#xff1a;生成工程代码&#xff1a; 二、编写驱动程序初始化I2C接口&#xff1a;编写读写函数&#xff1a; 三、调试与测试 前面讲到使用软件模拟i2c读写AT24C02&#xff0c;这篇文章使用stm32 提供的硬件i2c读写&#xff0c;看看怎么回事 …

gin入门教程(3):创建第一个 HTTP 服务器

首先设置golang github代理&#xff0c;可解决拉取git包的时候&#xff0c;无法拉取的问题&#xff1a; export GOPROXYhttps://goproxy.io再查看自己的go版本&#xff1a; go version我这里的版本是&#xff1a;go1.23.2 linux/arm64 准备工作做好之后就可以进行开发了 3.…

【AscendC算子开发】笔记1 算子开发哲学

重看这门课&#xff0c;有很多内容的认识更深了&#xff0c;做一些记录。 为什么不能将网络节点融合 这个问题关联到另一个问题&#xff1a;为什么我们需要激活函数&#xff1f; 使用线性的神经元堆叠得到的方程最后也是线性方程&#xff0c;无法表征非线性的信息&#xff0c…

软考(网工)——网络安全

文章目录 &#x1f550;网络安全基础1️⃣网络安全威胁类型2️⃣网络攻击类型 &#x1f551;现代加密技术1️⃣私钥密码/对称密码体制2️⃣对称加密算法总结3️⃣公钥密码/非对称密码4️⃣混合密码5️⃣国产加密算法 - SM 系列6️⃣认证7️⃣基于公钥的认证 &#x1f552;Hash …

Node.js:深入探秘 CommonJS 模块化的奥秘

在Node.js出现之前&#xff0c;服务端JavaScript基本上处于一片荒芜的境况&#xff0c;而当时也没有出现ES6的模块化规范。因此&#xff0c;Node.js采用了当时比较先进的一种模块化规范来实现服务端JavaScript的模块化机制&#xff0c;它就是CommonJS&#xff0c;有时也简称为C…