【老孟Flutter】自定义文本步进组件-LMLPHP

【老孟Flutter】自定义文本步进组件-LMLPHP

WriteText 组件是一个文本步进组件,即字符一个一个显示,就像手写一样。

【老孟Flutter】自定义文本步进组件-LMLPHP

引入软件包

pubspec.yaml 中添加如下依赖:

dependencies:
  write_text: ^0.0.1

执行命令:

flutter pub get

使用

WriteText(data: 'StepText 是一个步进文本组件,即字符一个一个显示,就像手写一样。'),

【老孟Flutter】自定义文本步进组件-LMLPHP

默认情况下,每个字符出现时长是 300 ms,设置时长为 1 秒:

WriteText(
  data: 'StepText 是一个步进文本组件,即字符一个一个显示,就像手写一样。',
  perMillSeconds: 1000,
)

【老孟Flutter】自定义文本步进组件-LMLPHP

设置字体样式

WriteText(
  data: 'StepText 是一个步进文本组件,即字符一个一个显示,就像手写一样。',
  textStyle: TextStyle(fontSize: 20, color: Colors.red),
)

【老孟Flutter】自定义文本步进组件-LMLPHP

设置不显示光标:

WriteText(
  data: 'StepText 是一个步进文本组件,即字符一个一个显示,就像手写一样。',
  showCursor: false,
),

设置自定义光标:

WriteText(
  data: 'StepText 是一个步进文本组件,即字符一个一个显示,就像手写一样。',
  cursor: Container(
    width: 2,
    height: 16,
    color: Colors.red,
  ),
)

【老孟Flutter】自定义文本步进组件-LMLPHP

主动控制组件的启动和暂停:

WriteTextController _controller = WriteTextController();
bool starting = false;

RaisedButton(
              onPressed: () {
                if (starting) {
                  starting = false;
                  _controller.stop();
                } else {
                  starting = true;
                  _controller.start();
                }
                setState(() {});
              },
              child: Text('${starting ? '暂停' : '启动'}'),
            ),
            WriteText(
              data: _data,
              controller: _controller,
              autoStart: false,
            ),

【老孟Flutter】自定义文本步进组件-LMLPHP

看下面的效果

完整代码如下:

class Demo extends StatefulWidget {
  @override
  _DemoState createState() => _DemoState();
}

class _DemoState extends State<Demo> with SingleTickerProviderStateMixin {
  AnimationController _controller;

  @override
  void initState() {
    _controller =
        AnimationController(vsync: this, duration: Duration(seconds: 2));
    _controller.forward();
    super.initState();
  }

  @override
  void dispose() {
    _controller.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Center(
        child: AnimatedBuilder(
          animation: _controller,
          builder: (BuildContext context, Widget child) {
            return Container(
              padding: EdgeInsets.symmetric(horizontal: 10),
              decoration: BoxDecoration(
                  color: Colors.lightBlue,
                  borderRadius: BorderRadius.circular(4)),
              height: 45,
              width: _controller.value * 200,
              alignment: Alignment.center,
              child: _controller.value == 1.0
                  ? WriteText(
                      data: '老孟 Flutter',
                      perMillSeconds: 200,
                      textStyle: TextStyle(fontSize: 16, color: Colors.white),
                      cursor: Container(
                        height: 2,
                        width: 8,
                        color: Colors.white,
                      ),
                    )
                  : Container(),
            );
          },
        ),
      ),
    );
  }
}

交流

老孟Flutter博客(330个控件用法+实战入门系列文章):http://laomengit.com

欢迎加入Flutter交流群(微信:laomengit)、关注公众号【老孟Flutter】:

11-25 04:55