首页 > 其他分享 >flutter系列之:flutter中的变形金刚Transform

flutter系列之:flutter中的变形金刚Transform

时间:2022-12-05 21:13:47浏览次数:61  
标签:origin scale transform Transform 变形金刚 key child flutter

目录

简介

虽然我们在开发APP的过程中是以功能为主,但是有时候为了美观或者其他的特殊的需求,需要对组件进行一些变换。在Flutter中这种变换就叫做Transform。

flutter的强大之处在于,可以对所有的widget进行Transform,因此可以做出非常酷炫的效果。

Transform简介

在Flutter中,Transform本身也是一个Widget,它主要是把变换作用在它的子widget上。我们先来看下Transform的定义和构造函数:

class Transform extends SingleChildRenderObjectWidget

  const Transform({
    Key? key,
    required this.transform,
    this.origin,
    this.alignment,
    this.transformHitTests = true,
    this.filterQuality,
    Widget? child,
  }) : assert(transform != null),
       super(key: key, child: child);

可以看到Transform需要transform,origin,alignment,transformHitTests和filterQuality这几个属性。

其中transform是一个Matrix4对象,它是一个4维的矩阵,用来描述child应该怎么被transform。

origin是一个Offset对象,表示的是原始坐标系的值,默认是左上角。origin和transform是有关联关系的,我们可以通过修改origin来达到不同的transform的效果。

alignment是origin的对其方式,是一个AlignmentGeometry对象。

filterQuality是在进行图像变换的过程中,图像的取样质量。

除了上面这个默认的构造函数之外,为了简单起见Transform还提供了几个有特殊作用的构造函数:

  Transform.rotate({
    Key? key,
    required double angle,
    this.origin,
    this.alignment = Alignment.center,
    this.transformHitTests = true,
    this.filterQuality,
    Widget? child,
  }) : transform = Matrix4.rotationZ(angle),
       super(key: key, child: child);

Transform.rotate就是对子child进行旋转变换。

通过传入angle属性,实现子child沿Z轴旋转。

  Transform.translate({
    Key? key,
    required Offset offset,
    this.transformHitTests = true,
    this.filterQuality,
    Widget? child,
  }) : transform = Matrix4.translationValues(offset.dx, offset.dy, 0.0),
       origin = null,
       alignment = null,
       super(key: key, child: child);

Transform.translate是通过改变offset的值来修改原始坐标系的位置。

  Transform.scale({
    Key? key,
    required double scale,
    this.origin,
    this.alignment = Alignment.center,
    this.transformHitTests = true,
    this.filterQuality,
    Widget? child,
  }) : transform = Matrix4.diagonal3Values(scale, scale, 1.0),
       super(key: key, child: child);

Transform.scale通过传入scale,来对子child进行放大缩小。

从上面的不同构造函数可以看出来,实际上最终都将传入的参数转换成为Matrix4的transform对象。

如果你对Matrix4熟悉的话,那么可以用最直接的构造函数,直接传入Matrix4。

Transform的使用

上面我们介绍了Transform.rotate,Transform.translate和Transform.scale这几个构造函数,接下来我们将会使用具体的例子来进行详细的讲解。

首先是Transform.rotate,用来对子组件进行旋转,下面是一个使用的例子:

  Widget build(BuildContext context) {
    return Center(
      child: Transform.rotate(
        angle: pi/4,
        child: const Icon(
            Icons.airplanemode_active,
            size: 200,
          color: Colors.blue,
        ),
      ));
  }

上面的例子将一个飞机的Icon旋转pi/4,也就是45度,最后生成的界面如下:

接下来是Transform.translate,这个方法主要是对子组件进行坐标轴变换,需要传入一个offset选项,如下所示:

    return Transform.translate(
          offset:const Offset(50.0, 100.0),
          child: const Icon(
            Icons.airplanemode_active,
            size: 200,
            color: Colors.blue,
          ),
        );

上面我们还是使用了飞机的图标,不过对他进行了坐标轴变换,最后得出的界面如下:

最后我们要展示的是Transform.scale,用来对子组件进行缩放。

上面我们的图标size是200,我们可以将其缩放为50%,如下所示:

    return Transform.scale(
      scale: 0.5,
      child: const Icon(
        Icons.airplanemode_active,
        size: 200,
        color: Colors.blue,
      ),
    );

运行我们可以得到下面的界面:

是不是变小了很多?

总结

Transform是一个功能强大的widget,通过Transform我们可以做出很多非常有趣的效果。

本文的例子:https://github.com/ddean2009/learn-flutter.git

标签:origin,scale,transform,Transform,变形金刚,key,child,flutter
From: https://www.cnblogs.com/flydean/p/16953516.html

相关文章

  • flutter 键盘弹出 都会重新Build
      解决:1.应该创建一个变量去接收一个方法,且方法必须用Future来返回,看上图2.由于每次触发键盘的时候都是执行build页面,如果future传的是方法,那么每次触发键盘都会触发......
  • Flutter不常用组件(五)
    PhysicalModel为子组件设置阴影它有以下几个属性:Key?key:标识键BoxShapeshape:形状。默认为BoxShape.rectangleClipclipBehavior:多余部分裁剪效果。默认为Clip.none......
  • 论文解读(CDTrans)《CDTrans: Cross-domain Transformer for Unsupervised Domain Adapt
    论文信息论文标题:CDTrans:Cross-domainTransformerforUnsupervisedDomainAdaptation论文作者:TongkunXu,WeihuaChen,PichaoWang,FanWang,HaoLi,RongJin......
  • Flutter 陈航 10-状态 State 编程范式 构建过程
    本文地址目录目录目录10|Widget中的State到底是什么?UI编程范式命令式声明式总结StatelessWidget构建过程适用场景StatefulWidget构建过程总结StatefulWidget可能......
  • 写一个flutter程序2
    需求完成一个简单的移动应用程序,功能是:为一个创业公司生成建议的名称。用户可以选择和取消选择的名称、保存(收藏)喜欢的名称。该代码一次生成十个名称,当用户滚动时,会生成......
  • Flutter 陈航 09-视图渲染 三棵树 Widget
    本文地址目录目录目录09|Widget,构建Flutter界面的基石视图渲染过程WidgetElementRenderObjectRenderObjectWidget介绍Element的创建RenderObject的创建与更新案......
  • Flutter 陈航 06-Dart 基础语法
    本文地址目录目录目录06|基础语法与类型变量Dart的变量与类型num、bool与StringList与Map常量定义07|函数、类与运算符函数可选命名参数和可选参数类的定义命......
  • Flutter不常用组件(四)
    Offstage创建一个在视觉上隐藏其子项的小部件。隐藏后不占空间。该组件有以下几个属性:Key?key:标识键booloffstage=true:是否隐藏。默认为trueWidget?child:子组件......
  • Flutter — 仅用三个步骤就能帮你把文本变得炫酷!
    ​前言:前天,一位不愿意透露姓名的朋友找到我,问我怎么样才能把文本变得炫酷一些,他想用图片嵌入到自己的名字里去,用来当作朋友圈的背景。我直接回了一句,你PS下不就好了。他回我......
  • 写一个flutter程序
    这一部分我们写一个简单应用功能是,为一个创业公司生成建议的公司名称。用户可以选择和取消选择的名称,保存喜欢的名称。该代码一次生成十个名称用户滚动时,生成新一批名......