Difference between revisions of "B2.createMouseJointDef"
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