2021-10-05 23:19:58 +00:00
|
|
|
import 'package:flame_audio/flame_audio.dart';
|
2021-09-22 19:26:06 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
2021-10-09 03:59:38 +00:00
|
|
|
import '../main.dart';
|
2021-09-22 19:26:06 +00:00
|
|
|
|
|
|
|
class LoseMenuOverlay extends StatelessWidget {
|
|
|
|
const LoseMenuOverlay({
|
|
|
|
Key? key,
|
|
|
|
required this.game,
|
|
|
|
}) : super(key: key);
|
|
|
|
|
|
|
|
final MyGame game;
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2021-10-01 22:40:28 +00:00
|
|
|
double width = MediaQuery.of(context).size.width;
|
2021-09-22 19:26:06 +00:00
|
|
|
return Center(
|
|
|
|
child: Container(
|
2024-05-24 15:14:17 +00:00
|
|
|
height: game.canvasSize.y,
|
|
|
|
width: game.canvasSize.x,
|
2021-09-22 19:26:06 +00:00
|
|
|
decoration: const BoxDecoration(
|
|
|
|
image: DecorationImage(
|
2021-10-01 22:40:28 +00:00
|
|
|
image: lossImage,
|
2021-09-22 19:26:06 +00:00
|
|
|
fit: BoxFit.fill,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
child: Column(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: [
|
2021-10-01 22:40:28 +00:00
|
|
|
Material(
|
|
|
|
type: MaterialType.transparency,
|
|
|
|
child: Text(
|
|
|
|
'Score: ${game.gameState.getPlayerScore()}',
|
|
|
|
style: TextStyle(
|
2021-10-09 18:32:15 +00:00
|
|
|
color: textColor,
|
2021-10-01 22:40:28 +00:00
|
|
|
fontSize: width * 0.05,
|
|
|
|
),
|
|
|
|
),
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
|
|
|
const SizedBox(height: 32.0),
|
|
|
|
Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: [
|
|
|
|
MaterialButton(
|
|
|
|
padding: const EdgeInsets.all(8.0),
|
|
|
|
elevation: 8.0,
|
|
|
|
child: Container(
|
|
|
|
decoration: const BoxDecoration(
|
2021-10-01 22:40:28 +00:00
|
|
|
image:
|
|
|
|
DecorationImage(image: buttonImage, fit: BoxFit.fill),
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
2021-10-01 22:40:28 +00:00
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.all(8.0),
|
2021-09-22 19:26:06 +00:00
|
|
|
child: Text(
|
2021-10-02 02:46:44 +00:00
|
|
|
" MAIN MENU ",
|
2021-10-01 22:40:28 +00:00
|
|
|
style: TextStyle(
|
2021-10-09 18:32:15 +00:00
|
|
|
color: textColor,
|
2021-10-01 22:40:28 +00:00
|
|
|
fontSize: width * 0.03,
|
|
|
|
),
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
// ),
|
2021-10-06 18:22:57 +00:00
|
|
|
onPressed: () async {
|
2021-09-22 19:26:06 +00:00
|
|
|
// Go to the Main Menu
|
2024-05-24 15:14:17 +00:00
|
|
|
await FlameAudio.play('sfx/button_click.mp3');
|
2021-10-01 22:40:28 +00:00
|
|
|
game.mainMenu();
|
2021-09-22 19:26:06 +00:00
|
|
|
},
|
|
|
|
),
|
|
|
|
const SizedBox(
|
|
|
|
width: 32.0,
|
|
|
|
),
|
|
|
|
MaterialButton(
|
|
|
|
padding: const EdgeInsets.all(8.0),
|
|
|
|
elevation: 8.0,
|
|
|
|
child: Container(
|
|
|
|
decoration: const BoxDecoration(
|
2021-10-01 22:40:28 +00:00
|
|
|
image:
|
|
|
|
DecorationImage(image: buttonImage, fit: BoxFit.fill),
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
2021-10-01 22:40:28 +00:00
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.all(8.0),
|
2021-09-22 19:26:06 +00:00
|
|
|
child: Text(
|
2021-10-09 03:50:47 +00:00
|
|
|
" REPLAY${game.competitive ? " ${game.tries}" : ""} ",
|
2021-10-01 22:40:28 +00:00
|
|
|
style: TextStyle(
|
2021-10-09 03:50:47 +00:00
|
|
|
color: game.competitive && game.tries <= 0
|
2021-10-09 18:32:15 +00:00
|
|
|
? inactiveColor
|
|
|
|
: textColor,
|
2021-10-01 22:40:28 +00:00
|
|
|
fontSize: width * 0.03,
|
|
|
|
),
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
// ),
|
2021-10-09 03:50:47 +00:00
|
|
|
onPressed: game.competitive && game.tries <= 0
|
|
|
|
? null
|
|
|
|
: () async {
|
2024-05-24 15:14:17 +00:00
|
|
|
await FlameAudio.play('sfx/button_click.mp3');
|
|
|
|
game.runner.friend = await FlameAudio.loop(
|
|
|
|
'sfx/robot_friend_beep.mp3');
|
2021-10-09 03:50:47 +00:00
|
|
|
game.reset();
|
|
|
|
},
|
2021-09-22 19:26:06 +00:00
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|