Flutter AnimationController / Tween 在 Multiple AnimatedBuilder 中重用

Zan*_*ane 6 flutter flutter-animation

我正在构建一个带有多张卡片的屏幕,在点击其中一张卡片时,卡片应该翻转。我使用带有 Tweens 和 AnimatedBuilder 的 AnimatedController 对卡片进行动画处理没有问题。我的问题是在我的所有“卡片”小部件中重用/应用相同的 AnimatedController 的最佳方法是什么,而不必创建多个 AnimatedControllers 和 Tweens 并将其设置为每张卡片,但仍然允许我单独为它们设置动画。

Zan*_*ane 1

最后这就是我所做的。我创建了一个 Stateful Widget 作为 Card 小部件,并在 Card 小部件内声明 AnimatedController。然后,我在 Card 小部件中创建一个方法,以使用其 AnimatedController 控制动画。在父小部件中,我只需调用相应的卡片小部件方法来控制每个卡片的动画。

在 Card 小部件中公开 showCard 方法:

class Card extends StatefulWidget {

  final _CardState _CardState = _CardState();
  @override
  State<StatefulWidget> createState() => _CardState;

  void showCard()=>_CardState.showCard();
}
Run Code Online (Sandbox Code Playgroud)

Card小部件中的动画方法:

AnimationController _acCardFlip;
Animation<double> _frontFlip;
Animation<double> _backFlip;

@override
void initState() {
  super.initState();
  _acCardFlip = AnimationController(
    vsync: this,
    duration: const Duration(milliseconds: 250),
  );
  _frontFlip = Tween(
    begin: 1.0,
    end: 0.0,
  ).animate(CurvedAnimation(
    parent: _acCardFlip,
    curve: Interval(0.0, 0.5, curve: Curves.easeIn),
  ));
  _backFlip = CurvedAnimation(
    parent: _acCardFlip,
    curve: Interval(0.5, 1.0, curve: Curves.easeOut),
  );
}

showCard() {
  setState(() {
    if (_acCardFlip.isCompleted || _acCardFlip.velocity > 0)
      _acCardFlip.reverse();
    else
      _acCardFlip.forward();
  });
}
Run Code Online (Sandbox Code Playgroud)

在父小部件中,只需创建 Card 小部件并调用动画方法:

Card card = Card();
card.showCard();
Run Code Online (Sandbox Code Playgroud)

然后只需在列表中创建卡片即可独立控制多张卡片。