mirror of https://github.com/flutter/pinball.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
2.2 KiB
91 lines
2.2 KiB
// ignore_for_file: public_member_api_docs
|
|
|
|
import 'package:flame/game.dart';
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:pinball/game/game.dart';
|
|
import 'package:pinball_theme/pinball_theme.dart';
|
|
|
|
class PinballGamePage extends StatelessWidget {
|
|
const PinballGamePage({Key? key, required this.theme}) : super(key: key);
|
|
|
|
final PinballTheme theme;
|
|
|
|
static Route route({required PinballTheme theme}) {
|
|
return MaterialPageRoute<void>(
|
|
builder: (_) {
|
|
return BlocProvider(
|
|
create: (_) => GameBloc(),
|
|
child: PinballGamePage(theme: theme),
|
|
);
|
|
},
|
|
);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return PinballGameView(theme: theme);
|
|
}
|
|
}
|
|
|
|
class PinballGameView extends StatefulWidget {
|
|
const PinballGameView({
|
|
Key? key,
|
|
required this.theme,
|
|
bool isDebugMode = kDebugMode,
|
|
}) : _isDebugMode = isDebugMode,
|
|
super(key: key);
|
|
|
|
final PinballTheme theme;
|
|
final bool _isDebugMode;
|
|
|
|
@override
|
|
State<PinballGameView> createState() => _PinballGameViewState();
|
|
}
|
|
|
|
class _PinballGameViewState extends State<PinballGameView> {
|
|
late PinballGame _game;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
|
|
// TODO(erickzanardo): Revisit this when we start to have more assets
|
|
// this could expose a Stream (maybe even a cubit?) so we could show the
|
|
// the loading progress with some fancy widgets.
|
|
_game = (widget._isDebugMode
|
|
? DebugPinballGame(theme: widget.theme)
|
|
: PinballGame(theme: widget.theme))
|
|
..preLoadAssets();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return BlocListener<GameBloc, GameState>(
|
|
listener: (context, state) {
|
|
if (state.isGameOver) {
|
|
showDialog<void>(
|
|
context: context,
|
|
builder: (_) {
|
|
return const GameOverDialog();
|
|
},
|
|
);
|
|
}
|
|
},
|
|
child: Stack(
|
|
children: [
|
|
Positioned.fill(
|
|
child: GameWidget<PinballGame>(game: _game),
|
|
),
|
|
const Positioned(
|
|
top: 8,
|
|
left: 8,
|
|
child: GameHud(),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|