Android Flutter如何实现3D动画效果
这篇文章主要讲解了“Android Flutter如何实现3D动画效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android Flutter如何实现3D动画效果”吧!
AnimatedWidget 简介
AnimatedWidget
是一个抽象的 StatefulWidget
, 构造方法如下所示。
const AnimatedWidget({ Key? key, required this.listenable, }) : assert(listenable != null), super(key: key);
主要在于接收一个 listenable
参数,通常会是 Animation
对象。在 AnimatedWidget
内部的_AnimatedState
类中,会添加该对象变化监听回调,进而刷新界面。
class _AnimatedState extends State<AnimatedWidget> { @override void initState() { super.initState(); widget.listenable.addListener(_handleChange); } @override void didUpdateWidget(AnimatedWidget oldWidget) { super.didUpdateWidget(oldWidget); if (widget.listenable != oldWidget.listenable) { oldWidget.listenable.removeListener(_handleChange); widget.listenable.addListener(_handleChange); } } @override void dispose() { widget.listenable.removeListener(_handleChange); super.dispose(); } void _handleChange() { setState(() { // The listenable's state is our build state, and it changed already. }); } // ...}
可以看到,只需要将 Animation
对象传给 AnimatedWidget
对象后,就不需要我们之前那样自己写 addListener
之类的处理了。而整个动画可以交给外部其他对象来控制,从而实现动画组件的复用。
3D 旋转动画的实现
3D 旋转的实现比较简单,在 Container
组件有两个参数控制转换(transform),分别是:
transform
:Matrix4
对象,可以实现围绕 X、Y、Z轴的旋转、平移,以及变形等效果。关于Matrix4
涉及到很多矩阵运算和线性代数的知识,可以参考 Matrix4的源码自行温习一下大学的数学知识。transformAlignment
:转换的对齐方式,可以理解为起点位置,可以使用Alignment
对象来设置。
有了这个基础,我们就可以定义3D 旋转动效了,我们定义一个通用的组件,ThreeDAnimatedWidget
:
class ThreeDAnimatedWidget extends AnimatedWidget { final Widget child; const ThreeDAnimatedWidget( {Key? key, required Animation<double> animation, required this.child}) : super(key: key, listenable: animation); @override Widget build(BuildContext context) { final animation = listenable as Animation<double>; return Center( child: Container( transform: Matrix4.identity() ..rotateY(2 * pi * animation.value) ..setEntry(1, 0, 0.01), transformAlignment: Alignment.center, child: child, ), ); }}
这里我们设置的是围绕中心点绕 Y 轴旋转,并使用 setEntry
设置了一定的倾斜角 (这会更有立体感)。实际我们也可以设置围绕 X 轴或 Z 轴旋转。接下来就是这个动画组件的应用了,我们构建一个带有阴影的文字(看起来像立体字)作为这个动画的子组件,其他的控制和上一篇的是类似的,完整代码如下:
class AnimatedWidgetDemo extends StatefulWidget { const AnimatedWidgetDemo({Key? key}) : super(key: key); @override _AnimatedWidgetDemoState createState() => _AnimatedWidgetDemoState();}class _AnimatedWidgetDemoState extends State<AnimatedWidgetDemo> with SingleTickerProviderStateMixin { late Animation<double> animation; late AnimationController controller; @override void initState() { super.initState(); controller = AnimationController(duration: const Duration(seconds: 3), vsync: this); animation = Tween<double>(begin: 0.0, end: 1.0).animate(controller); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('AnimatedWidget 动画'), ), body: ThreeDAnimatedWidget( animation: animation, child: Text( '岛上码农', style: TextStyle( fontSize: 42.0, color: Colors.blue, fontWeight: FontWeight.bold, shadows: [ Shadow( blurRadius: 2, offset: Offset(2.0, 1.0), color: Colors.blue[900]!), ], ), ), ), floatingActionButton: FloatingActionButton( child: Icon(Icons.play_arrow, color: Colors.white), onPressed: () { if (controller.status == AnimationStatus.completed) { controller.reverse(); } else { controller.forward(); } }, ), ); } @override void dispose() { controller.dispose(); super.dispose(); }}
可以看到,这个 ThreeDAnimatedWidget
可以做到复用了,在需要这样动效的场景里,按照上面的方式给它传入 Animation
对象和子组件就可以了。例如我们将文字修改为一张图片。
//...body: ThreeDAnimatedWidget( animation: animation, child: Image.asset( 'images/avatar.jpg', width: 100, height: 100, ),),//...
感谢各位的阅读,以上就是“Android Flutter如何实现3D动画效果”的内容了,经过本文的学习后,相信大家对Android Flutter如何实现3D动画效果这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341