颤抖的动画颤动

时间:2018-10-30 18:28:08

标签: dart flutter

我需要像这样video摇动动画
我是Flutter的新手。我希望能找到一个解决方案或本教程的链接。

1 个答案:

答案 0 :(得分:3)

我认为可以有更好的解决方案。但这可以正常工作,也许会有所帮助

class TestAnimWidget extends StatefulWidget {
  @override
  State<StatefulWidget> createState() => _TestAnimWidgetState();
}

class _TestAnimWidgetState extends State<TestAnimWidget> with SingleTickerProviderStateMixin {

  final TextEditingController textController = TextEditingController();
  AnimationController controller;

  @override
  void initState() {
    controller = AnimationController(duration: const Duration(milliseconds: 500), vsync: this);
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    final Animation<double> offsetAnimation =
    Tween(begin: 0.0, end: 24.0).chain(CurveTween(curve: Curves.elasticIn)).animate(controller)
      ..addStatusListener((status) {
        if (status == AnimationStatus.completed) {
          controller.reverse();
        }
      });

    return Scaffold(
      appBar: AppBar(),
      body: Column(
        mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            AnimatedBuilder(
                animation: offsetAnimation,
                builder: (buildContext, child) {
                  if (offsetAnimation.value < 0.0) print('${offsetAnimation.value + 8.0}');
                  return Container(
                    margin: EdgeInsets.symmetric(horizontal: 24.0),
                    padding: EdgeInsets.only(left: offsetAnimation.value + 24.0, right: 24.0 - offsetAnimation.value),
                    child: Center(child: TextField(controller: textController, )),
                  );
                }),
            RaisedButton(onPressed: () {
              if (textController.value.text.isEmpty) controller.forward(from: 0.0);
            },
            child: Text('Enter'),)
          ],
        ),
    );
  }
}