StatelessWidget

This commit is contained in:
toly
2023-04-22 09:05:32 +08:00
parent 88f535f3e8
commit a2d2b18c1f
2 changed files with 23 additions and 36 deletions

View File

@@ -14,16 +14,30 @@ class GuessPage extends StatefulWidget {
State<GuessPage> createState() => _GuessPageState(); State<GuessPage> createState() => _GuessPageState();
} }
class _GuessPageState extends State<GuessPage> { class _GuessPageState extends State<GuessPage> with SingleTickerProviderStateMixin{
late AnimationController controller;
@override
void initState() {
super.initState();
controller = AnimationController(
vsync: this,
duration: const Duration(milliseconds: 200),
);
}
int _value = 0; int _value = 0;
Random _random = Random(); Random _random = Random();
bool _guessing = false; bool _guessing = false;
bool? _isBig; bool? _isBig;
@override @override
void dispose() { void dispose() {
_guessCtrl.dispose(); _guessCtrl.dispose();
controller.dispose();
super.dispose(); super.dispose();
} }
@@ -42,7 +56,7 @@ class _GuessPageState extends State<GuessPage> {
int? guessValue = int.tryParse(_guessCtrl.text); int? guessValue = int.tryParse(_guessCtrl.text);
// 游戏未开始,或者输入非整数,无视 // 游戏未开始,或者输入非整数,无视
if (!_guessing || guessValue == null) return; if (!_guessing || guessValue == null) return;
controller.forward(from: 0);
//猜对了 //猜对了
if (guessValue == _value) { if (guessValue == _value) {
setState(() { setState(() {
@@ -70,10 +84,10 @@ class _GuessPageState extends State<GuessPage> {
Column( Column(
children: [ children: [
if(_isBig!) if(_isBig!)
ResultNotice(color:Colors.redAccent,info:'大了'), ResultNotice(color:Colors.redAccent,info:'大了',controller: controller,),
Spacer(), Spacer(),
if(!_isBig!) if(!_isBig!)
ResultNotice(color:Colors.blueAccent,info:'小了'), ResultNotice(color:Colors.blueAccent,info:'小了',controller: controller,),
], ],
), ),
Center( Center(

View File

@@ -1,54 +1,27 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
class ResultNotice extends StatefulWidget { class ResultNotice extends StatelessWidget {
final Color color; final Color color;
final String info; final String info;
final AnimationController controller;
const ResultNotice({ const ResultNotice({
Key? key, Key? key,
required this.color, required this.color,
required this.info, required this.info,
required this.controller,
}) : super(key: key); }) : 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 @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Expanded( return Expanded(
child: Container( child: Container(
alignment: Alignment.center, alignment: Alignment.center,
color: widget.color, color: color,
child: AnimatedBuilder( child: AnimatedBuilder(
animation: controller, animation: controller,
builder: (_, child) => Text( builder: (_, child) => Text(
widget.info, info,
style: TextStyle( style: TextStyle(
fontSize: 54 * (controller.value), fontSize: 54 * (controller.value),
color: Colors.white, color: Colors.white,