Commit fde92a69 authored by Viktor Lidholt's avatar Viktor Lidholt

Improves physics debug drawing

parent 96689dec
...@@ -47,6 +47,10 @@ class PhysicsWorld extends Node { ...@@ -47,6 +47,10 @@ class PhysicsWorld extends Node {
List<PhysicsBody> _bodiesScheduledForUpdate = <PhysicsBody>[]; List<PhysicsBody> _bodiesScheduledForUpdate = <PhysicsBody>[];
bool drawDebug = false;
Matrix4 _debugDrawTransform ;
_PhysicsDebugDraw _debugDraw; _PhysicsDebugDraw _debugDraw;
double b2WorldToNodeConversionFactor = 10.0; double b2WorldToNodeConversionFactor = 10.0;
...@@ -228,8 +232,10 @@ class PhysicsWorld extends Node { ...@@ -228,8 +232,10 @@ class PhysicsWorld extends Node {
} }
void paint(PaintingCanvas canvas) { void paint(PaintingCanvas canvas) {
if (drawDebug) {
_debugDrawTransform = new Matrix4.fromFloat64List(canvas.getTotalMatrix());
}
super.paint(canvas); super.paint(canvas);
paintDebug(canvas);
} }
void paintDebug(PaintingCanvas canvas) { void paintDebug(PaintingCanvas canvas) {
......
...@@ -347,6 +347,14 @@ class SpriteBox extends RenderBox { ...@@ -347,6 +347,14 @@ class SpriteBox extends RenderBox {
Matrix4 totalMatrix = new Matrix4.fromFloat64List(canvas.getTotalMatrix()); Matrix4 totalMatrix = new Matrix4.fromFloat64List(canvas.getTotalMatrix());
_rootNode._visit(canvas, totalMatrix); _rootNode._visit(canvas, totalMatrix);
// Draw physics debug
for (PhysicsWorld world in _physicsNodes) {
if (world.drawDebug) {
canvas.setMatrix(world._debugDrawTransform.storage);
world.paintDebug(canvas);
}
}
canvas.restore(); canvas.restore();
} }
......
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