firo_runner/lib/overlays/main_menu_overlay.dart

240 lines
10 KiB
Dart
Raw Normal View History

2021-10-05 23:22:01 +00:00
import 'package:flame_audio/flame_audio.dart';
import 'package:flutter/material.dart';
import '../main.dart';
2021-10-05 23:22:01 +00:00
class MainMenuOverlay extends StatelessWidget {
const MainMenuOverlay({
Key? key,
required this.game,
}) : super(key: key);
final MyGame game;
@override
Widget build(BuildContext context) {
double width = MediaQuery.of(context).size.width;
return Center(
child: Container(
2024-05-24 15:14:17 +00:00
height: game.canvasSize.y,
width: game.canvasSize.x,
2021-10-05 23:22:01 +00:00
decoration: const BoxDecoration(
image: DecorationImage(
image: mainMenuImage,
fit: BoxFit.fitWidth,
),
),
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: NO_TOURNAMENT
? MainAxisAlignment.spaceEvenly
: MainAxisAlignment.start,
2021-10-05 23:22:01 +00:00
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Column(
crossAxisAlignment: CrossAxisAlignment.start,
2021-10-05 23:22:01 +00:00
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
const SizedBox(
height: 16.0,
),
const SizedBox(
height: 16.0,
),
const SizedBox(
height: 16.0,
),
Row(
children: [
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: buttonImage, fit: BoxFit.fill),
),
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Text(
" START ",
style: TextStyle(
2021-10-09 18:32:15 +00:00
color: textColor,
fontSize: width * 0.025,
),
),
2021-10-05 23:22:01 +00:00
),
),
onPressed: () async {
// Go to the Main Menu
2024-05-24 15:14:17 +00:00
FlameAudio.play('sfx/menu_button.mp3');
game.competitive = false;
game.reset();
2024-05-24 15:14:17 +00:00
game.runner.boost =
FlameAudio.play('sfx/laser.mp3', volume: 0.0);
FlameAudio.bgm.stop();
FlameAudio.bgm.play('Infinite_Spankage_M.mp3');
2024-05-24 15:14:17 +00:00
game.runner.friend = await FlameAudio.loop(
'sfx/robot_friend_beep.mp3',
2024-05-24 15:14:17 +00:00
volume: 0.25);
},
2021-10-05 23:22:01 +00:00
),
],
2021-10-05 23:22:01 +00:00
),
NO_TOURNAMENT
? const SizedBox(
height: 16.0,
)
: Row(
children: [
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: buttonImage, fit: BoxFit.fill),
),
child: Padding(
2021-10-09 18:32:15 +00:00
padding: const EdgeInsets.all(8.0),
child: Text(
" DEPOSIT ",
style: TextStyle(
color: game.username == ""
2021-10-09 18:32:15 +00:00
? inactiveColor
: textColor,
fontSize: width * 0.025,
),
),
),
),
onPressed: game.username == ""
? null
: () async {
game.address = await game.connectServer(
"deposit", "user=${game.username}");
2024-05-24 15:14:17 +00:00
FlameAudio.play('sfx/button_click.mp3');
game.overlays.add("deposit");
},
),
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: buttonImage, fit: BoxFit.fill),
),
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Text(
" TOURNAMENT ${game.tries} ",
style: TextStyle(
color:
game.username == "" || game.tries == 0
2021-10-09 18:32:15 +00:00
? inactiveColor
: textColor,
fontSize: width * 0.025,
),
),
),
),
onPressed: game.username == "" || game.tries == 0
? null
: () async {
// Go to the Main Menu
2024-05-24 15:14:17 +00:00
FlameAudio.play('sfx/menu_button.mp3');
game.runner.boost = FlameAudio.play(
'sfx/laser.mp3',
volume: 0.0);
game.competitive = true;
game.reset();
FlameAudio.bgm.stop();
FlameAudio.bgm
.play('Infinite_Spankage_M.mp3');
2024-05-24 15:14:17 +00:00
game.runner.friend = await FlameAudio.loop(
'sfx/robot_friend_beep.mp3',
volume: 0.25);
},
),
],
),
NO_TOURNAMENT
? const SizedBox(
height: 16.0,
)
: Row(
children: [
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: buttonImage, fit: BoxFit.fill),
),
child: Padding(
2021-10-09 18:32:15 +00:00
padding: const EdgeInsets.all(8.0),
child: Text(
" ${game.username == "" ? "SIGN IN" : game.username} ",
style: TextStyle(
2021-10-09 18:32:15 +00:00
color: textColor,
fontSize: width * 0.025,
),
),
),
),
onPressed: () async {
2024-05-24 15:14:17 +00:00
FlameAudio.play('sfx/button_click.mp3');
game.overlays.add("signin");
},
),
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: buttonImage, fit: BoxFit.fill),
),
child: Padding(
2021-10-09 18:32:15 +00:00
padding: const EdgeInsets.all(8.0),
child: Text(
" LEADER BOARD ",
style: TextStyle(
2021-10-09 18:32:15 +00:00
color: textColor,
fontSize: width * 0.025,
),
),
),
),
onPressed: () async {
game.leaderboard = await game.connectServer(
"leaderboard", "user=value");
2024-05-24 15:14:17 +00:00
FlameAudio.play('sfx/button_click.mp3');
game.overlays.add("leaderboard");
},
),
],
),
2021-10-05 23:22:01 +00:00
],
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
],
),
),
);
}
}