提问人:Jaafar Melhem 提问时间:4/10/2022 更新时间:8/14/2023 访问量:1031
监听 Animation flutter 内部的位置变化
listen for the position changes inside Animation flutter
问:
当动画当前运行(未完成或取消)时,是否有监听子小部件位置的变化? 例如 我们有这个变量:
GlobalKey globalKey= GlobalKey();
bool isAnimated =false;
我需要侦听目标小部件在此 AnimatedContainer 中的位置:
InkWell(
onTap:() => setState(() {isAnimated=!isAnimated};) ,
child: AnimatedContainer(
duration: Duration(milliseconds: 1000),
width: 200,
height: isAnimated?100:40,
child: Column(
mainAxisAlignment: MainAxisAlignment.end,
children: [
SizedBox(height: 10,),
//the target widget
SizedBox(
key: globalKey,
)
],)
),
)
例如,当 AnimatedContainer 的高度达到 70 时,它会根据目标小部件的位置确认我做一些事情。
答:
4赞
can
4/10/2022
#1
您的确切要求尚不清楚。根据“对目标小部件执行某些操作”的含义,您可能需要选择不同的方法。但是,如果要向动画添加侦听器或对当前动画值做出反应,则最好使用 AnimatedBuilder。我包括一个基本的例子,可以帮助你处理这种情况。
class MyAnimatedWidget extends StatefulWidget {
const MyAnimatedWidget({
Key? key,
}) : super(key: key);
@override
State<MyAnimatedWidget> createState() => _MyAnimatedWidgetState();
}
class _MyAnimatedWidgetState extends State<MyAnimatedWidget>
with TickerProviderStateMixin {
late final AnimationController _controller;
late Animation _animation;
GlobalKey globalKey = GlobalKey();
@override
void initState() {
super.initState();
_controller = AnimationController(
vsync: this,
duration: const Duration(milliseconds: 1000),
);
_controller.addListener(() {
//also possible to listen for changes with a listener
});
_animation = CurveTween(curve: Curves.easeOut).animate(_controller);
_controller.forward();
}
@override
void dispose() {
_controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return AnimatedBuilder(
animation: _animation,
builder: (context, child) {
return InkWell(
onTap: () {},
child: Container(
width: 200,
height: _containerHeightBuilder(_controller.value),
child: Column(
mainAxisAlignment: MainAxisAlignment.end,
children: [
const SizedBox(
height: 10,
),
//the target widget
SizedBox(
//or do something here with the current animation value
key: globalKey,
)
],
)),
);
});
}
double _containerHeightBuilder(double animationValue) {
const double containerAnimationTarget = 60;
const double containerBaseHeight = 40;
const double thresholdHeight = 70;
double currentHeight =
containerBaseHeight + (containerAnimationTarget * animationValue);
if (currentHeight == thresholdHeight) {
//do something here
}
return currentHeight;
}
}
评论