Flutter组件--Padding和AnimatedPadding
创始人
2024-04-11 06:04:16

示意图:

Padding介绍

在应用程序中有许多widget 时,这个时候画面常常会变得很拥挤,这个时候如果想要在widget之间来保留一些间距,那就用 Padding

为什么使用 Padding 而不使用 Container.padding 属性的 Container?

Container 是将许多更简单的 widget 组合在一个方便的包中,如果只需要设置 padding ,那我们最好使用 Padding 而不是 Container


Padding属性和说明

序列号字段属性描述
1paddingEdgeInsetsGeometry给子widget的间距
2childWidget子widget

Padding属性详细使用

1、padding 、child

padding 给子widget的间距

child 接收一个子 Widget

import 'package:flutter/material.dart';class PaddingExample extends StatefulWidget {@override_PaddingExampleState createState() => _PaddingExampleState();
}class _PaddingExampleState extends State {@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("Padding example"),),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Padding(padding: EdgeInsets.all(0),child: Container(width: 100,height: 100,color: Colors.red,),),Padding(padding: EdgeInsets.all(0),child: Container(width: 100,height: 100,color: Colors.green,),),Padding(padding: EdgeInsets.all(0),child: Container(width: 100,height: 100,color: Colors.orange,),)],),),);}
}

 

EdgeInsetsGeometry详解

EdgeInsetsGeometry 是一个描述边距的组件,一般都是使用它的子类 EdgeInsets 来进行设置。

1、fromLTRB

设置左、上、右、下的边距,可设定不同的值

Padding(padding: EdgeInsets.fromLTRB(10, 20, 30, 40),child: Container(width: 100,height: 100,color: Colors.red,),
),

 2、all

同时设置所有的边距为同一个值

Padding(padding: EdgeInsets.all(10),child: Container(width: 100,height: 100,color: Colors.green,),
)

 3、only

根据需要设置某一个边的间距

Padding(padding: EdgeInsets.only(left: 10,right: 10),child: Container(width: 100,height: 100,color: Colors.orange,),
)

 4、symmetric

设置水平(上下)、或者垂直(左右)的间距

Padding(padding: EdgeInsets.symmetric(vertical: 10,horizontal: 10),child: Container(width: 100,height: 100,color: Colors.orange,),
)

 完整代码

import 'package:flutter/material.dart';class PaddingExample extends StatefulWidget {@override_PaddingExampleState createState() => _PaddingExampleState();
}class _PaddingExampleState extends State {@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("Padding example"),),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Padding(padding: EdgeInsets.fromLTRB(10, 20, 30, 40),child: Container(width: 100,height: 100,color: Colors.red,),),Padding(padding: EdgeInsets.all(10),child: Container(width: 100,height: 100,color: Colors.green,),),Padding(padding: EdgeInsets.only(left: 10,right: 10),child: Container(width: 100,height: 100,color: Colors.orange,),),Padding(padding: EdgeInsets.symmetric(vertical: 10,horizontal: 10),child: Container(width: 100,height: 100,color: Colors.orange,),)],),),);}
}

AnimatedPadding介绍

AnimatedPadding构造函数

AnimatedPadding({Key? key,required this.padding, // 边距this.child,  // 子WidgetCurve curve = Curves.linear,  // 动画的运动速率required Duration duration,  // 动画的持续时间VoidCallback? onEnd,   // 动画结束时的回调}) : assert(padding != null),assert(padding.isNonNegative),super(key: key, curve: curve, duration: duration, onEnd: onEnd);

AnimatedPadding完整示例代码

import 'package:flutter/material.dart';class AnimatedPaddingExample extends StatefulWidget {@override_AnimatedPaddingExampleState createState() => _AnimatedPaddingExampleState();
}class _AnimatedPaddingExampleState extends State {double paddingAllValue = 0.0;@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("AnimatedPaddingExample"),),body: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Text('Padding: $paddingAllValue'),AnimatedPadding(padding: EdgeInsets.all(paddingAllValue),duration: Duration(milliseconds: 1000),curve: Curves.easeInOut,child: Container(width: MediaQuery.of(context).size.width,height: MediaQuery.of(context).size.height / 4,color: Colors.blue,),onEnd: () {print("动画结束时的回调");},),ElevatedButton(child: Text('改变padding的值'),onPressed: () {setState(() {paddingAllValue = paddingAllValue == 0.0 ? 50.0 : 0.0;});}),],),);}
}

相关内容

热门资讯

埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...