Commit 9a21cbc7 authored by Viktor Lidholt's avatar Viktor Lidholt

Adds level labels to demo game

parent 3f2369db
...@@ -5,6 +5,7 @@ import 'dart:math' as math; ...@@ -5,6 +5,7 @@ import 'dart:math' as math;
import 'dart:sky' as sky; import 'dart:sky' as sky;
import 'package:sky/rendering/object.dart'; import 'package:sky/rendering/object.dart';
import 'package:sky/painting/text_style.dart';
import 'package:sky/widgets/framework.dart'; import 'package:sky/widgets/framework.dart';
import 'package:skysprites/skysprites.dart'; import 'package:skysprites/skysprites.dart';
import 'package:vector_math/vector_math.dart'; import 'package:vector_math/vector_math.dart';
......
...@@ -4,7 +4,7 @@ final double _gameSizeWidth = 320.0; ...@@ -4,7 +4,7 @@ final double _gameSizeWidth = 320.0;
double _gameSizeHeight = 320.0; double _gameSizeHeight = 320.0;
final double _chunkSpacing = 640.0; final double _chunkSpacing = 640.0;
final int _chunksPerLevel = 5; final int _chunksPerLevel = 6;
final bool _drawDebug = false; final bool _drawDebug = false;
...@@ -190,25 +190,22 @@ class GameDemoNode extends NodeWithSize { ...@@ -190,25 +190,22 @@ class GameDemoNode extends NodeWithSize {
} }
void addLevelChunk(int chunk, double yPos) { void addLevelChunk(int chunk, double yPos) {
if (chunk == 0) {
// Leave the first chunk empty
return;
}
chunk -= 1;
int level = chunk ~/ _chunksPerLevel; int level = chunk ~/ _chunksPerLevel;
int part = chunk % _chunksPerLevel; int part = chunk % _chunksPerLevel;
if (part == 0) { if (part == 0) {
_objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7)); LevelLabel lbl = new LevelLabel(_objectFactory, level + 1);
lbl.position = new Point(0.0, yPos + _chunkSpacing / 2.0 - 150.0);
_level.addChild(lbl);
} else if (part == 1) { } else if (part == 1) {
_objectFactory.addEnemyScoutSwarm(4 + level * 2, yPos);
} else if (part == 2) {
_objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7)); _objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7));
} else if (part == 2) {
_objectFactory.addEnemyScoutSwarm(4 + level * 2, yPos);
} else if (part == 3) { } else if (part == 3) {
_objectFactory.addEnemyDestroyerSwarm(2 + level, yPos); _objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7));
} else if (part == 4) { } else if (part == 4) {
_objectFactory.addEnemyDestroyerSwarm(2 + level, yPos);
} else if (part == 5) {
_objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7)); _objectFactory.addAsteroids(10 + level * 4, yPos, 0.0 + (level * 0.2).clamp(0.0, 0.7));
} }
} }
......
...@@ -86,6 +86,23 @@ abstract class GameObject extends Node { ...@@ -86,6 +86,23 @@ abstract class GameObject extends Node {
} }
} }
class LevelLabel extends GameObject {
LevelLabel(GameObjectFactory f, int level) : super(f) {
canDamageShip = false;
canBeDamaged = false;
Label lbl = new Label(
"LEVEL $level",
new TextStyle(
textAlign: TextAlign.center,
color:new Color(0xffffffff),
fontSize: 24.0,
fontWeight: FontWeight.w600
));
addChild(lbl);
}
}
class Ship extends GameObject { class Ship extends GameObject {
Ship(GameObjectFactory f) : super(f) { Ship(GameObjectFactory f) : super(f) {
// Add main ship sprite // Add main ship sprite
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment