Commit 1eff5b8c authored by Viktor Lidholt's avatar Viktor Lidholt

Merge pull request #184 from vlidholt/master

Updates sprite widget to handle changes to renderbox
parents 310412fd 6c510fb5
{"frames": [
{
"filename": "bar_shield.png",
"frame": {"x":2,"y":954,"w":412,"h":100},
"rotated": false,
"trimmed": false,
"spriteSourceSize": {"x":0,"y":0,"w":412,"h":100},
"sourceSize": {"w":412,"h":100},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "bar_shield_fill.png",
"frame": {"x":2,"y":1156,"w":320,"h":72},
"rotated": false,
"trimmed": false,
"spriteSourceSize": {"x":0,"y":0,"w":320,"h":72},
"sourceSize": {"w":320,"h":72},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "btn_play_down.png",
"frame": {"x":2,"y":484,"w":468,"h":468},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":2,"y":16,"w":468,"h":468},
"sourceSize": {"w":472,"h":484},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "btn_play_up.png",
"frame": {"x":2,"y":2,"w":468,"h":480},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":2,"y":4,"w":468,"h":480},
"sourceSize": {"w":472,"h":484},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_0.png",
"frame": {"x":416,"y":954,"w":38,"h":63},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_1.png",
"frame": {"x":324,"y":1221,"w":16,"h":57},
"rotated": true,
"trimmed": true,
"spriteSourceSize": {"x":45,"y":25,"w":16,"h":57},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_2.png",
"frame": {"x":366,"y":1056,"w":38,"h":63},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_3.png",
"frame": {"x":364,"y":1156,"w":35,"h":63},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":26,"y":22,"w":35,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_4.png",
"frame": {"x":416,"y":1019,"w":38,"h":57},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":25,"w":38,"h":57},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_5.png",
"frame": {"x":324,"y":1156,"w":38,"h":63},
"rotated": false,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_6.png",
"frame": {"x":406,"y":1078,"w":38,"h":63},
"rotated": true,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_7.png",
"frame": {"x":401,"y":1198,"w":35,"h":60},
"rotated": true,
"trimmed": true,
"spriteSourceSize": {"x":26,"y":22,"w":35,"h":60},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_8.png",
"frame": {"x":406,"y":1118,"w":38,"h":63},
"rotated": true,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "number_9.png",
"frame": {"x":401,"y":1158,"w":38,"h":63},
"rotated": true,
"trimmed": true,
"spriteSourceSize": {"x":23,"y":22,"w":38,"h":63},
"sourceSize": {"w":84,"h":107},
"pivot": {"x":0.5,"y":0.5}
},
{
"filename": "scoreboard.png",
"frame": {"x":2,"y":1056,"w":362,"h":98},
"rotated": false,
"trimmed": false,
"spriteSourceSize": {"x":0,"y":0,"w":362,"h":98},
"sourceSize": {"w":362,"h":98},
"pivot": {"x":0.5,"y":0.5}
}],
"meta": {
"app": "http://www.codeandweb.com/texturepacker",
"version": "1.0",
"image": "game_ui.png",
"format": "RGBA8888",
"size": {"w":472,"h":1239},
"scale": "1",
"smartupdate": "$TexturePacker:SmartUpdate:02d6676bdde949110cbdc9a2c385b33a:6b0974f94eba9593dd9636cc730412b8:10ac111e32c27e51f4e8444dbb39eff6$"
}
}
This diff was suppressed by a .gitattributes entry.
...@@ -2,9 +2,11 @@ library game; ...@@ -2,9 +2,11 @@ library game;
import 'dart:sky' as sky; import 'dart:sky' as sky;
import 'dart:math' as Math; import 'dart:math' as Math;
import 'package:vector_math/vector_math_64.dart';
import 'package:sky/widgets/widget.dart';
import 'sprites.dart'; import 'sprites.dart';
import 'package:sky/rendering/object.dart'; import 'package:sky/rendering/object.dart';
import 'package:sky/widgets/widget.dart';
import 'package:sky/widgets/navigator.dart';
import 'package:vector_math/vector_math_64.dart';
part 'game_demo_world.dart'; part 'game_demo_world.dart';
...@@ -27,6 +27,7 @@ class GameDemoWorld extends NodeWithSize { ...@@ -27,6 +27,7 @@ class GameDemoWorld extends NodeWithSize {
sky.Image _imgNebula; sky.Image _imgNebula;
SpriteSheet _spriteSheet; SpriteSheet _spriteSheet;
Navigator _navigator;
// Inputs // Inputs
double _joystickX = 0.0; double _joystickX = 0.0;
...@@ -45,7 +46,7 @@ class GameDemoWorld extends NodeWithSize { ...@@ -45,7 +46,7 @@ class GameDemoWorld extends NodeWithSize {
int _numFrames = 0; int _numFrames = 0;
bool _isGameOver = false; bool _isGameOver = false;
GameDemoWorld(App app, ImageMap images, this._spriteSheet) : super(new Size(_gameSizeWidth, _gameSizeHeight)) { GameDemoWorld(App app, this._navigator, ImageMap images, this._spriteSheet) : super(new Size(_gameSizeWidth, _gameSizeHeight)) {
// Fetch images // Fetch images
_imgNebula = images["assets/nebula.png"]; _imgNebula = images["assets/nebula.png"];
...@@ -317,6 +318,8 @@ class GameDemoWorld extends NodeWithSize { ...@@ -317,6 +318,8 @@ class GameDemoWorld extends NodeWithSize {
// Add an explosion // Add an explosion
addExplosion(AsteroidSize.large, _ship.position); addExplosion(AsteroidSize.large, _ship.position);
_navigator.pop();
} }
// Handling controls // Handling controls
...@@ -588,6 +591,7 @@ class Nebula extends Node { ...@@ -588,6 +591,7 @@ class Nebula extends Node {
for (int i = 0; i < 2; i++) { for (int i = 0; i < 2; i++) {
for (int j = 0; j < 2; j++) { for (int j = 0; j < 2; j++) {
Sprite sprt = new Sprite.fromImage(img); Sprite sprt = new Sprite.fromImage(img);
sprt.transferMode = sky.TransferMode.plus;
sprt.pivot = Point.origin; sprt.pivot = Point.origin;
sprt.position = new Point(i * _gameSizeWidth - _gameSizeWidth, j * _gameSizeHeight - _gameSizeHeight); sprt.position = new Point(i * _gameSizeWidth - _gameSizeWidth, j * _gameSizeHeight - _gameSizeHeight);
addChild(sprt); addChild(sprt);
......
...@@ -28,6 +28,19 @@ class SpriteBox extends RenderBox { ...@@ -28,6 +28,19 @@ class SpriteBox extends RenderBox {
// Root node for drawing // Root node for drawing
NodeWithSize _rootNode; NodeWithSize _rootNode;
void set rootNode (NodeWithSize value) {
if (value == _rootNode) return;
// Remove sprite box references
if (_rootNode != null) _removeSpriteBoxReference(_rootNode);
// Update the value
_rootNode = value;
// Add new references
_addSpriteBoxReference(_rootNode);
}
// Tracking of frame rate and updates // Tracking of frame rate and updates
double _lastTimeStamp; double _lastTimeStamp;
int _numFrames = 0; int _numFrames = 0;
...@@ -36,6 +49,15 @@ class SpriteBox extends RenderBox { ...@@ -36,6 +49,15 @@ class SpriteBox extends RenderBox {
// Transformation mode // Transformation mode
SpriteBoxTransformMode _transformMode; SpriteBoxTransformMode _transformMode;
void set transformMode (SpriteBoxTransformMode value) {
if (value == _transformMode)
return;
_transformMode = value;
// Invalidate stuff
if (attached) performLayout();
}
/// The transform mode used by the [SpriteBox]. /// The transform mode used by the [SpriteBox].
SpriteBoxTransformMode get transformMode => _transformMode; SpriteBoxTransformMode get transformMode => _transformMode;
...@@ -44,6 +66,10 @@ class SpriteBox extends RenderBox { ...@@ -44,6 +66,10 @@ class SpriteBox extends RenderBox {
List<Node> _eventTargets; List<Node> _eventTargets;
Rect _visibleArea;
Rect get visibleArea => _visibleArea;
// Setup // Setup
/// Creates a new SpriteBox with a node as its content, by default uses letterboxing. /// Creates a new SpriteBox with a node as its content, by default uses letterboxing.
...@@ -58,15 +84,17 @@ class SpriteBox extends RenderBox { ...@@ -58,15 +84,17 @@ class SpriteBox extends RenderBox {
assert(rootNode._spriteBox == null); assert(rootNode._spriteBox == null);
// Setup root node // Setup root node
_rootNode = rootNode; this.rootNode = rootNode;
// Assign SpriteBox reference to all the nodes
_addSpriteBoxReference(_rootNode);
// Setup transform mode // Setup transform mode
_transformMode = mode; this.transformMode = mode;
}
_scheduleTick(); void _removeSpriteBoxReference(Node node) {
node._spriteBox = null;
for (Node child in node._children) {
_removeSpriteBoxReference(child);
}
} }
void _addSpriteBoxReference(Node node) { void _addSpriteBoxReference(Node node) {
...@@ -76,6 +104,11 @@ class SpriteBox extends RenderBox { ...@@ -76,6 +104,11 @@ class SpriteBox extends RenderBox {
} }
} }
void attach() {
super.attach();
_scheduleTick();
}
// Properties // Properties
/// The root node of the node tree that is rendered by this box. /// The root node of the node tree that is rendered by this box.
...@@ -271,6 +304,7 @@ class SpriteBox extends RenderBox { ...@@ -271,6 +304,7 @@ class SpriteBox extends RenderBox {
} }
void _tick(double timeStamp) { void _tick(double timeStamp) {
if (!attached) return;
// Calculate the time between frames in seconds // Calculate the time between frames in seconds
if (_lastTimeStamp == null) _lastTimeStamp = timeStamp; if (_lastTimeStamp == null) _lastTimeStamp = timeStamp;
......
...@@ -31,8 +31,7 @@ class SpriteWidget extends OneChildRenderObjectWrapper { ...@@ -31,8 +31,7 @@ class SpriteWidget extends OneChildRenderObjectWrapper {
void syncRenderObject(SpriteWidget old) { void syncRenderObject(SpriteWidget old) {
super.syncRenderObject(old); super.syncRenderObject(old);
// SpriteBox doesn't allow mutation of these properties root.rootNode = rootNode;
assert(rootNode == root.rootNode); root.transformMode = transformMode;
assert(transformMode == root._transformMode);
} }
} }
...@@ -5,6 +5,8 @@ ...@@ -5,6 +5,8 @@
import 'package:sky/mojo/asset_bundle.dart'; import 'package:sky/mojo/asset_bundle.dart';
import 'package:sky/theme/colors.dart' as colors; import 'package:sky/theme/colors.dart' as colors;
import 'package:sky/widgets/basic.dart'; import 'package:sky/widgets/basic.dart';
import 'package:sky/widgets/raised_button.dart';
import 'package:sky/widgets/navigator.dart';
import 'package:sky/widgets/widget.dart'; import 'package:sky/widgets/widget.dart';
import 'package:sky/widgets/task_description.dart'; import 'package:sky/widgets/task_description.dart';
import 'package:sky/widgets/theme.dart'; import 'package:sky/widgets/theme.dart';
...@@ -22,6 +24,7 @@ final AssetBundle _bundle = _initBundle(); ...@@ -22,6 +24,7 @@ final AssetBundle _bundle = _initBundle();
ImageMap _loader; ImageMap _loader;
SpriteSheet _spriteSheet; SpriteSheet _spriteSheet;
SpriteSheet _spriteSheetUI;
GameDemoApp _app; GameDemoApp _app;
main() async { main() async {
...@@ -31,10 +34,15 @@ main() async { ...@@ -31,10 +34,15 @@ main() async {
'assets/nebula.png', 'assets/nebula.png',
'assets/sprites.png', 'assets/sprites.png',
'assets/starfield.png', 'assets/starfield.png',
'assets/game_ui.png',
]); ]);
String json = await _bundle.loadString('assets/sprites.json'); String json = await _bundle.loadString('assets/sprites.json');
_spriteSheet = new SpriteSheet(_loader['assets/sprites.png'], json); _spriteSheet = new SpriteSheet(_loader['assets/sprites.png'], json);
json = await _bundle.loadString('assets/game_ui.json');
_spriteSheetUI = new SpriteSheet(_loader["assets/game_ui.png"], json);
_app = new GameDemoApp(); _app = new GameDemoApp();
runApp(_app); runApp(_app);
...@@ -42,6 +50,22 @@ main() async { ...@@ -42,6 +50,22 @@ main() async {
class GameDemoApp extends App { class GameDemoApp extends App {
NavigationState _navigationState;
void initState() {
_navigationState = new NavigationState([
new Route(
name: '/',
builder: _buildMainScene
),
new Route(
name: '/game',
builder: _buildGameScene
),
]);
super.initState();
}
Widget build() { Widget build() {
// TODO(viktork): The task bar purple is the wrong purple, we may need // TODO(viktork): The task bar purple is the wrong purple, we may need
// a custom theme swatch to match the purples in the sprites. // a custom theme swatch to match the purples in the sprites.
...@@ -54,9 +78,22 @@ class GameDemoApp extends App { ...@@ -54,9 +78,22 @@ class GameDemoApp extends App {
data: theme, data: theme,
child: new TaskDescription( child: new TaskDescription(
label: 'Asteroids', label: 'Asteroids',
child: new SpriteWidget( child: new Navigator(_navigationState)
new GameDemoWorld(_app, _loader, _spriteSheet)
) )
);
}
Widget _buildGameScene(navigator, route) {
return new SpriteWidget(
new GameDemoWorld(_app, navigator, _loader, _spriteSheet)
);
}
Widget _buildMainScene(navigator, route) {
return new Center(
child: new RaisedButton(
child: new Text("Play"),
onPressed: () => navigator.pushNamed('/game')
) )
); );
} }
......
...@@ -3,3 +3,5 @@ assets: ...@@ -3,3 +3,5 @@ assets:
- assets/sprites.json - assets/sprites.json
- assets/sprites.png - assets/sprites.png
- assets/starfield.png - assets/starfield.png
- assets/game_ui.png
- assets/game_ui.json
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