[-Flutter趣玩篇-] 出神入化的Align+动画
时间:2022-07-27
本文章向大家介绍[-Flutter趣玩篇-] 出神入化的Align+动画,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
龙少:上一个Align玩的出神入化。现在有个需求,让一个组件以某个函数图像动起来。你说咱们要不先去找块砖头再和设计谈谈。
捷特: 别激动,都是成年人。多大点事,有哥在。 龙少:有什么好主意。 捷特: Align。 龙少:神TM又Align,能让你水两篇文章,这么厉害? 捷特:当然Animation也是本文的要点
代码实现
捷特噼里啪啦三分钟搞定:实现好了sin运动,自自己封装一下 龙少:少侠请留步,这是你的文章好吧,我是导演叫来打酱油的。 捷特:想偷个懒都不行,哎。
class MathRunner extends StatefulWidget {
MathRunner({
Key key,
}) : super(key: key);
@override
_MathRunnerState createState() => _MathRunnerState();
}
class _MathRunnerState extends State
with SingleTickerProviderStateMixin {
AnimationController _controller;
Animation animationX;
double _x = -1.0;
double _y = 0;
@override
void initState() {
_controller =
AnimationController(vsync: this, duration: Duration(seconds: 3));
animationX = Tween(begin: -1.0, end: 1.0).animate(_controller)
..addListener(() {
setState(() {
_x = animationX.value;
_y = f(_x);
});
});
super.initState();
}
@override
void dispose() {
_controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return GestureDetector(
onTap: () {
_controller.repeat(reverse: true);
},
child: Container(
width: 300,
color: Colors.grey.withAlpha(33),
height: 150,
child: Align(
alignment: Alignment(_x, _y),
child: CircleAvatar(
backgroundImage: AssetImage("images/icon_head.png"),
),
),
),
);
}
double f(double x) {
double y = sin(pi * x);
return y;
}
}
实现思路
捷特:用一个AnimationController作为0~1的动画器,再使用Tween给这个动画器加buff,使其在-1 ~ 1间运动,成为animationX。 上一篇也说了Align的出神入化之处 现在只需要通过
_y = f(_x);
动态修改位置即可。
简单封装
typedef FunNum1=Function(double t );
class MathRunner extends StatefulWidget {
MathRunner({Key key, this.child, this.f, this.g,this.reverse=true}) : super(key: key);
final Widget child;
final FunNum1 f;
final FunNum1 g;
final bool reverse;
@override
_MathRunnerState createState() => _MathRunnerState();
}
class _MathRunnerState extends State
with SingleTickerProviderStateMixin {
AnimationController _controller;
Animation animationX;
double _x = -1.0;
double _y = 0;
@override
void initState() {
_controller =
AnimationController(vsync: this, duration: Duration(seconds: 3));
animationX = Tween(begin: -1.0, end: 1.0).animate(_controller)
..addListener(() {
setState(() {
_x = widget.f(animationX.value);
_y = widget.g(animationX.value);
});
});
super.initState();
}
@override
void dispose() {
_controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return GestureDetector(
onTap: () {
_controller.repeat(reverse: widget.reverse);
},
child: Container(
child: Align(
alignment: Alignment(_x, _y),
child: widget.child,
),
),
);
}
}
捷特:sin运动,简单
Container(
width: 150,
height: 150,
child: MathRunner(
f: (t)=>t,
g: (t)=>sin(t*pi),
child:CircleAvatar(
backgroundImage: AssetImage("images/icon_head.png"),
)));
捷特:圆形旋转,走你
var circle=Container(
width: 150,
height: 150,
child: MathRunner(
reverse: false,
f: (t)=>cos(t*pi),
g: (t)=>sin(t*pi),
child: CircleAvatar(
backgroundImage: AssetImage("images/icon_head.png"),
),
));
椭圆运动:so easy (下面是四个倾斜的椭圆环绕)
Container(
width: 150,
height: 150,
child: MathRunner(
reverse: false,
f: (t)=>cos(t*pi),
g: (t)=>0.6*sin(t*pi),
child:CircleAvatar(
backgroundImage: AssetImage("images/icon_head.png"),
)));
纯真的笛卡尔心形线,拿去:
var love=Container(
width: 100,
height: 100,
child: MathRunner(
reverse: false,
f: (t)=>1*(2*cos(t*pi)-cos(2*t*pi)),
g: (t)=>1*(2*sin(t*pi)-sin(2*t*pi)),
child:Ball(color: Colors.red,)));
龙少:其实这个需求不是设计提的,只是我想做个心形线给巫缨,兄弟却之不恭 捷特: ....
龙少: 昨天我从小学一年级的数学看到六年级。感觉真是温故而知新啊,站在如今的角度重新审视知识,会有完全不一样的想法。等我今天看完初中数学,应该也能和你一样厉害。 捷特: 啧啧,虽然至今为止
没有超过初中数学知识
。不过,看来不让你体验一下离散数学
的恐怖,你还真就小瞧了我。
- Linux信号基础
- 剑指OFFER之合并有序链表(九度OJ1519)
- Android Studio快捷键每日一练(6)
- Linux文本流
- Linux并发与同步
- Android Studio快捷键每日一练(5)
- 2017年移动行业五大发展趋势及2018年前景展望(下)
- 剑指OFFER之反转链表(九度OJ1518)
- Android Studio快捷键每日一练(4)
- Android Studio快捷键每日一练(3)
- 一分钟教你在博客园中制作自己的动态云球形标签页
- Python标准库06 子进程 (subprocess包)
- 摩拜、美团也伸手共享汽车拉!众多品牌里面,这三家最牛!
- Android Studio快捷键每日一练(2)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- laravel5.5安装jwt-auth 生成token令牌的示例
- Windows环境下安装PHP Pear的方法图文教程
- php菜单/评论数据递归分级算法的实现方法
- 关于laravel5.5的定时任务详解(demo)
- 用PHP做了一个领取优惠券活动的示例代码
- Laravel 自定命令以及生成文件的例子
- 深入了解Python 变量作用域
- Laravel5.5 数据库迁移:创建表与修改表示例
- python代码能做成软件吗
- php适配器模式简单应用示例
- Python 解析简单的XML数据
- Laravel 实现Eloquent模型分组查询并返回每个分组的数量 groupBy()
- Python分类测试代码实例汇总
- Swoole 5将移除自动添加Event::wait()特性详解
- laravel 数据验证规则详解