Difference between revisions of "B2.createMouseJointDef"

From GiderosMobile
Line 1: Line 1:
 
__NOTOC__
 
__NOTOC__
'''Available since:''' Gideros 2011.6<br/>
+
'''<translate>Available since</translate>:''' Gideros 2011.6<br/>
=== Description ===
+
=== <translate>Description</translate> ===
 
<translate><br />
 
<translate><br />
 
Creates and returns a mouse joint definition table with the bodies, world target point, maxForce and optional frequencyHz and dampingRatio.<br />
 
Creates and returns a mouse joint definition table with the bodies, world target point, maxForce and optional frequencyHz and dampingRatio.<br />
Line 9: Line 9:
 
(table) = b2.createMouseJointDef(bodyA,bodyB,targetx,targety,maxForce,frequencyHz,dampingRatio)
 
(table) = b2.createMouseJointDef(bodyA,bodyB,targetx,targety,maxForce,frequencyHz,dampingRatio)
 
</source>
 
</source>
=== Parameters ===
+
=== <translate>Parameters</translate> ===
 
'''bodyA''': (b2.Body) <translate>the first attached body</translate> <br/>
 
'''bodyA''': (b2.Body) <translate>the first attached body</translate> <br/>
 
'''bodyB''': (b2.Body) <translate>the second attached body</translate> <br/>
 
'''bodyB''': (b2.Body) <translate>the second attached body</translate> <br/>
Line 17: Line 17:
 
'''frequencyHz''': (number, default = 5) <translate>the response speed</translate> <br/>
 
'''frequencyHz''': (number, default = 5) <translate>the response speed</translate> <br/>
 
'''dampingRatio''': (number, default = 0.7) <translate>the damping ratio. 0 = no damping, 1 = critical damping</translate> <br/>
 
'''dampingRatio''': (number, default = 0.7) <translate>the damping ratio. 0 = no damping, 1 = critical damping</translate> <br/>
=== Return values ===
+
=== <translate>Return values</translate> ===
'''Returns''' (table) <translate>A new mouse joint definition table</translate><br/>
+
'''<translate>Returns</translate>''' (table) <translate>A new mouse joint definition table</translate><br/>
=== Examples ===
+
=== <translate>Examples</translate> ===
 
'''Mouse joint'''<br/>
 
'''Mouse joint'''<br/>
 
<source lang="lua">--create empty box2d body for joint
 
<source lang="lua">--create empty box2d body for joint

Revision as of 07:28, 24 August 2018

Available since: Gideros 2011.6

Description


Creates and returns a mouse joint definition table with the bodies, world target point, maxForce and optional frequencyHz and dampingRatio.
(Please refer to b2.World:createJoint function for more information about all the information needed to create a mouse joint).

(table) = b2.createMouseJointDef(bodyA,bodyB,targetx,targety,maxForce,frequencyHz,dampingRatio)

Parameters

bodyA: (b2.Body) the first attached body
bodyB: (b2.Body) the second attached body
targetx: (number) the x coordinate of the world target point
targety: (number) the y coordinate of the world target point
maxForce: (number) the maximum constraint force that can be exerted to move the candidate body
frequencyHz: (number, default = 5) the response speed
dampingRatio: (number, default = 0.7) the damping ratio. 0 = no damping, 1 = critical damping

Return values

Returns (table) A new mouse joint definition table

Examples

Mouse joint

--create empty box2d body for joint
local ground = world:createBody({})

--joint with dummy body
local mouseJoint = nil

-- create a mouse joint on mouse down
function self:onMouseDown(event)
	local jointDef = b2.createMouseJointDef(ground, body, event.x, event.y, 100000)
	mouseJoint = world:createJoint(jointDef)
end

-- update the target of mouse joint on mouse move
function self:onMouseMove(event)
	if mouseJoint ~= nil then
		mouseJoint:setTarget(event.x, event.y)
	end
end

-- destroy the mouse joint on mouse up
function self:onMouseUp(event)
	if mouseJoint ~= nil then
		world:destroyJoint(mouseJoint)
		mouseJoint = nil
	end
end