如何在Flutter中制作手势驱动的动画?

时间:2020-01-13 14:30:30

标签: flutter dart flutter-layout flutter-animation

我是Flutter的新手,目前,我正在尝试制作可滑动的底部面板,以使某些文本的不透明度具有动画效果(仅此刻)。

这基本上是我要实现的动画

enter image description here

我通过Saed Nabil找到了这个答案,它创建了一个底页并得到了它的位置。

如何根据拖动百分比为Text设置动画?

2 个答案:

答案 0 :(得分:4)

基于Saed Nabil的响应,我对他的示例进行了一些调整,使用了TextStyle.lerp来根据拖动位置获得文本样式。

StreamController<double> controller = StreamController.broadcast();

class MyWidget extends StatefulWidget {
  @override
  _MyWidgetState createState() => _MyWidgetState();
}

const defaultTextStyle = TextStyle(
  color: Colors.blue,
  fontSize: 15,
);

class _MyWidgetState extends State<MyWidget> {
  double position;
  TextStyle textStyle = defaultTextStyle;

  @override
  Widget build(BuildContext context) {
    final maxPosition = MediaQuery.of(context).size.height - 300;
    return Container(
      child: Center(
        child: RaisedButton(
            child: Text('Show Buttom Sheet'),
            onPressed: () {
              showModalBottomSheet(
                  isScrollControlled: true,
                  context: context,
                  builder: (context) {
                    return StreamBuilder(
                      stream: controller.stream,
                      builder: (context, snapshot) => GestureDetector(
                          onVerticalDragUpdate: (DragUpdateDetails details) {
                            position = MediaQuery.of(context).size.height -
                                details.globalPosition.dy;
                            double newPosition = position;
                            if (position.isNegative || position == 0)
                              Navigator.pop(context);
                            else {
                              if (position > maxPosition) {
                                newPosition = maxPosition;
                              }
                              controller.add(newPosition);
                            }

                            textStyle = TextStyle.lerp(
                                defaultTextStyle,
                                TextStyle(
                                  color: Colors.black,
                                  fontSize: 24,
                                ),
                                newPosition / maxPosition);
                          },
                          behavior: HitTestBehavior.translucent,
                          child: Container(
                            color: Colors.white,
                            height: snapshot.hasData ? snapshot.data : 50.0,
                            width: double.infinity,
                            child: Text(
                              'Reviews',
                              style: textStyle,
                              textAlign: TextAlign.center,
                            ),
                          )),
                    );
                  });
            }),
      ),
    );
  }
}

结果

enter image description here

答案 1 :(得分:1)

根据模态底部工作表所使用的解决方案,您应该能够隔离出随该工作表而变化的变量。通常,这是通过一些小部件提供的controller来实现的;对于Saed Nabil而言,他是将该变量提供给自定义变量的。

只要您具有变量,您就应该能够通过诸如此类的内容为Text小部件上的Opacity小部件提供简单的数学运算。

假设您的变量从0、0.1、0.111、0.222 ..... 1。您可以执行以下操作:

double opacity = 1 - controller.position;

Opacity(
  opacity: opacity,
  child: Text(),
);