当前位置: 首页 > news >正文

网站开发说明书网站价格表

网站开发说明书,网站价格表,龙岩酷搜网,黄冈网站建设公司Flutter开发基础之动画专题 动画设计的作用是让UI界面更流畅、直观,能够有效的提升用户体验。 在Flutter开发中,动画分为多个方面: 基础动画、页面交互动画、绘图动画、矩阵变换等。 基本动画 常用的基本动画有透明度动画、缩放动画、旋转动…

Flutter开发基础之动画专题

动画设计的作用是让UI界面更流畅、直观,能够有效的提升用户体验。
在Flutter开发中,动画分为多个方面:
基础动画、页面交互动画、绘图动画、矩阵变换等。
Flutter开发基础

基本动画

常用的基本动画有透明度动画、缩放动画、旋转动画、平移动画等。

  1. 透明度动画
    AnimatedOpacity可以实现基本的透明度变化动画,适用于简单的过渡场景。
    AnimatedOpacity(opacity: opacity,duration: duration,curve: curve,onEnd: onEnd,child: child,)

可以通过设置目标opacity,将child初始opacity修改为目标opacity
FadeTransition可以和AnimationController配合实现子Widget的透明度变换,绑定的AnimationController控制动画的开始与结束。

    FadeTransition(opacity: opacity,child: child,)

在这里对应的State需要绑定SingleTickerProviderStateMixin,如果有多个AnimationController需要绑定TickerProviderStateMixinSingleTickerProviderStateMixinTickerProviderStateMixin都实现于TickerProviderTickerProvider用来发送Ticker对象,Ticker对象的作用是获取每一帧刷新的通知;
Ticker受到SchedulerBinding的驱动,锁屏后会停止刷新,可以避免资源浪费。

  1. 缩放动画
    ScaleTransition可以和AnimationController配合构建缩放动画效果,此缩放是等比例的。
    ScaleTransition(scale: scale,alignment: alignment,child: child,filterQuality: filterQuality,)
  1. 旋转动画
    RotationTransition配合AnimationController实现旋转效果。
    RotationTransition(turns: turns,alignment: alignment,filterQuality: filterQuality,child: child,)
  1. 平移动画
    SlideTransition配合AnimationControllerAnimation<Offset>实现对子Widget的平移变换。
    SlideTransition(position: position,transformHitTests: transformHitTests,textDirection: textDirection,child: child,)

Widget还可以直接配合TweenAnimationController实现动画效果,这里的Tween就是AnimationTween有一下几种:

ColorTweenColor切换动画
DecorationTweenContainer的Decoration变化
BoxConstraintsTween针对ConstrainedBox使用
EdgeInsetsTween一般用于padding或margin变化
BorderTween边框变换动画
BorderRadiusTween边框圆角变换动画
Matrix4Tween矩阵变换动画
TextStyleTween文本样式过渡动画
TweenSequence串行动画,是动画序列的组合动画
ConstantTween常量值动画,一般与TweenSequence配合组合动画
SizeTweensize变换动画
RectTweenrect变换动画
StepTween与TweenAnimationBuilder配合使用,可显著提高动画效率

Widget动画还可以通过AnimatedWidget实现,AnimatedWidget会封装好setState状态更新,通过Listenable监听Widget动画;
AnimatedBuilder继承自AnimatedWidget,对AnimatedWidget做了优化。
AnimatedModalBarrier继承自AnimatedWidget,可以防止用户与身后的子Widget交互。
SpringSimulation可以和SpringDescription配合AnimationController实现阻尼效果。

页面交互动画

Flutter中可以通过Hero组件来组合不同路由页面的过渡元素,通过使用相同的tag绑定不同的Widget,确保不同的Widget完成过渡。

    Hero(tag: tag,createRectTween: createRectTween,flightShuttleBuilder: flightShuttleBuilder,placeholderBuilder: placeholderBuilder,transitionOnUserGestures: transitionOnUserGestures,child: child,)

若过渡效果不满意,可以配合PageRouteBuilder实现自定义Hero动画效果。
当需要对相邻或有关联的Widget进行切换过渡时可以使用AnimatedSwitcher实现。

    AnimatedSwitcher(duration: duration,reverseDuration: reverseDuration,switchInCurve: switchInCurve,switchOutCurve: switchOutCurve,transitionBuilder: transitionBuilder,layoutBuilder: layoutBuilder,child: child,)

绘图动画

绘图动画是Canvas结合Path绘制自定义图形,对于完整的Path可以通过PathMetric分解获得任一截数据,形成新的Path
在一定时间内逐步绘制一部分Path实现画线效果,我们可以同过自定义一个CustomPainter配合AnimationController实现动画效果。

    CustomPaint(painter: painter,foregroundPainter: foregroundPainter,size: size,isComplex: isComplex,willChange: willChange,child: child,)
http://www.yayakq.cn/news/480733/

相关文章:

  • 四川省信用建设促进会网站厦门外贸网站建设报价
  • 黄山找人做网站wordpress 4.5.3 ueditor
  • 私募股权基金网站建设做dhl底单的网站是 什么
  • 免费做网站哪里有响应式网站模板怎么做
  • 苏州制作企业网站公司网页制作工具知乎
  • 东莞网站建设公司注册建设门户网站所需
  • 上海网站设计首选刻公司企业宣传片的拍摄
  • 九江建网站报价企业网站创建小结
  • 冒充it男给某网站做修复米拓建站免费模板
  • 网站建设如何算成本京东购物app下载安装
  • 网站素材包括哪些传媒公司网站建设策划
  • 网站排名首页前三位网站开发 制作阶段的说课稿
  • 免费申请网站空间泉州有那些网站建设公司
  • 太原百度网站排名优化做哪些网站可以赚钱的
  • 永兴县网站建设哪家好金寨县住房和城乡建设部网站
  • 龙泉做网站哪家好网站后台编辑技巧
  • 网站的软文 怎么做推广方案静态网站开发语言
  • 做奥数题网站网络认证工程师
  • 烟台网站建设推广江西 网站制作
  • 网站平台建设方案的难点重点wordpress页面显示什么意思
  • 网站和网页的区别是什么网站建设会计科目
  • 万网的网站怎么建设中国地震网今天发生地震最新消息
  • 大连网站开发 选领超科技中国核工业二三建设有限公司是国企吗
  • 简约网站欣赏新媒体运营的相关优势
  • 9元建站节wordpress中怎么排序
  • 在哪个彩票网站是小黄人做头像的狭义的网络营销
  • 专业医疗网站建设威海哪里做网站
  • 公司怎么与网站进行活动推广网站网页模板
  • 怎么和网站合作推广php 数据库转wordpress
  • 宁德网站建设维护wordpress 多用户商城