vue 页面切换动画_Flutter Hero动画让你的APP页面切换充满动效 不一样的体验 不一样的细节处理...

优美的应用体验 来自于细节的处理,更源自于码农的自我要求与努力,当然也需要码农年轻灵活的思维。


本文章实现的Demo效果,如下图所示:

8d2690e3870c2a5839d608ad4aee0ea8.gif

class HeroHomePage extends StatefulWidget {  @override  _TestPageState createState() => _TestPageState();}class _TestPageState extends State<HeroHomePage> {  @override  Widget build(BuildContext context) {    return Scaffold(      //背景      backgroundColor: Colors.grey[200],      //标题      appBar: AppBar(        title: Text("每日分享"),      ),      //页面主体      body: buildBodyWidget(),    );  }  ...  }

页面的主体就是这里显示的图文,使用Row来将图片与文本区域左右排列,代码如下:

75f5a0e65d4831d706ea17b57e8ba1db.png

  Widget buildBodyWidget() {    //水波纹点击事件监听    return InkWell(      //手指点击抬起时的回调      onTap: () {        //打开新的页面        openPageFunction();      },      child: Container(        padding: EdgeInsets.all(10),        color: Colors.white,        //线性布局左右排列        child: Row(          //主轴方向开始对齐 在这里是左对齐           mainAxisAlignment: MainAxisAlignment.start,          //交叉轴上开始对齐 在这里是顶部对齐          crossAxisAlignment: CrossAxisAlignment.start,          children: [            //左侧的图片            buildLeftImage(),            //右侧的文本区域            buildRightTextArea()],        ),      ),    );  }

2 显示图片的构建

左侧的图片区域 需要 使用 Hero 来包裹,因为这里就是Hero动画触发的效果,代码如下:

  ///左侧的图片区域  Container buildLeftImage() {    return Container(      margin: EdgeInsets.only(right: 12),      child: Hero(        tag: "test",        child: Image.asset(          "images/banner3.webp",          width: 96,          fit: BoxFit.fill,          height: 96,        ),      ),    );  }

3 右侧的文本区域

d3c2a15c38adebcb93a0b0fe1f65a1f4.png

  ///右侧的文本区域  Expanded buildRightTextArea() {    return Expanded(      child: Column(        crossAxisAlignment: CrossAxisAlignment.start,        mainAxisSize: MainAxisSize.min,        children: [          Text(            "优美的应用",            softWrap: true,            overflow: TextOverflow.ellipsis,            maxLines: 3,            style: TextStyle(fontSize: 16),          ),          Text(            "优美的应用体验 来自于细节的处理,更源自于码农的自我要求与努力,当然也需要码农年轻灵活的思维。",            softWrap: true,            overflow: TextOverflow.ellipsis,            maxLines: 3,            style: TextStyle(fontSize: 14, color: Colors.black38),          )        ],      ),    );  }

4 自定义透明过度动画路由

Hero达成两个页面之间共享元素的连动效果,但是页面的切换效果造成碍眼的体验,配合一个透明过度,达成舒适的体验,代码如下:

  ///自定义路由动画  void openPageFunction() {    Navigator.of(context).push(      PageRouteBuilder(        pageBuilder: (BuildContext context, Animation<double> animation,            Animation<double> secondaryAnimation) {          //目标页面          return DetailsPage();        },        //打开新的页面用时        transitionDuration: Duration(milliseconds: 1800),        //关半页岩用时        reverseTransitionDuration: Duration(milliseconds: 1800),        //过渡动画构建        transitionsBuilder: (          BuildContext context,          Animation<double> animation,          Animation<double> secondaryAnimation,          Widget child,        ) {          //渐变过渡动画          return FadeTransition(            // 透明度从 0.0-1.0            opacity: Tween(begin: 0.0, end: 1.0).animate(              CurvedAnimation(                parent: animation,                //动画曲线规则,这里使用的是先快后慢                curve: Curves.fastOutSlowIn,              ),            ),            child: child,          );        },      ),    );  }

5 最后就是点击图文信息打开的详情页面

class DetailsPage extends StatelessWidget {  @override  Widget build(BuildContext context) {    return Scaffold(      //背景透明      backgroundColor: Colors.white,      appBar: AppBar(        title: Text("精彩人生"),      ),      body: buildCurrentWidget(context),    );  }  Widget buildCurrentWidget(BuildContext context) {    return Container(      color: Colors.white,      padding: EdgeInsets.all(8),      margin: EdgeInsets.all(10),      child: Column(        crossAxisAlignment: CrossAxisAlignment.start,        children: [          //图片区域          buildHero(context),          SizedBox(            width: 22,          ),          //文字区域          buildTextContainer(),        ],      ),    );  }}

页面分为两部分,第一部分的图片,使用Hero过渡 ,需要注意的是 目标 Hero 的直接子类必须是一个 Material包裹,代码如下:

  ///图片区域  Hero buildHero(BuildContext context) {    return Hero(      tag: "test",      child: Material(        color: Colors.blue,        child: InkWell(          onTap: () {            Navigator.of(context).pop();          },          child: Image.asset(            "images/banner3.webp",            fit: BoxFit.fill,          ),        ),      ),    );  }

第二部分就是一个普通的文本了

  Container buildTextContainer() {    return Container(      child: Text(        "优美的应用体验 来自于细节的处理,更源自于码农的自我要求与努力",        softWrap: true,        overflow: TextOverflow.ellipsis,        maxLines: 3,        style: TextStyle(fontSize: 16),      ),    );  }

点击原文可获取源码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/430961.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自定义左右侧滑菜单

实现效果&#xff1a; 左右侧滑菜单&#xff0c;侧滑栏占主屏比为60%监听触控&#xff0c;自定义滑动动画&#xff0c;当侧边栏滑动超过50%松开触控将自动滑动到60%&#xff0c;未超过50%松开触控回归侧边栏隐藏为主屏设置蒙版效果&#xff0c;根据侧滑菜单的占屏比设置主屏蒙版…

秦九韶算法matlab程序,数值分析matlab程序实例.doc

数值分析matlab程序实例1&#xff0c;秦九韶算法&#xff0c;求出P(x3)24x5x^22x^3的值clear?all;x3;n3;a(1)2;a(2)4;a(3)5;a(4)2v(1)a(n1);for k2:(n1);v(k)x*v(k-1)a(n-k2);end?pv(n1)p ,1132&#xff0c;一次线型插值程序&#xff1a;利用100.121.求115的开方。clear all;…

在github上创建新分支

在github上创建仓库&#xff1a; Create a new repository on the command line touch README.md git init git add README.md git commit -m "first commit" git remote add origin https://github.com/BrentHuang/MyRepo.git git push -u origin master 在本地新建…

以python程序调用的系统_python 系统调用的实例详解

python 系统调用的实例详解本文将通过两种方法对python 系统调用进行讲解&#xff0c;包括python使用CreateProcess函数运行其他程序和ctypes模块的实例&#xff0c;一 python使用CreateProcess函数运行其他程序>>> import win32process>>> handle win32pro…

ubuntu php7 memcache,linux上安装php7 memcache扩展

php7安装memcache扩展需要memcache php7的分支 否则安装会失败php7的memcache扩展安装&#xff0c;真的很让人心碎&#xff01;下面则是php7的扩展memcache安装了。用之前的php版本安装是没有问题&#xff0c;但是用了php7安装 http://pecl.php.net/package/memcache 下的任一…

好文推荐系列--------(3)GruntJS 在线重载 提升生产率至新境界

好文原文地址&#xff1a;http://segmentfault.com/a/1190000000354555 本文将首先介绍grunt-markdown插件如何配合HTML模板使用&#xff0c;接着我将介绍如何使用grunt-watch插件将工作效率提升至新层次。如果你不熟悉GruntJS&#xff0c;请先阅读我关于GruntJS的文章。 Githu…

python3有多少个关键字排序_python3 数据结构和算法-- 通过某个关键字排序一个字典列表...

通过某个关键字排序一个字典列表问题你有一个字典列表&#xff0c;你想根据某个或某几个字典字段来排序这个列表。解决方案通过使用 operator 模块的 itemgetter 函数&#xff0c;可以非常容易的排序这样的数据结构。 假设你从数据库中检索出来网站会员信息列表&#xff0c;并且…

php页面怎么去登录,php中登录后跳转回原来要访问的页面实例

在很多网站用户先访问一个要登录的页面&#xff0c;但当时没有登录后来登录了&#xff0c;等待用户登录成功之后肯定希望返回到上次访问的页面&#xff0c;下面我就来给大家介绍登录后跳转回原来要访问的页面实例最简单的办法就是直接使用php $_SERVER[HTTP_REFERER]如果我在A.…

三目运算

total>100?total*0.8:total;//true执行冒号前面的&#xff1b;false执行冒号后面的 等价于 if(total>100){ totaltotal*0.8; }else{ totaltotal; }转载于:https://www.cnblogs.com/barbie7/p/5129566.html

二叉树的创建_大多数人都不会手写创建并遍历二叉树,一航这里帮你终结了

创建二叉树、遍历二叉树、二叉树的最近公共祖先任何疑问、意见、建议请公众号留言或联系qq474356284先序、后序创建二叉树先中后层序遍历二叉树二叉树的最近公共祖先 输入格式&#xff1a;创建二叉树时的输入&#xff1a;如序列&#xff1a;{1 2 -1 -1 3 -1 -1}表示1结点有2,…

tp5 php正则邮箱,TP5验证器使用实例

TP5验证器建立模块\validate\验证器文件名例如我们定义了一个验证USER的验证器类<?php namespace app\admin\validate;use think\Validate;class Admin extends Validate{protected $rule [username > require|min:3|max:16|unique:admin,password > require|min:6|…

zookeeper 密码_阿里资深JAVA架构带你深度剖析dubbo和zookeeper关系

为什么要用dubbo&#xff1f;当网站规模达到了一定的量级的时候&#xff0c;普通的MVC框架已经不能满足我们的需求&#xff0c;于是分布式的服务框架和流动式的架构就凸显出来了。单一应用架构当网站流量很小时&#xff0c;只需一个应用&#xff0c;将所有功能都部署在一起&…

python pandas csv 追加 空行,python – Pandas:read_csv在空行后忽略行

有一个奇怪的.csv文件,如&#xff1a;header1,header2,header3val11,val12,val13val21,val22,val23val31,val32,val33很好,但在这些线之后,总会有一个空行,后面跟着很多无用的线.整个事情是一致的&#xff1a;header1,header2,header3val11,val12,val13val21,val22,val23val31,…

nw.js FrameLess Window下的窗口拖拽与窗口大小控制

nw.js FrameLess Window下的窗口拖拽与窗口大小控制 很多时候&#xff0c;我们觉得系统的Frame框很难看&#xff0c;于是想自定义。 自定义Frame的第一步是在package.config文件中将frame选项设置为false。 { "name": "1", "main": "index.…

python控制语句实验报告,python流程控制语句案例练习

最近玩python&#xff0c;为了更好的学习其中的流程控制语句&#xff0c;本身写了一个查询员工信息和更新信息的脚本&#xff0c;此脚本仅供练习使用。大拿可绕行&#xff01;python#!/usr/bin/env pythonimport sysimport osos.system(clear)mess \033[;35m ID :%s\033[0m\03…

linux 文件重命名_如何在 Linux 上重命名一组文件 | Linux 中国

要用单个命令重命名一组文件&#xff0c;请使用 rename 命令。它需要使用正则表达式&#xff0c;并且可以在开始前告诉你会有什么更改。-- Sandra Henry-stocker几十年来&#xff0c;Linux 用户一直使用 mv 命令重命名文件。它很简单&#xff0c;并且能做到你要做的。但有时你需…

Spring 构造注入 传參数

1. 提供相应的构造方法 //构造器注入 public class Bean6 {private String name;private Integer age;// 服务于构造器注入使用public Bean6(String name, Integer age) {super();this.name name;this.age age;}public void show() {System.out.println("bean6:&…

php正则表达式函数案例,PHP正则表达式函数preg_replace用法实例分析

PHP正则表达式函数preg_replace用法。&#xff0c;具体如下&#xff1a;preg_replace 执行一个正则表达式的搜索和替换语法&#xff1a;preg_replace (pattern ,replacement ,subject,limit,count )参数描述pattern正则表达式(字符串或字符串数组)replacement用于替换的字符串或…

python tk protocol_Python Modbus_tk在树莓派上实现rtu master

利用 python modbus工具实现modbus从站的数据采集&#xff0c;很方便简单。Python Modbus 协议工具目前有下面三种&#xff1a;modbus_tk&#xff1a;完整modbus协议栈的实现&#xff0c;支持modbus tcp/rtu&#xff5b;1.提供slave模拟器&#xff0c;即模拟modbus server:502)…

根据另外一个表来更新,增加字段

update table1 set field1table2.field1,field2table2.field2from table2where table1.idtable2.id添加字段&#xff1a;alter table 表名 add 字段名 类型删除字段&#xff1a;alter table 表名 drop column 字段名转载于:https://www.cnblogs.com/yzwdli/p/5147512.html