gpt4 book ai didi

Flutter AnimationController/Tween 在 Multiple AnimatedBuilder 中重用

转载 作者:行者123 更新时间:2023-12-03 17:30:08 25 4
gpt4 key购买 nike

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

最佳答案

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

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

class Card extends StatefulWidget {

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

void showCard()=>_CardState.showCard();
}

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();
});
}

在父小部件中,只需创建 Card 小部件并调用方法进行动画处理:
Card card = Card();
card.showCard();

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

关于Flutter AnimationController/Tween 在 Multiple AnimatedBuilder 中重用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55877787/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com