@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: GestureDetector(
onTap: () {
setState(() {
selected = !selected;
});
},
child: Center(
child: AnimatedContainer(
width: selected ? 200.0 : 100.0,
height: selected ? 100.0 : 200.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeOut,
child: Text(‘’),
),
),
),
),
);
}
Cubic easeInOut = Cubic(0.42, 0.0, 0.58, 1.0)
开始缓慢,加速,然后缓慢结束的三次动画曲线
Curves.easeInOut
AnimatedContainer(
width: selected ? 200.0 : 100.0,
height: selected ? 100.0 : 200.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeInOut,
child: Text(‘’),
),
Cubic easeInExpo = Cubic(0.95, 0.05, 0.795, 0.035)
立方体动画曲线开始缓慢,结束迅速
Curves.easeInExpo
AnimatedContainer(
width: selected ? 200.0 : 100.0,
height: selected ? 100.0 : 200.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeInExpo,
child: Text(‘’),
),
Cubic easeInCubic = Cubic(0.55, 0.055, 0.675, 0.19)
立方体动画曲线开始缓慢,结束迅速
Curves.easeInCubic
AnimatedContainer(
width: selected ? 200.0 : 100.0,
height: selected ? 100.0 : 200.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeInCubic,
child: Text(‘’),
),
Matrix4.rotationZ(selected?50.0:0.0)
绕Z轴旋转
Matrix4.rotationZ
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeInCubic,
transform: Matrix4.rotationZ(selected ? -90.0 : 0.0),
child: Text(‘’),
),
Matrix4.rotationX(selected ? 10.0 : 0.0)
绕X轴旋转
Matrix4.rotationX
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
curve: Curves.easeInCubic,
transform: Matrix4.rotationX(selected ? 10.0 : 0.0),
child: Text(‘’),
),
Matrix4.rotationY(selected ? 10.0 : 0.0)
绕Y轴旋转
Matrix4.rotationY
多个 AnimatedContainer 绕X轴旋转效果
Matrix4.rotationX
var selected = false;
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: Stack(
children: [
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 1),
curve: Curves.easeInCubic,
alignment: Alignment.center,
transform: Matrix4.rotationX(selected ? 10.0 : 0.0),
child: Text(‘1’),
),
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 2),
alignment: Alignment.center,
curve: Curves.easeInCubic,
transform: Matrix4.rotationX(selected ? 10.0 : 0.0),
child: Text(‘2’),
),
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 3),
curve: Curves.easeInCubic,
alignment: Alignment.center,
transform: Matrix4.rotationX(selected ? 10.0 : 0.0),
child: Text(‘3’),
),
AnimatedContainer(
width: 200.0,
height: 100.0,
color: selected ? Colors.red : Colors.blue,
duration: Duration(seconds: 4),
alignment: Alignment.center,
curve: Curves.easeInCubic,
transform: Matrix4.rotationX(selected ? 10.0 : 0.0),
child: Text(‘4’),
),
],
),
),
floatingActionButton: FloatingActionButton(
child: Icon(Icons.play_arrow),
onPressed: () {
setState(() {
selected = !selected;
});
},
),
),
);
}
多个AnimatedContainer组合动画式展开布局
import ‘package:flutter/material.dart’;
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: ‘Flutter Animation Container’,
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: AnimatedContainerApp(),
);
}
}
class AnimatedContainerApp extends StatefulWidget {
@override
_AnimatedContainerAppState createState() => _AnimatedContainerAppState();
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
尾声
最后,我再重复一次,如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
Android进阶学习资料库
一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
要的事情做深度研究。
对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。
[外链图片转存中…(img-isUYOFdz-1711817249495)]
Android进阶学习资料库
一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!
[外链图片转存中…(img-MlWTiSOl-1711817249495)]