/**
* @author Chris Campbell
* @author Richard Davey
* @copyright 2015 Photon Storm Ltd.
* @license {@link http://choosealicense.com/licenses/no-license/|No License}
*
* @description This example requires the Phaser Box2D Plugin to run.
* For more details please see http://phaser.io/shop/plugins/box2d
*/
var game = new Phaser.Game(800, 600, Phaser.CANVAS, 'phaser-example', { preload: preload, create: create, update: update, render: render });
function preload() {
game.load.image('a', 'assets/sprites/a.png');
game.load.image('b', 'assets/sprites/b.png');
}
var codeCaption;
var bodyAs = [];
function create() {
game.stage.backgroundColor = '#124184';
// Enable Box2D physics
game.physics.startSystem(Phaser.Physics.BOX2D);
game.physics.box2d.debugDraw.joints = true;
game.physics.box2d.gravity.y = 500;
// Simple case with joint anchors at the center of each sprite, and
// using the position of the sprites to determine the joint length.
{
// Dynamic box A
var spriteA = game.add.sprite(300, 300, 'a');
game.physics.box2d.enable(spriteA);
// Dynamic box B
var spriteB = game.add.sprite(500, 300, 'b');
game.physics.box2d.enable(spriteB);
//bodyA, bodyB, ax, ay, bx, by, gax, gay, gbx, gby, ratio, lengthA, lengthB
game.physics.box2d.pulleyJoint(spriteA, spriteB, 0,0, 0,0, 300,200, 500,200 );
bodyAs.push(spriteA.body);
}
// Set up handlers for mouse events
game.input.onDown.add(mouseDragStart, this);
game.input.addMoveCallback(mouseDragMove, this);
game.input.onUp.add(mouseDragEnd, this);
game.add.text(5, 5, 'Pulley joint. Click to start.', { fill: '#ffffff', font: '14pt Arial' });
game.add.text(5, 25, 'Mouse over bodyA to see the code used to create the joint.', { fill: '#ffffff', font: '14pt Arial' });
codeCaption = game.add.text(5, 50, 'Parameters: bodyA, bodyB, ax, ay, bx, by, gax, gay, gbx, gby, ratio, lengthA, lengthB', { fill: '#dddddd', font: '10pt Arial' });
codeCaption = game.add.text(5, 65, '', { fill: '#ccffcc', font: '14pt Arial' });
// Start paused so user can see how the joints start out
game.paused = true;
game.input.onDown.add(function(){game.paused = false;}, this);
}
function mouseDragStart() { game.physics.box2d.mouseDragStart(game.input.mousePointer); }
function mouseDragMove() { game.physics.box2d.mouseDragMove(game.input.mousePointer); }
function mouseDragEnd() { game.physics.box2d.mouseDragEnd(); }
function update() {
if (bodyAs[0].containsPoint(game.input.mousePointer))
{
codeCaption.text = 'game.physics.box2d.pulleyJoint(spriteA, spriteB, 0,0, 0,0, 300,200, 500,200 )';
}
else
{
codeCaption.text = '';
}
}
function render() {
// update will not be called while paused, but we want to change the caption on mouse-over
if (game.paused)
{
update();
}
game.debug.box2dWorld();
}