63 lines
1.4 KiB
Dart
63 lines
1.4 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
class ResultNotice extends StatefulWidget {
|
|
final Color color;
|
|
final String info;
|
|
|
|
const ResultNotice({
|
|
Key? key,
|
|
required this.color,
|
|
required this.info,
|
|
}) : super(key: key);
|
|
|
|
@override
|
|
State<ResultNotice> createState() => _ResultNoticeState();
|
|
}
|
|
|
|
class _ResultNoticeState extends State<ResultNotice> with SingleTickerProviderStateMixin {
|
|
late AnimationController controller;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
controller = AnimationController(
|
|
vsync: this,
|
|
duration: const Duration(milliseconds: 200),
|
|
);
|
|
controller.forward();
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
controller.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
void didUpdateWidget(covariant ResultNotice oldWidget) {
|
|
controller.forward(from: 0);
|
|
super.didUpdateWidget(oldWidget);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Expanded(
|
|
child: Container(
|
|
alignment: Alignment.center,
|
|
color: widget.color,
|
|
child: AnimatedBuilder(
|
|
animation: controller,
|
|
builder: (_, child) => Text(
|
|
widget.info,
|
|
style: TextStyle(
|
|
fontSize: 54 * (controller.value),
|
|
color: Colors.white,
|
|
fontWeight: FontWeight.bold,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|