0
0
Fork 0
mirror of https://github.com/liabru/matter-js.git synced 2024-11-30 10:20:52 -05:00

implemented render.bounds

This commit is contained in:
liabru 2014-05-01 13:40:15 +01:00
parent 38c541363a
commit 2a9d2613d6

View file

@ -28,6 +28,7 @@ var Render = {};
height: 600, height: 600,
background: '#fafafa', background: '#fafafa',
wireframeBackground: '#222', wireframeBackground: '#222',
hasBounds: false,
enabled: true, enabled: true,
wireframes: true, wireframes: true,
showSleeping: true, showSleeping: true,
@ -50,6 +51,17 @@ var Render = {};
render.context = render.canvas.getContext('2d'); render.context = render.canvas.getContext('2d');
render.textures = {}; render.textures = {};
render.bounds = render.bounds || {
min: {
x: 0,
y: 0
},
max: {
x: render.options.width,
y: render.options.height
}
};
Render.setBackground(render, render.options.background); Render.setBackground(render, render.options.background);
if (Common.isElement(render.element)) { if (Common.isElement(render.element)) {
@ -101,8 +113,10 @@ var Render = {};
canvas = render.canvas, canvas = render.canvas,
context = render.context, context = render.context,
options = render.options, options = render.options,
bodies = Composite.allBodies(world), allBodies = Composite.allBodies(world),
constraints = Composite.allConstraints(world), allConstraints = Composite.allConstraints(world),
bodies = [],
constraints = [],
i; i;
if (options.wireframes) { if (options.wireframes) {
@ -117,8 +131,39 @@ var Render = {};
context.fillRect(0, 0, canvas.width, canvas.height); context.fillRect(0, 0, canvas.width, canvas.height);
context.globalCompositeOperation = 'source-over'; context.globalCompositeOperation = 'source-over';
/*if (options.showShadows && !options.wireframes) // handle bounds
Render.bodyShadows(engine, bodies, context);*/ if (options.hasBounds) {
// filter out bodies that are not in view
for (i = 0; i < allBodies.length; i++) {
var body = allBodies[i];
if (Bounds.overlaps(body.bounds, render.bounds))
bodies.push(body);
}
// filter out constraints that are not in view
for (i = 0; i < allConstraints.length; i++) {
var constraint = allConstraints[i],
bodyA = constraint.bodyA,
bodyB = constraint.bodyB,
pointAWorld = constraint.pointA,
pointBWorld = constraint.pointB;
if (bodyA) pointAWorld = Vector.add(bodyA.position, constraint.pointA);
if (bodyB) pointBWorld = Vector.add(bodyB.position, constraint.pointB);
if (!pointAWorld || !pointBWorld)
continue;
if (Bounds.contains(render.bounds, pointAWorld) || Bounds.contains(render.bounds, pointBWorld))
constraints.push(constraint);
}
// translate the view
context.translate(-render.bounds.min.x, -render.bounds.min.y);
} else {
constraints = allConstraints;
bodies = allBodies;
}
if (!options.wireframes || (engine.enableSleeping && options.showSleeping)) { if (!options.wireframes || (engine.enableSleeping && options.showSleeping)) {
// fully featured rendering of bodies // fully featured rendering of bodies
@ -153,6 +198,9 @@ var Render = {};
if (options.showDebug) if (options.showDebug)
Render.debug(engine, context); Render.debug(engine, context);
if (options.hasBounds)
context.translate(render.bounds.min.x, render.bounds.min.y);
}; };
/** /**
@ -699,9 +747,13 @@ var Render = {};
mouse = engine.input.mouse, mouse = engine.input.mouse,
selected = inspector.selected, selected = inspector.selected,
c = context, c = context,
options = engine.render.options, render = engine.render,
options = render.options,
bounds; bounds;
if (options.hasBounds)
context.translate(-render.bounds.min.x, -render.bounds.min.y);
for (var i = 0; i < selected.length; i++) { for (var i = 0; i < selected.length; i++) {
var item = selected[i].data; var item = selected[i].data;
@ -758,6 +810,9 @@ var Render = {};
context.fill(); context.fill();
context.translate(-0.5, -0.5); context.translate(-0.5, -0.5);
} }
if (options.hasBounds)
context.translate(render.bounds.min.x, render.bounds.min.y);
}; };
/** /**