Files
flutter_first_station/lib/muyu/animate_text.dart
2023-05-03 15:21:44 +08:00

61 lines
1.5 KiB
Dart

import 'package:flutter/material.dart';
import 'models/merit_record.dart';
class AnimateText extends StatefulWidget {
final MeritRecord record;
const AnimateText({Key? key, required this.record}) : super(key: key);
@override
State<AnimateText> createState() => _AnimateTextState();
}
class _AnimateTextState extends State<AnimateText> with SingleTickerProviderStateMixin {
late AnimationController controller;
late Animation<double> opacity;
late Animation<Offset> position;
late Animation<double> scale;
@override
void initState() {
super.initState();
controller =
AnimationController(vsync: this, duration: Duration(milliseconds: 500));
opacity = Tween(begin: 1.0, end: 0.0).animate(controller);
scale = Tween(begin: 1.0, end: 0.9).animate(controller);
position = Tween<Offset>(
begin: const Offset(0, 2),
end: Offset.zero,
).animate(controller);
controller.forward();
}
@override
void didUpdateWidget(covariant AnimateText oldWidget) {
super.didUpdateWidget(oldWidget);
if (oldWidget.record.id != widget.record.id) {
controller.forward(from: 0);
}
}
@override
void dispose() {
controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return ScaleTransition(
scale: scale,
child: SlideTransition(
position: position,
child: FadeTransition(
opacity: opacity,
child: Text('功德+${widget.record.value}'),
)),
);
}
}