Skip to content

根据时间t(0.0~1.0)计算点(Offset)在贝塞尔曲线上的位置

License

Notifications You must be signed in to change notification settings

jethroHuang/bessel_tween

Repository files navigation

bessel_tween

贝塞尔曲线补间动画,用来实现一个Widget按照贝塞尔曲线路径移动。 可实现多阶贝塞尔曲线

  • 安装bessel_tween

    修改yaml

    dependencies:
      bessel_tween: ^0.1.0

    安装

    $ flutter packages get
    
  • 使用bessel_tween

    import 'package:flutter/animation.dart';
    import 'package:bessel_tween/bessel_tween.dart';
    
    void initState() {  
        // 定义3个控制点,可以更多
        pointList = [Offset(0, 0), Offset(250, 20), Offset(300, 300)];
        AnimationController controller = AnimationController(duration: Duration(milliseconds: 3000), vsync: this);
        Animation<Offset> besselAnimation = BesselTween(pointList).animate(controller);
        controller.addListener(() {
              setState(() {
              //改变 Widget 的位置
              widgetOffset = besselAnimation.value;
            });
            });
        controller.forward();
    }
  • 运行效果动图

    运行效果图

    实现效果的代码在example里,debug模式会有点卡顿,在release模式里就会极其丝滑

最后感谢 https://blog.csdn.net/aimeimeits/article/details/72809382 这篇文章的作者。

本package的算法部分来自于上面那篇文章

About

根据时间t(0.0~1.0)计算点(Offset)在贝塞尔曲线上的位置

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published