一文带你了解Android Flutter中Transform的使用
简介
虽然我们在开发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我们可以做出很多非常有趣的效果。
以上就是一文带你了解Android Flutter中Transform的使用的详细内容,更多关于Android Flutter Transform的资料请关注脚本之家其它相关文章!
相关文章
Android使用HorizontalScrollView实现水平滚动
这篇文章主要为大家详细介绍了Android使用HorizontalScrollView实现水平滚动,并点击有相应的反应效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-11-11Android 中从屏幕左下角弹出Dialog动画效果的实现代码
这篇文章主要介绍了Android 中从屏幕左下角弹出Dialog动画效果的实现代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-12-12Android Fragment中使用SurfaceView切换时闪一下黑屏的解决办法
本篇文章主要给大家分享Android Fragment中使用SurfaceView切换时闪一下黑屏的解决办法,需要的朋友可以参考下2015-09-09Android开发 -- 控件的显示与隐藏 setVisibility View.VISIBLE View.INVISI
本文简单介绍在Android开发中控件的显示与隐藏几种常见的属性,给大家一个参考,希望对大家学习有所帮助。2016-06-06Android性能优化之RecyclerView分页加载组件功能详解
这篇文章主要为大家介绍了Android性能优化之RecyclerView分页加载组件功能详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-09-09
最新评论