Zan*_*ane 6 flutter flutter-animation
我正在构建一个带有多张卡片的屏幕,在点击其中一张卡片时,卡片应该翻转。我使用带有 Tweens 和 AnimatedBuilder 的 AnimatedController 对卡片进行动画处理没有问题。我的问题是在我的所有“卡片”小部件中重用/应用相同的 AnimatedController 的最佳方法是什么,而不必创建多个 AnimatedControllers 和 Tweens 并将其设置为每张卡片,但仍然允许我单独为它们设置动画。
最后这就是我所做的。我创建了一个 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)
然后只需在列表中创建卡片即可独立控制多张卡片。
| 归档时间: |
|
| 查看次数: |
359 次 |
| 最近记录: |