Flutter 动画容器 AnimatedContainer

@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移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合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)]

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 30
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值