首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Flutter的AnimatedDefaultTextStyle实现文本样式的动画过渡切换效果

Flutter的AnimatedDefaultTextStyle实现文本样式的动画过渡切换效果

原创
作者头像
早起的年轻人
修改2020-07-13 10:12:26
1.3K0
修改2020-07-13 10:12:26
举报

题记

—— 执剑天涯,从你的点滴积累开始,所及之处,必精益求精,即是折腾每一天。

重要消息


AnimatedDefaultTextStyle通过动画过渡的方式来切换文本的显示样式,如下图所示效果,当点击切换样式按钮时,显示的文本样式会以动画过渡的方式来切换。

在这里插入图片描述
在这里插入图片描述

这个效果的核心代码就是通过AnimatedDefaultTextStyle来实现的动画效果过渡,代码如下:

AnimatedDefaultTextStyle buildAnimatedDefaultTextStyle() {
  return AnimatedDefaultTextStyle(
    ///设置Text中的文本样式
    ///每当样式有改变时会以动画的方式过渡切换
    style: isSelected
        ? TextStyle(
            fontSize: 50, color: Colors.red, fontWeight: FontWeight.bold)
        : TextStyle(
            fontSize: 24.0, color: Colors.black, fontWeight: FontWeight.w100),
    ///动画切换的时间
    duration: const Duration(milliseconds: 200),
    ///动画执行插值器
    curve: Curves.bounceInOut,
    ///文本对齐方式
    textAlign: TextAlign.start,
    ///文本是否应该在软换行符处换行
    softWrap: true,
    ///超过文本行数区域的裁剪方式
    ///设置设置为省略号
    overflow: TextOverflow.ellipsis,
    ///最大显示行数
    maxLines: 1,
    ///每当样式有修改触发动画时
    ///动画执行结束的回调
    onEnd: () {
      print("动画执行结束");
    },

    ///文本组件
    child: Text("Hello, Flutter"),
  );
}

通过一个按钮来动态修改isSelected的值,从而来触发修改文本样式的切换动画过渡效果,完整代码如下:

class AnimatedTextStylePage extends StatefulWidget {
  @override
  _FirstPageState createState() => _FirstPageState();
}

class _FirstPageState extends State<AnimatedTextStylePage> {
  @override
  Widget build(BuildContext context) {
    return buildBodyFunction();
  }

  bool isSelected = false;

  ///5.8 /lib/code4/main_data404.dart
  /// 文本显示组件Text
  Widget buildBodyFunction() {
    return Scaffold(
      appBar: AppBar(
        title: Text("动画样式"),
      ),
      body: Container(
        padding: EdgeInsets.all(16),
        child: Column(
          children: <Widget>[
            ///动画样式组件
            buildAnimatedDefaultTextStyle(),
            SizedBox(
              height: 55,
            ),
            FlatButton(
              child: Text("切换样式"),
              onPressed: () {
                setState(() {
                  isSelected = !isSelected;
                });
              },
            )
          ],
        ),
      ),
    );
  }
  ///省略 buildAnimatedDefaultTextStyle 方法代码
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档