firo_runner/lib/main_menu_overlay.dart

155 lines
5.6 KiB
Dart

import 'package:flame_audio/flame_audio.dart';
import 'package:flutter/material.dart';
import 'package:audioplayers/src/api/player_mode.dart';
import 'main.dart';
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(
height: game.viewport.canvasSize.y,
width: game.viewport.canvasSize.x,
decoration: const BoxDecoration(
image: DecorationImage(
image: mainMenuImage,
fit: BoxFit.fitWidth,
),
),
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
// const SizedBox(
// height: 32.0,
// ),
// const SizedBox(
// height: 32.0,
// ),
// const SizedBox(
// height: 32.0,
// ),
MaterialButton(
padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
textColor: Colors.white,
splashColor: Colors.greenAccent,
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(
color: Colors.cyan,
fontSize: width * 0.03,
),
),
),
),
// ),
onPressed: () async {
// Go to the Main Menu
FlameAudio.audioCache.play('sfx/menu_button.mp3',
mode: PlayerMode.LOW_LATENCY);
game.reset();
FlameAudio.bgm.stop();
FlameAudio.bgm.play('Infinite_Spankage_M.mp3');
game.runner.friend = await FlameAudio.audioCache.loop(
'sfx/robot_friend_beep.mp3',
volume: 0.25,
mode: PlayerMode.LOW_LATENCY);
},
),
// MaterialButton(
// padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
// textColor: Colors.white,
// splashColor: Colors.greenAccent,
// elevation: 8.0,
// child: Container(
// decoration: const BoxDecoration(
// image:
// DecorationImage(image: buttonImage, fit: BoxFit.fill),
// ),
// child: Padding(
// padding: EdgeInsets.all(8.0),
// child: Text(
// " DEPOSIT ",
// style: TextStyle(
// color: Colors.cyan,
// fontSize: width * 0.03,
// ),
// ),
// ),
// ),
// // ),
// onPressed: () {
// // Show QR code
// await FlameAudio.audioCache.play('sfx/button_click.mp3', mode: PlayerMode.LOW_LATENCY);
// },
// ),
// MaterialButton(
// padding: const EdgeInsets.fromLTRB(8, 8, 8, 8),
// textColor: Colors.white,
// splashColor: Colors.greenAccent,
// elevation: 8.0,
// child: Container(
// decoration: const BoxDecoration(
// image:
// DecorationImage(image: buttonImage, fit: BoxFit.fill),
// ),
// child: Padding(
// padding: EdgeInsets.all(8.0),
// child: Text(
// " LEADER BOARD ",
// style: TextStyle(
// color: Colors.cyan,
// fontSize: width * 0.03,
// ),
// ),
// ),
// ),
// // ),
// onPressed: () {
// // Show QR code
// await FlameAudio.audioCache.play('sfx/button_click.mp3', mode: PlayerMode.LOW_LATENCY);
// },
// ),
],
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
const SizedBox(
width: 32.0,
),
],
),
),
);
}
}