Flutter   发布时间:2022-05-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了【Flutter实战】定位装饰权重组件及柱状图案例大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

【Flutter实战】定位装饰权重组件及柱状图案例

Container

Container 是最常用的组件之一,它是单容器类组件,即仅能包含一个子组件,用于装饰和定位子组件,例如设置背景颜色、形状等。

最简单的用法如下:

Container(
	child: Text('老孟'),)

子组件不会发生任何外观上的变化:

【Flutter实战】定位装饰权重组件及柱状图案例

设置背景颜色:

Container(
	color: Colors.blue,child: Text('老孟'),)

【Flutter实战】定位装饰权重组件及柱状图案例

设置内边距( padding ) 和 外边距( @H_407_10@margin )

Container(
      color: Colors.blue,child: Container(
        margin: EdgeInsets.all(10),padding: EdgeInsets.all(20),color: Colors.red,),)

效果如下:

【Flutter实战】定位装饰权重组件及柱状图案例

decoration 属性设置子组件的背景颜色、形状等。设置背景为圆形,颜色为蓝色:

Container(
  child: Text('老孟,专注分享Flutter技术及应用'),decoration: BoxDecoration(shape: BoxShape.circle,color: Colors.bluE),)

【Flutter实战】定位装饰权重组件及柱状图案例

认情况下,圆形的直径等于 Container 窄边长度,相当于在矩形内绘制内切圆。

上面的情况明显不是我们希望看到了,希望背景是圆角矩形:

Container(
        child: Text('老孟,专注分享Flutter技术及应用'),padding: EdgeInsets.symmetric(horizontal: 10),decoration: BoxDecoration(
            shape: BoxShape.rectangle,borderRadius: BorderRadius.all(Radius.circular(20)),)

【Flutter实战】定位装饰权重组件及柱状图案例

除了背景我们可以设置边框效果代码如下:

Container(
        child: Text('老孟,专注分享Flutter技术及应用'),decoration: BoxDecoration(
          borderRadius: BorderRadius.circular(12),border: Border.all(
            color: Colors.blue,width: 2,)

【Flutter实战】定位装饰权重组件及柱状图案例

创建圆角图片和圆形图片

Container(
      height: 200,width: 200,decoration: BoxDecoration(
        image:  DecorationImage(
          image: NetworkImage(
              'https://Flutter.github.io/assets-for-api-docs/assets/widgets/owl-2.jpg'),fit: BoxFit.cover,border: Border.all(
          color: Colors.blue,borderRadius: BorderRadius.circular(12),)

【Flutter实战】定位装饰权重组件及柱状图案例


修改其形状为圆形,代码如下:

Container(
      height: 200,decoration: BoxDecoration(
        image: DecorationImage(
          image: NetworkImage(
              'https://Flutter.github.io/assets-for-api-docs/assets/widgets/owl-2.jpg'),shape: BoxShape.circle,)

【Flutter实战】定位装饰权重组件及柱状图案例

设置对齐方式为居中,背景色为蓝色,代码如下:

Container(
        color: Colors.blue,child: Text('老孟,一个有态度的程序员'),alignment: Alignment.center,)

【Flutter实战】定位装饰权重组件及柱状图案例

Alignment 已经封装了常用的位置,

【Flutter实战】定位装饰权重组件及柱状图案例

通过名字就知道其位置,这里要介绍一下其他的位置,比如在距离左上角1/4处:

Container(
  alignment: Alignment(-.5,-.5),child: Text('老孟,专注分享Flutter技术及应用'),)

所以这里有一个非常重要的坐标系,Alignment 坐标系如下:

【Flutter实战】定位装饰权重组件及柱状图案例

组件的中心为坐标原点。

设置固定的宽高属性

Container(
        color: Colors.blue,height: 60,width: 250,)

【Flutter实战】定位装饰权重组件及柱状图案例

通过 consTraints 属性设置最大/小宽、高来确定大小,如果不设置,认最小宽高是0,最大宽高是无限大(double.infinity),约束width代码如下:

Container(
        color: Colors.blue,consTraints: BoxConsTraints(
          maxHeight: 100,maxWidth: 300,minHeight: 100,minWidth: 100,)

【Flutter实战】定位装饰权重组件及柱状图案例

通过transform可以旋转、平移、缩放Container,旋转代码如下:

Container(
        color: Colors.blue,transform: Matrix4.rotationZ(0.5),)

【Flutter实战】定位装饰权重组件及柱状图案例

SizedBox

SizedBox 是具有固定宽高的组件,直接指定具体的宽高,用法如下:

SizedBox(
        height: 60,child: Container(
          color: Colors.blue,)

【Flutter实战】定位装饰权重组件及柱状图案例

设置尺寸无限大,如下:

SizedBox(
  height: double.infinity,width: double.infinity,...
)

然设置了无限大,子控件是否会无限长呢?不,不会,子控件依然会受到父组件的约束,会扩展到父组件的尺寸,还有一个便捷的方式设置此方式:

SizedBox.expand(
  child: Text('老孟,专注分享Flutter技术及应用'),)

SizedBox 可以没有子组件,但仍然会占用空间,所以 SizedBox 非常适合控制2个组件之间的空隙,用法如下:

column(
          children: <Widget>[
            Container(height: 30,color: Colors.blue,SizedBox(height: 30,Container(height: 30,],)

【Flutter实战】定位装饰权重组件及柱状图案例

AspectRatio

AspectRatio 是固定宽高比的组件,用法如下:

Container(
        height: 300,width: 300,child: AspectRatio(
          aspectRatio: 2 / 1,child: Container(color: Colors.red,)

aspectRatio 是宽高比,可以直接写成分数的形式,也可以写成小数的形式,但建议写成分数的形式,可读性更高。效果如下:

【Flutter实战】定位装饰权重组件及柱状图案例

FractionallySizedBox

FractionallySizedBox一个相对父组件尺寸的组件,比如占父组件的70%:

Container(
  height: 200,child: FractionallySizedBox(
    widthFactor: .8,heightFactor: .3,child: Container(
      color: Colors.red,)

【Flutter实战】定位装饰权重组件及柱状图案例

通过 alignment 参数控制子组件显示的位置,认为居中,用法如下:

FractionallySizedBox(
  alignment: Alignment.center,...
)

权重组件

ExpandedFlexibleSpacer 都是具有权重属性的组件,可以控制 Row、column、Flex 的子控件如何布局的组件。

Flexible 组件可以控制 Row、column、Flex 的子控件占满父组件,比如,Row 中有3个子组件,两边的宽是100,中间的占满剩余的空间,代码如下:

Row(
      children: <Widget>[
        Container(
          color: Colors.blue,height: 50,width: 100,Flexible(
            child: Container(
              color: Colors.red,)
        ),Container(
          color: Colors.blue,)

【Flutter实战】定位装饰权重组件及柱状图案例

还是有3个子组件,第一个占1/6,第二个占2/6,第三个占3/6,代码如下:

column(
      children: <Widget>[
        Flexible(
          flex: 1,child: Container(
            color: Colors.blue,child: Text('1 Flex/ 6 @R_161_10586@l',style: TextStyle(color: Colors.whitE),Flexible(
          flex: 2,child: Container(
            color: Colors.red,child: Text('2 Flex/ 6 @R_161_10586@l',Flexible(
          flex: 3,child: Container(
            color: Colors.green,child: Text('3 Flex/ 6 @R_161_10586@l',)

【Flutter实战】定位装饰权重组件及柱状图案例

子组件占比 = 当前子控件 flex / 所有子组件 flex 之和。

Flexible中 fit 参数表示填满剩余空间的方式,说明如下:

  • tight:必须(强制)填满剩余空间。
  • loose:尽可能大的填满剩余空间,但是可以不填满。

这2个看上去不是很好理解啊,什么叫尽可能大的填满剩余空间?什么时候填满?看下面的例子:

Row(
      children: <Widget>[
        Container(
          color: Colors.blue,child: Text('Container',)

【Flutter实战】定位装饰权重组件及柱状图案例

这段代码是在最上面代码的基础上给中间的红色Container添加了Text子控件,此时红色Container就不在充满空间,再给Container添加对齐方式,代码如下:

Row(
      children: <Widget>[
        Container(
          color: Colors.blue,)

【Flutter实战】定位装饰权重组件及柱状图案例


此时又填满剩余空间。

大家是否还记得 Container 组件的大小是如何调整的吗?Container 认是适配子控件大小的,但当设置对齐方式时 Container 将会填满父组件,因此是否填满剩余空间取决于子组件是否需要填满父组件。

如果把 Flexible 中子组件由 Container 改为 OutlineButton,代码如下:

Row(
      children: <Widget>[
        Container(
          color: Colors.blue,Flexible(
          child: OutlineButton(
            child: Text('OutlineButton'),)

OutlineButton 正常情况下是不充满父组件的,因此最终的效果应该是不填满剩余空间:

【Flutter实战】定位装饰权重组件及柱状图案例

下面再来介绍另一个权重组件 Expanded ,源代码如下:

class Expanded extends Flexible {
  /// Creates a widget that expands a child of a [Row],[column],or [Flex]
  /// so that the child fills the available space along the flex widget's
  /// main axis.
  const Expanded({
    Key key,int flex = 1,@required Widget child,}) : super(key: key,flex: flex,fit: FlexFit.tight,child: child);
}

Expanded 继承字 Flexible,fit 参数固定为 FlexFit.tight,也就是说 Expanded 必须(强制)填满剩余空间。上面的 OutlineButton 想要充满剩余空间可以直接使用 Expanded :

Row(
      children: <Widget>[
        Container(
          color: Colors.blue,Expanded(
          child: OutlineButton(
            child: Text('OutlineButton'),)

【Flutter实战】定位装饰权重组件及柱状图案例

Spacer 也是一个权重组件,源代码如下:

@override
Widget build(BuildContext context) {
  return Expanded(
    flex: flex,child: const SizedBox.shrink(),);
}

Spacer 的本质也是 Expanded 的实现的,和Expanded的区别是:Expanded 可以设置子控件,而 Spacer 的子控件尺寸是0,因此Spacer适用于撑开 Row、column、Flex 的子控件的空隙,用法如下:

Row(
  children: <Widget>[
    Container(width: 100,color: Colors.green,Spacer(flex: 2,Container(width: 100,Spacer(),)

【Flutter实战】定位装饰权重组件及柱状图案例

三个权重组建总结如下

  • Spacer 是通过 Expanded 实现的,Expanded继承自Flexible。
  • 填满剩余空间直接使用Expanded更方便
  • Spacer 用于撑开 Row、column、Flex 的子组件的空隙。

仿 掘金-我 效果

先看下效果

@H_912_450@

拿到效果图先不要慌 (取出手机拍照发个朋友圈

大佬总结

以上是大佬教程为你收集整理的【Flutter实战】定位装饰权重组件及柱状图案例全部内容,希望文章能够帮你解决【Flutter实战】定位装饰权重组件及柱状图案例所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: