staging #20

Merged
marco merged 52 commits from staging into master 2021-10-09 18:48:59 +00:00
5 changed files with 164 additions and 11 deletions
Showing only changes of commit 35f5d4a79b - Show all commits

BIN
assets/images/button.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 116 KiB

View File

@ -91,6 +91,14 @@ class GameState extends Component {
return distance ~/ 10 + numCoins * 1000000; return distance ~/ 10 + numCoins * 1000000;
} }
int getPlayerScore() {
return getScore() ~/ 10000;
}
int getPlayerDistance() {
return distance ~/ 1000000;
}
double getVelocity() { double getVelocity() {
if (!isPaused) { if (!isPaused) {
switch (getLevel()) { switch (getLevel()) {

View File

@ -0,0 +1,88 @@
import 'package:flutter/material.dart';
import 'main.dart';
class LoseMenuOverlay extends StatelessWidget {
const LoseMenuOverlay({
Key? key,
required this.game,
}) : super(key: key);
final MyGame game;
@override
Widget build(BuildContext context) {
return Center(
child: Container(
height: game.viewport.canvasSize.y,
width: game.viewport.canvasSize.x,
decoration: const BoxDecoration(
image: DecorationImage(
image: AssetImage('assets/images/overlay100.png'),
fit: BoxFit.fill,
),
),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
'Score: ' + game.gameState.getPlayerScore().toString(),
style: overlayText,
),
const SizedBox(height: 32.0),
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
MaterialButton(
padding: const EdgeInsets.all(8.0),
textColor: Colors.white,
splashColor: Colors.greenAccent,
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: AssetImage('assets/images/button.png'),
fit: BoxFit.fill),
),
child: const Padding(
padding: EdgeInsets.all(8.0),
child: Text("Main Menu"),
),
),
// ),
onPressed: () {
// Go to the Main Menu
},
),
const SizedBox(
width: 32.0,
),
MaterialButton(
padding: const EdgeInsets.all(8.0),
textColor: Colors.white,
splashColor: Colors.greenAccent,
elevation: 8.0,
child: Container(
decoration: const BoxDecoration(
image: DecorationImage(
image: AssetImage('assets/images/button.png'),
fit: BoxFit.fill),
),
child: const Padding(
padding: EdgeInsets.all(8.0),
child: Text("Replay"),
),
),
// ),
onPressed: () {
game.reset();
},
),
],
),
],
),
),
);
}
}

View File

@ -24,6 +24,8 @@ import 'package:flutter/services.dart';
import 'package:firo_runner/runner.dart'; import 'package:firo_runner/runner.dart';
import 'package:flutter/foundation.dart' show kIsWeb; import 'package:flutter/foundation.dart' show kIsWeb;
import 'package:firo_runner/lose_menu_overlay.dart';
const COLOR = Color(0xFFDDC0A3); const COLOR = Color(0xFFDDC0A3);
const LEVEL2 = 10000000; const LEVEL2 = 10000000;
@ -33,6 +35,7 @@ const LEVEL5 = 40000000;
const LEVEL6 = 50000000; const LEVEL6 = 50000000;
const LEVEL7 = 60000000; const LEVEL7 = 60000000;
const OVERLAY_PRIORITY = 110;
const RUNNER_PRIORITY = 100; const RUNNER_PRIORITY = 100;
const BUG_PRIORITY = 75; const BUG_PRIORITY = 75;
const COIN_PRIORITY = 70; const COIN_PRIORITY = 70;
@ -43,12 +46,24 @@ const WIRE_PRIORITY = 25;
const FIREWORK_PRIORITY = 15; const FIREWORK_PRIORITY = 15;
const WINDOW_PRIORITY = 10; const WINDOW_PRIORITY = 10;
const overlayText = TextStyle(
fontSize: 30,
color: Colors.white,
);
void main() async { void main() async {
WidgetsFlutterBinding.ensureInitialized(); WidgetsFlutterBinding.ensureInitialized();
await Flame.device.fullScreen(); await Flame.device.fullScreen();
await Flame.device.setLandscape(); await Flame.device.setLandscape();
final myGame = MyGame(); final myGame = MyGame();
runApp(GameWidget(game: myGame)); runApp(GameWidget<MyGame>(
game: myGame,
overlayBuilderMap: {
'gameOver': (_, myGame) {
return LoseMenuOverlay(game: myGame);
},
},
));
} }
int getNearestPlatform(int level) { int getNearestPlatform(int level) {
@ -67,6 +82,10 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
fontSize: 48.0, fontFamily: 'Codystar', color: COLOR), fontSize: 48.0, fontFamily: 'Codystar', color: COLOR),
); );
TextPaint scoresPaint = TextPaint(
config: const TextPaintConfig(fontSize: 16.0, color: COLOR),
);
late CircuitBackground circuitBackground; late CircuitBackground circuitBackground;
late PlatformHolder platformHolder; late PlatformHolder platformHolder;
late CoinHolder coinHolder; late CoinHolder coinHolder;
@ -83,15 +102,15 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
late double blockSize; late double blockSize;
bool loaded = false; bool loaded = false;
bool firstDeath = true;
late Wire wire; late Wire wire;
late TextComponent _distance;
late TextComponent _coins;
MyGame() : super() { MyGame() : super() {
viewport.resize(Vector2(1920, 1080)); viewport.resize(Vector2(1920, 1080));
} }
// @override
// flame.Viewport viewport = FixedResolutionViewport(Vector2(1920, 1080));
@override @override
Future<void> onLoad() async { Future<void> onLoad() async {
// debugMode = true; // debugMode = true;
@ -123,6 +142,14 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
playMusic(); playMusic();
} }
loaded = true; loaded = true;
_distance = TextComponent("Distance: 0",
position: Vector2(size.x - 100, 10), textRenderer: scoresPaint)
..anchor = Anchor.topRight;
_distance.changePriorityWithoutResorting(OVERLAY_PRIORITY);
_coins = TextComponent("Coins: 0",
position: Vector2(size.x - 10, 10), textRenderer: scoresPaint)
..anchor = Anchor.topRight;
_coins.changePriorityWithoutResorting(OVERLAY_PRIORITY);
setUp(); setUp();
} }
@ -217,12 +244,19 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
bool shouldReset = false; bool shouldReset = false;
void reset() { void displayLoss() {
if (!(runner.sprite.animation?.done() ?? false) && if (!(runner.sprite.animation?.done() ?? false) &&
runner.sprite.animation!.loop == false) { runner.sprite.animation!.loop == false &&
firstDeath) {
return; return;
} }
firstDeath = false;
overlays.add('gameOver');
}
void reset() {
runner.sprite.animation!.reset(); runner.sprite.animation!.reset();
overlays.remove('gameOver');
shouldReset = false; shouldReset = false;
components.clear(); components.clear();
setUp(); setUp();
@ -249,6 +283,8 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
gameState.setUp(this); gameState.setUp(this);
runner.setUp(); runner.setUp();
add(_coins);
add(_distance);
fillScreen(); fillScreen();
platformHolder.objects[2][0].sprite.current = PlatformState.left; platformHolder.objects[2][0].sprite.current = PlatformState.left;
@ -287,8 +323,11 @@ class MyGame extends BaseGame with PanDetector, TapDetector, KeyboardEvents {
bugHolder.update(dt); bugHolder.update(dt);
debrisHolder.update(dt); debrisHolder.update(dt);
wallHolder.update(dt); wallHolder.update(dt);
if (shouldReset) {
reset(); _distance.text = "Distance: ${gameState.getPlayerDistance()}";
_coins.text = "Coins: ${gameState.numCoins}";
if (shouldReset && !overlays.isActive('gameOver')) {
displayLoss();
} }
} }

View File

@ -164,7 +164,13 @@ class Runner extends Component with HasGameRef<MyGame> {
return; return;
} }
sprite.clearEffects(); sprite.clearEffects();
updateLevel(); level = 11;
sprite.addEffect(MoveEffect(
path: [Vector2(sprite.position.x, gameRef.blockSize * 11)],
duration: 2,
curve: Curves.bounceOut,
onComplete: () {},
));
runnerState = event; runnerState = event;
sprite.current = RunnerState.die; sprite.current = RunnerState.die;
gameRef.die(); gameRef.die();
@ -174,7 +180,13 @@ class Runner extends Component with HasGameRef<MyGame> {
return; return;
} }
sprite.clearEffects(); sprite.clearEffects();
updateLevel(); level = 11;
sprite.addEffect(MoveEffect(
path: [Vector2(sprite.position.x, gameRef.blockSize * 11)],
duration: 1,
curve: Curves.bounceOut,
onComplete: () {},
));
runnerState = event; runnerState = event;
sprite.current = RunnerState.electrocute; sprite.current = RunnerState.electrocute;
gameRef.die(); gameRef.die();
@ -184,7 +196,13 @@ class Runner extends Component with HasGameRef<MyGame> {
return; return;
} }
sprite.clearEffects(); sprite.clearEffects();
updateLevel(); level = 11;
sprite.addEffect(MoveEffect(
path: [Vector2(sprite.position.x, gameRef.blockSize * 11)],
duration: 1,
curve: Curves.bounceOut,
onComplete: () {},
));
runnerState = event; runnerState = event;
sprite.current = RunnerState.glitch; sprite.current = RunnerState.glitch;
gameRef.die(); gameRef.die();