Flutter - 布局原理与约束(constraints)

news2025/1/13 10:49:28

尺寸限制类容器用于限制容器大小,Flutter中提供了多种这样的容器,如ConstrainedBox、SizedBox、UnconstrainedBox、AspectRatio 等

1 ConstrainedBox
ConstrainedBox 用于对子组件添加额外的约束 一般作为最外层的父布局

2 BoxConstraints
BoxConstraints 为ConstrainedBox提供 基础的宽高限制

const BoxConstraints({
  this.minWidth = 0.0, //最小宽度
  this.maxWidth = double.infinity, //最大宽度
  this.minHeight = 0.0, //最小高度
  this.maxHeight = double.infinity //最大高度
})

示例 :
ConstrainedBox(
  constraints: BoxConstraints(
    minWidth: double.infinity, //宽度尽可能大
    minHeight: 46.0 //最小高度为46像素
  ),
  child: Container(
    height: 5.0, // 不起作用 ,以父容器的约束为准
    child: DecoratedBox(
           decoration: BoxDecoration(color: Colors.blue),
    ) ,
  ),
)

在这里插入图片描述

同时 BoxConstraints 也定义有一些便捷的构造方法

1  BoxConstraints.tight(Size(100,100))  // 设置宽高为100 ,100 通过Size 设置

ConstrainedBox(
  constraints: BoxConstraints.tight(Size(60,80)),
  child: DecoratedBox(
    decoration: BoxDecoration(color: Colors.blue),
  ),
),

在这里插入图片描述

2 BoxConstraints.tightFor(width: 80,height: 80)  // 设置最大值 和 最小值 都为80 ,80 

相当于 

BoxConstraints(minHeight: 80.0,maxHeight: 80.0,minWidth: 80.0,maxWidth: 80.0)
//可以生成一个尽可能大的用以填充另一个容器的BoxConstraints
3 BoxConstraints.expand(width: 100.0,height: 100.0), 

示例 :
ConstrainedBox(
  constraints: BoxConstraints.tightFor(width: 50,height: 50),// 最外围的约束是 宽 50  高 50
  child: ConstrainedBox(
      constraints: const BoxConstraints.expand(), // 可以生成一个尽可能大的用以填充另一个容器的BoxConstraints
      child: Container(
        height: 59,  // 不起作用 ,以父容器的约束为准
        width: 102,  // 不起作用 ,以父容器的约束为准
        child: DecoratedBox(
          decoration: BoxDecoration(color: Colors.red),
        ),
      ),
  ),
),

在这里插入图片描述
3 SizedBox
SizedBox 用于给子元素指定固定的宽高

SizedBox(
  width: 80,
  height: 80,
  child: DecoratedBox(
    decoration: BoxDecoration(color: Colors.yellow),
  ),
),

在这里插入图片描述
但SizedBox只是ConstrainedBox的一个简单用法,上面代码等价于:

ConstrainedBox(
  constraints: BoxConstraints.tightFor(width: 80.0,height: 80.0),
  child: DecoratedBox(
    decoration: BoxDecoration(color: Colors.yellow),
  ),
)

等价于


ConstrainedBox(
  constraints: BoxConstraints(minHeight: 80.0,maxHeight: 80.0,minWidth: 80.0,maxWidth: 80.0),
  child: DecoratedBox(
    decoration: BoxDecoration(color: Colors.yellow),
  ),
)

4 多重限制

有多个 父级限制, 会取两个限制值的最大的值

ConstrainedBox(
    constraints: BoxConstraints(minWidth: 60.0, minHeight: 60.0),  //父
    child: ConstrainedBox(
    constraints: BoxConstraints(minWidth: 5.0, minHeight: 80.0),//子
      child: DecoratedBox(
        decoration: BoxDecoration(color: Colors.orange),
      ),
    ),
),

在这里插入图片描述
5 UnconstrainedBox
UnconstrainedBox 取消限制 子布局 可以取消父布局的限制 ,但 父布局仍占用空间

ConstrainedBox(
    constraints: BoxConstraints(minWidth: 90.0, minHeight: 20.0),
    child: ConstrainedBox(//多重布局限制
      constraints: BoxConstraints(minWidth: 60.0, minHeight: 60.0),
      child: DecoratedBox(//多重布局限制
        decoration: BoxDecoration(color: Colors.yellow),
        child: UnconstrainedBox(
          alignment: Alignment.topRight, // UnconstrainedBox 中控制子布局的位置
          child:
          SizedBox( // 取消限制的子布局
            width: 80,
            height: 20,
            child: DecoratedBox(
              decoration: BoxDecoration(color: Colors.red),
            )
          ),
        ),
      ),
    )
),

在这里插入图片描述

6 AspectRatio
AspectRatio 使用时 是根据父空间的宽高比进行设置的 ,如果父布局有具体宽高则 AspectRatio 失效

ConstrainedBox(
    constraints: BoxConstraints(maxWidth: 90), // 创建一个宽度最大为90的约束
    // height: 100,
    child: AspectRatio( // 使用时 是根据父空间的宽高比进行设置的 ,如果父布局有具体宽高则 AspectRatio 失效
      aspectRatio: 3,
      child: Container(
        color: Colors.pink,
      ),
    ),
),

在这里插入图片描述
LimitedBox 用于指定最大宽高
FractionallySizedBox 可以根据父容器宽高的百分比来设置子组件宽高

其他
在这里插入图片描述

import 'package:flutter/material.dart';
import 'package:english_words/english_words.dart';

class MyConstrainedBoxState extends StatefulWidget {
  const MyConstrainedBoxState({Key? key}) : super(key: key);

  
  State<MyConstrainedBoxState> createState() => _MyState();
}

class _MyState extends State<MyConstrainedBoxState> {

  
  Widget build(BuildContext context) {


    return Scaffold(
      appBar: AppBar(
        title: const Text("MyConstrainedBoxState"),
      ),
      body:  Center(
          child: Column(
            mainAxisSize: MainAxisSize.min,
            children: <Widget>[
              ConstrainedBox(
                constraints: BoxConstraints(
                  minWidth: double.infinity,
                  minHeight: 46,
                ),
                child: Container(
                  height: 59,
                  child: DecoratedBox(
                    decoration: BoxDecoration(color: Colors.blue),
                  ),
                ),
              ),
              Text("----------"),
              ConstrainedBox(
                constraints: BoxConstraints.tight(Size(60,80)),
                child: DecoratedBox(
                  decoration: BoxDecoration(color: Colors.blue),
                ),
              ),
              Text("----------"),
              SizedBox(
                width: 90,
                height: 90,
                child: DecoratedBox(
                  decoration: BoxDecoration(color: Colors.yellow),
                ),
              ),
              Text("----------"),
              ConstrainedBox(
                  constraints: BoxConstraints(minWidth: 90.0, minHeight: 20.0),
                  child: ConstrainedBox(
                    constraints: BoxConstraints(minWidth: 60.0, minHeight: 60.0),
                    child: DecoratedBox(
                      decoration: BoxDecoration(color: Colors.yellow),
                      child: UnconstrainedBox(
                        alignment: Alignment.topRight,
                        child:
                        SizedBox(
                          width: 80,
                          height: 20,
                          child: DecoratedBox(
                            decoration: BoxDecoration(color: Colors.red),
                          )
                        ),
                      ),
                    ),
                  )
              ),
              Text("----------"),
              ConstrainedBox(
                  constraints: BoxConstraints(minWidth: 60.0, minHeight: 60.0),  //父
                  child: ConstrainedBox(
                  constraints: BoxConstraints(minWidth: 5.0, minHeight: 80.0),//子
                    child: DecoratedBox(
                      decoration: BoxDecoration(color: Colors.orange),
                    ),
                  ),
              ),
              Text("------------"),
              ConstrainedBox(
                constraints: BoxConstraints.tightFor(width: 60,height: 60),// 最外围的约束是 宽 50  高 50
                child: ConstrainedBox(
                    constraints: const BoxConstraints.expand(), // 可以生成一个尽可能大的用以填充另一个容器的BoxConstraints
                    child: Container(
                      height: 59,  // 不起作用 ,以父容器的约束为准
                      width: 102,  // 不起作用 ,以父容器的约束为准
                      child: DecoratedBox(
                        decoration: BoxDecoration(color: Colors.red),
                      ),
                    ),
                ),
              ),
              Text("------------"),
              ConstrainedBox(
                  constraints: BoxConstraints(maxWidth: 90), // 创建一个宽度最大为90的约束
                  // height: 100,
                  child: AspectRatio( // 使用时 是根据父空间的宽高比进行设置的 ,如果父布局有具体宽高则 AspectRatio 失效
                    aspectRatio: 3,
                    child: Container(
                      color: Colors.pink,
                    ),
                  ),
              ),
            ],
          )
      ),
    );
  }


}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]Python计算机毕业设计SSM基于社区人员管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

阿里P8架构师精心整理:Dubbo+Docker+Kubernetes实战PDf,附面试题

前言 学习是一种基础性的能力。然而&#xff0c;“吾生也有涯&#xff0c;而知也无涯。”&#xff0c;如果学习不注意方法&#xff0c;则会“以有涯随无涯&#xff0c;殆矣”。 学习就像吃饭睡觉一样&#xff0c;是人的一种本能&#xff0c;人人都有学习的能力。我们在刚出生…

Keycloak之17.0.1 版本和Gerrit 整合-yellowcong

通过keycloak 来实现gerrit的用户管理。主要有几个步骤,1.安装gerrit,2.安装gerrit oauth 插件,3.配置gerrit . 4.创建keycloak的配置,添加realm,client,user ,三个,5.重启gerrit 测试。 17版本不一样的是,需要开启oauth,服务器增加前缀。 准备 Keycloak之17.0.1 版本安…

43. Python for 循环

43. Python for 循环 文章目录43. Python for 循环1. 课题导入2. 什么是循环3. 什么是for循环4. for 循环语法5. 可迭代对象6. for循环的执行流程7. for 循环的对象1. 循环对象为字符串2. 循环的对象不能为整数3. 循环的对象不能为浮点数4. 循环对象为布尔类型5. 循环对象为列表…

使用docker构建vue项目并成功运行在本地和线上

先说本地环境 windows10 node vue docker都已经安装齐全 获取nginx镜像 因为要用这个镜像来构建你的vue项目&#xff0c;就像给vue项目提供一个环境一样 docker pull nginx 创建 nginx config配置文件 在项目根目录下创建文件default.conf server {listen 80;s…

火灾报警产品-火灾探测报警产品

消防产品&#xff0c;是指专门用于火灾预防、灭火救援和火灾防护、避难、逃生的产品。适用范围 适用于消防联动控制系统设备、防火卷帘控制器、线型感温火灾探测器、城市消防远程监控产品。认证模式 型式试验初始工厂检查获证后监督。申请资料 1.认证委托人/生产者/生产企业的资…

全面支持 PyTorch 2.0:BladeDISC 5 月~11 月新功能发布

作者&#xff1a;BladeDISC研发团队 BladeDISC 上一次更新主要发布了 GPU AStitch 优化&#xff0c;方法来源于我们发表在 ASPLOS 2022上的论文AStitch。这一次&#xff0c;我们发布了 0.3.0 版本。 本次更新中 BladeDISC 社区全面支持了 PyTorch 2.0 编译&#xff0c;推进了…

同城跑腿系统搭建,灵活的配送选择满足更多场景

为了提供更加便捷的生活服务&#xff0c;同城跑腿系统搭建通过线上的同城跑腿服务平台&#xff0c;在网上用户可以申请同城服务的需求&#xff0c;平台的相关的工作人员快速的响应接单&#xff0c;快速进行同城的配送跑腿服务。 同城跑腿系统搭建&#xff0c;功能少是万万不能…

微信小程序第四篇:生成图片并保存到手机相册

系列文章传送门&#xff1a; 微信小程序第一篇&#xff1a;自定义组件详解 微信小程序第二篇&#xff1a;七种主流通信方法详解 微信小程序第三篇&#xff1a;获取页面节点信息 目录 一、封装分享组件 二、定义用户授权方法 三、调用流程 首先我们看一下要完成的效果&#x…

地理空间开发包 TatukGIS Developer Kernel 11.72.X Crack

TatukGIS Developer Kernel (DK) 是专业级 GIS SDK&#xff08;软件开发工具包&#xff09;&#xff0c;各行各业的客户都使用它来开发自定义 GIS 应用程序或向现有产品添加地理空间功能。DK 可作为多个 SDK 版本使用&#xff0c;每个版本都针对特定的开发平台进行本地编译&…

胡扯系列之私人AI助手系统的分析与设计

背景 随着时代的发展&#xff0c;计算机算力的提升和近些年来AI模型的井喷以及发展。人工智能应用已经深入我们的日常生活。如人脸识别&#xff0c;无人驾驶等等&#xff0c;同时为了更好地与用户进行交互&#xff0c;完成特定功能&#xff0c;智能对话助手应运而生。如今大量…

某宝付费买的价值上万的60G的Python学习资源,0基础轻松赚钱到手软,请低调使用,禁止外传

前言 你是否 还在为升职加薪发愁&#xff1f; 苦于领导看不到自己更多长处&#xff1f; 还在为房贷&#xff0c;车贷&#xff0c;生计而发愁&#xff1f; 苦于不上班如何轻松赚快钱补贴家用&#xff1f; 为了帮助财务、设计、运营、策划、销售、HR、金融从业者、电商从业…

【单目3D目标检测】MonoFlex论文精读与代码解析

文章目录PrefaceAbstractContributionsPipelineProblem DefinitionDecoupled Representations of ObjectsInside & Outside ObjectsEdge FusionLossVisual Properties Regression2D DetectionDimension EstimationOrientation EstimationKeypoint EstimationAdaptive Depth…

Docker网络模式与配置

目录 &#x1f388;&#x1f388;1. Docker网络模式&#x1f3c3;‍♂️&#x1f3c3;‍♂️ &#x1f3c3;‍♂️&#x1f3c3;‍♂️2. 外部访问docker容器&#x1f3c3;‍♂️&#x1f3c3;‍♂️ &#x1f388;&#x1f388;3. 创建自定义网络&#xff1a;&#xff08;设…

尚医通 (三十一) --------- 手机登录

目录一、登录需求1. 登录效果2. 登录需求二、登录1. 搭建 service-user 模块2. 添加用户基础类3. 登录 API 接口4. 生成 token5. 阿里云短信6. 登录前端7. 登录全局事件8. myheader.vue 完整代码三、用户认证与网关整合一、登录需求 1. 登录效果 2. 登录需求 ① 登录采取弹出…

Python爬虫实战,requests+time模块,爬取某招聘网站数据并保存csv文件(附源码)

前言 今天给大家介绍的是Python爬取某招聘网站数据并保存本地&#xff0c;在这里给需要的小伙伴们代码&#xff0c;并且给出一点小心得。 首先是爬取之前应该尽可能伪装成浏览器而不被识别出来是爬虫&#xff0c;基本的是加请求头&#xff0c;但是这样的纯文 本数据爬取的人会…

ImmunoChemistry丨艾美捷抗体夹心ELISA开发试剂盒说明书

使用ImmunoChemistry艾美捷抗体夹心ELISA开发试剂盒评估检测可行性并优化ELISA性能参数。抗体夹心ELISA开发试剂盒提供了八种特殊配制的ELISA溶液和一个模板&#xff0c;用于抗体夹心ELISA测试的初始开发和优化。全面的ELISA开发手册提供了评估初始检测可行性和优化ELISA性能参…

关于 npm run buildprod 报错问题 :文件名、目录名或卷标语法不正确

引言 vue开发基本完成后进行打包时出现错误&#xff0c;这个错误以前没有遇到过&#xff0c;所以在这里激励 参考文章1 参考文章2 问题描述 在idea中运行npm run build:prod打包vue时出现报错 E:\Allworkspaces\idea-workspace\Project\vue-project\my-blog\vue-admin-te…

代码随想录第三天

专题&#xff1a;链表 题目&#xff1a;移除链表元素 题意&#xff1a;删除链表中等于给定值 val 的所有节点。 示例 &#xff1a; 输入&#xff1a;head [1,2,6,3,4,5,6], val 6 输出&#xff1a;[1,2,3,4,5] 解题思想&#xff1a; 我们为了统一操作&#xff0c;我们给链表…

身份证实名认证API接口有什么意义与作用?

身份证实名认证API接口有什么意义&#xff1f; 中国公民的身份证是一种对外证明自己身份的有效证件&#xff0c;随着国家对实名制要求的落实&#xff0c;工作与生活中许多场景都会需要进行身份验证。比如出门外出乘座火车与飞机时、注册互联网络平台时、网络游戏与购物时等等&a…