MouseJoint.smali
.class public Lorg/jbox2d/dynamics/joints/MouseJoint;
.super Lorg/jbox2d/dynamics/joints/Joint;
.source "MouseJoint.java"
# static fields
.field static final synthetic $assertionsDisabled:Z
# instance fields
.field private final m_C:Lorg/jbox2d/common/Vec2;
.field private m_beta:F
.field private m_dampingRatio:F
.field private m_frequencyHz:F
.field private m_gamma:F
.field private final m_impulse:Lorg/jbox2d/common/Vec2;
.field private m_indexB:I
.field private m_invIB:F
.field private m_invMassB:F
.field private final m_localAnchorB:Lorg/jbox2d/common/Vec2;
.field private final m_localCenterB:Lorg/jbox2d/common/Vec2;
.field private final m_mass:Lorg/jbox2d/common/Mat22;
.field private m_maxForce:F
.field private final m_rB:Lorg/jbox2d/common/Vec2;
.field private final m_targetA:Lorg/jbox2d/common/Vec2;
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 43
const-class v0, Lorg/jbox2d/dynamics/joints/MouseJoint;
invoke-virtual {v0}, Ljava/lang/Class;->desiredAssertionStatus()Z
move-result v0
if-nez v0, :cond_c
const/4 v0, 0x1
:goto_9
sput-boolean v0, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
return-void
:cond_c
const/4 v0, 0x0
goto :goto_9
.end method
.method protected constructor <init>(Lorg/jbox2d/pooling/IWorldPool;Lorg/jbox2d/dynamics/joints/MouseJointDef;)V
.registers 7
.prologue
const/4 v3, 0x0
.line 66
invoke-direct {p0, p1, p2}, Lorg/jbox2d/dynamics/joints/Joint;-><init>(Lorg/jbox2d/pooling/IWorldPool;Lorg/jbox2d/dynamics/joints/JointDef;)V
.line 45
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localAnchorB:Lorg/jbox2d/common/Vec2;
.line 46
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
.line 52
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
.line 58
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
.line 59
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localCenterB:Lorg/jbox2d/common/Vec2;
.line 62
new-instance v0, Lorg/jbox2d/common/Mat22;
invoke-direct {v0}, Lorg/jbox2d/common/Mat22;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_mass:Lorg/jbox2d/common/Mat22;
.line 63
new-instance v0, Lorg/jbox2d/common/Vec2;
invoke-direct {v0}, Lorg/jbox2d/common/Vec2;-><init>()V
iput-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_C:Lorg/jbox2d/common/Vec2;
.line 67
sget-boolean v0, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
if-nez v0, :cond_47
iget-object v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->target:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0}, Lorg/jbox2d/common/Vec2;->isValid()Z
move-result v0
if-nez v0, :cond_47
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
.line 68
:cond_47
sget-boolean v0, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
if-nez v0, :cond_57
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->maxForce:F
cmpl-float v0, v0, v3
if-gez v0, :cond_57
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
.line 69
:cond_57
sget-boolean v0, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
if-nez v0, :cond_67
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->frequencyHz:F
cmpl-float v0, v0, v3
if-gez v0, :cond_67
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
.line 70
:cond_67
sget-boolean v0, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
if-nez v0, :cond_77
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->dampingRatio:F
cmpl-float v0, v0, v3
if-gez v0, :cond_77
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
.line 72
:cond_77
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
iget-object v1, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->target:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, v1}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 73
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
invoke-virtual {v0}, Lorg/jbox2d/dynamics/Body;->getTransform()Lorg/jbox2d/common/Transform;
move-result-object v0
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localAnchorB:Lorg/jbox2d/common/Vec2;
invoke-static {v0, v1, v2}, Lorg/jbox2d/common/Transform;->mulTransToOutUnsafe(Lorg/jbox2d/common/Transform;Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)V
.line 75
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->maxForce:F
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_maxForce:F
.line 76
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0}, Lorg/jbox2d/common/Vec2;->setZero()V
.line 78
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->frequencyHz:F
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_frequencyHz:F
.line 79
iget v0, p2, Lorg/jbox2d/dynamics/joints/MouseJointDef;->dampingRatio:F
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_dampingRatio:F
.line 81
iput v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_beta:F
.line 82
iput v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
.line 83
return-void
.end method
# virtual methods
.method public getAnchorA(Lorg/jbox2d/common/Vec2;)V
.registers 3
.prologue
.line 87
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
invoke-virtual {p1, v0}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 88
return-void
.end method
.method public getAnchorB(Lorg/jbox2d/common/Vec2;)V
.registers 4
.prologue
.line 92
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localAnchorB:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, v1, p1}, Lorg/jbox2d/dynamics/Body;->getWorldPointToOut(Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)V
.line 93
return-void
.end method
.method public getDampingRatio()F
.registers 2
.prologue
.line 141
iget v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_dampingRatio:F
return v0
.end method
.method public getFrequency()F
.registers 2
.prologue
.line 132
iget v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_frequencyHz:F
return v0
.end method
.method public getMaxForce()F
.registers 2
.prologue
.line 123
iget v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_maxForce:F
return v0
.end method
.method public getReactionForce(FLorg/jbox2d/common/Vec2;)V
.registers 4
.prologue
.line 97
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {p2, v0}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v0
invoke-virtual {v0, p1}, Lorg/jbox2d/common/Vec2;->mulLocal(F)Lorg/jbox2d/common/Vec2;
.line 98
return-void
.end method
.method public getReactionTorque(F)F
.registers 3
.prologue
.line 102
const/4 v0, 0x0
mul-float/2addr v0, p1
return v0
.end method
.method public getTarget()Lorg/jbox2d/common/Vec2;
.registers 2
.prologue
.line 114
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
return-object v0
.end method
.method public initVelocityConstraints(Lorg/jbox2d/dynamics/SolverData;)V
.registers 12
.prologue
const/4 v9, 0x1
.line 146
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
iget v0, v0, Lorg/jbox2d/dynamics/Body;->m_islandIndex:I
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
.line 147
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localCenterB:Lorg/jbox2d/common/Vec2;
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
iget-object v1, v1, Lorg/jbox2d/dynamics/Body;->m_sweep:Lorg/jbox2d/common/Sweep;
iget-object v1, v1, Lorg/jbox2d/common/Sweep;->localCenter:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, v1}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 148
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
iget v0, v0, Lorg/jbox2d/dynamics/Body;->m_invMass:F
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
.line 149
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
iget v0, v0, Lorg/jbox2d/dynamics/Body;->m_invI:F
iput v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
.line 151
iget-object v0, p1, Lorg/jbox2d/dynamics/SolverData;->positions:[Lorg/jbox2d/dynamics/contacts/Position;
iget v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v0, v0, v1
iget-object v0, v0, Lorg/jbox2d/dynamics/contacts/Position;->c:Lorg/jbox2d/common/Vec2;
.line 152
iget-object v1, p1, Lorg/jbox2d/dynamics/SolverData;->positions:[Lorg/jbox2d/dynamics/contacts/Position;
iget v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v1, v1, v2
iget v1, v1, Lorg/jbox2d/dynamics/contacts/Position;->a:F
.line 153
iget-object v2, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v2, v2, v3
iget-object v2, v2, Lorg/jbox2d/dynamics/contacts/Velocity;->v:Lorg/jbox2d/common/Vec2;
.line 154
iget-object v3, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v3, v3, v4
iget v3, v3, Lorg/jbox2d/dynamics/contacts/Velocity;->w:F
.line 156
iget-object v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v4}, Lorg/jbox2d/pooling/IWorldPool;->popRot()Lorg/jbox2d/common/Rot;
move-result-object v4
.line 158
invoke-virtual {v4, v1}, Lorg/jbox2d/common/Rot;->set(F)Lorg/jbox2d/common/Rot;
.line 160
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
invoke-virtual {v1}, Lorg/jbox2d/dynamics/Body;->getMass()F
move-result v1
.line 163
const v5, 0x40c90fdb
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_frequencyHz:F
mul-float/2addr v5, v6
.line 166
const/high16 v6, 0x40000000 # 2.0f
mul-float/2addr v6, v1
iget v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_dampingRatio:F
mul-float/2addr v6, v7
mul-float/2addr v6, v5
.line 169
mul-float/2addr v5, v5
mul-float/2addr v1, v5
.line 174
iget-object v5, p1, Lorg/jbox2d/dynamics/SolverData;->step:Lorg/jbox2d/dynamics/TimeStep;
iget v5, v5, Lorg/jbox2d/dynamics/TimeStep;->dt:F
.line 175
sget-boolean v7, Lorg/jbox2d/dynamics/joints/MouseJoint;->$assertionsDisabled:Z
if-nez v7, :cond_73
mul-float v7, v5, v1
add-float/2addr v7, v6
const/high16 v8, 0x34000000
cmpl-float v7, v7, v8
if-gtz v7, :cond_73
new-instance v0, Ljava/lang/AssertionError;
invoke-direct {v0}, Ljava/lang/AssertionError;-><init>()V
throw v0
.line 176
:cond_73
mul-float v7, v5, v1
add-float/2addr v6, v7
mul-float/2addr v6, v5
iput v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
.line 177
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
const/4 v7, 0x0
cmpl-float v6, v6, v7
if-eqz v6, :cond_87
.line 178
const/high16 v6, 0x3f800000 # 1.0f
iget v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
div-float/2addr v6, v7
iput v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
.line 180
:cond_87
mul-float/2addr v1, v5
iget v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
mul-float/2addr v1, v5
iput v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_beta:F
.line 182
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v1}, Lorg/jbox2d/pooling/IWorldPool;->popVec2()Lorg/jbox2d/common/Vec2;
move-result-object v1
.line 185
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localAnchorB:Lorg/jbox2d/common/Vec2;
invoke-virtual {v1, v5}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v1
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_localCenterB:Lorg/jbox2d/common/Vec2;
invoke-virtual {v1, v5}, Lorg/jbox2d/common/Vec2;->subLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v1
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
invoke-static {v4, v1, v5}, Lorg/jbox2d/common/Rot;->mulToOutUnsafe(Lorg/jbox2d/common/Rot;Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)V
.line 190
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v1}, Lorg/jbox2d/pooling/IWorldPool;->popMat22()Lorg/jbox2d/common/Mat22;
move-result-object v1
.line 191
iget-object v4, v1, Lorg/jbox2d/common/Mat22;->ex:Lorg/jbox2d/common/Vec2;
iget v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
iget-object v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v7, v7, Lorg/jbox2d/common/Vec2;->y:F
mul-float/2addr v6, v7
iget-object v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v7, v7, Lorg/jbox2d/common/Vec2;->y:F
mul-float/2addr v6, v7
add-float/2addr v5, v6
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
add-float/2addr v5, v6
iput v5, v4, Lorg/jbox2d/common/Vec2;->x:F
.line 192
iget-object v4, v1, Lorg/jbox2d/common/Mat22;->ex:Lorg/jbox2d/common/Vec2;
iget v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
neg-float v5, v5
iget-object v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v6, v6, Lorg/jbox2d/common/Vec2;->x:F
mul-float/2addr v5, v6
iget-object v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v6, v6, Lorg/jbox2d/common/Vec2;->y:F
mul-float/2addr v5, v6
iput v5, v4, Lorg/jbox2d/common/Vec2;->y:F
.line 193
iget-object v4, v1, Lorg/jbox2d/common/Mat22;->ey:Lorg/jbox2d/common/Vec2;
iget-object v5, v1, Lorg/jbox2d/common/Mat22;->ex:Lorg/jbox2d/common/Vec2;
iget v5, v5, Lorg/jbox2d/common/Vec2;->y:F
iput v5, v4, Lorg/jbox2d/common/Vec2;->x:F
.line 194
iget-object v4, v1, Lorg/jbox2d/common/Mat22;->ey:Lorg/jbox2d/common/Vec2;
iget v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
iget-object v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v7, v7, Lorg/jbox2d/common/Vec2;->x:F
mul-float/2addr v6, v7
iget-object v7, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget v7, v7, Lorg/jbox2d/common/Vec2;->x:F
mul-float/2addr v6, v7
add-float/2addr v5, v6
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
add-float/2addr v5, v6
iput v5, v4, Lorg/jbox2d/common/Vec2;->y:F
.line 196
iget-object v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_mass:Lorg/jbox2d/common/Mat22;
invoke-virtual {v1, v4}, Lorg/jbox2d/common/Mat22;->invertToOut(Lorg/jbox2d/common/Mat22;)V
.line 198
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_C:Lorg/jbox2d/common/Vec2;
invoke-virtual {v1, v0}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v0
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, v1}, Lorg/jbox2d/common/Vec2;->addLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v0
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, v1}, Lorg/jbox2d/common/Vec2;->subLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 199
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_C:Lorg/jbox2d/common/Vec2;
iget v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_beta:F
invoke-virtual {v0, v1}, Lorg/jbox2d/common/Vec2;->mulLocal(F)Lorg/jbox2d/common/Vec2;
.line 202
const v0, 0x3f7ae148 # 0.98f
mul-float/2addr v0, v3
.line 204
iget-object v1, p1, Lorg/jbox2d/dynamics/SolverData;->step:Lorg/jbox2d/dynamics/TimeStep;
iget-boolean v1, v1, Lorg/jbox2d/dynamics/TimeStep;->warmStarting:Z
if-eqz v1, :cond_15b
.line 205
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
iget-object v3, p1, Lorg/jbox2d/dynamics/SolverData;->step:Lorg/jbox2d/dynamics/TimeStep;
iget v3, v3, Lorg/jbox2d/dynamics/TimeStep;->dtRatio:F
invoke-virtual {v1, v3}, Lorg/jbox2d/common/Vec2;->mulLocal(F)Lorg/jbox2d/common/Vec2;
.line 206
iget v1, v2, Lorg/jbox2d/common/Vec2;->x:F
iget v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget-object v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
iget v4, v4, Lorg/jbox2d/common/Vec2;->x:F
mul-float/2addr v3, v4
add-float/2addr v1, v3
iput v1, v2, Lorg/jbox2d/common/Vec2;->x:F
.line 207
iget v1, v2, Lorg/jbox2d/common/Vec2;->y:F
iget v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget-object v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
iget v4, v4, Lorg/jbox2d/common/Vec2;->y:F
mul-float/2addr v3, v4
add-float/2addr v1, v3
iput v1, v2, Lorg/jbox2d/common/Vec2;->y:F
.line 208
iget v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
iget-object v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-static {v2, v3}, Lorg/jbox2d/common/Vec2;->cross(Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)F
move-result v2
mul-float/2addr v1, v2
add-float/2addr v0, v1
.line 214
:goto_143
iget-object v1, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v1, v1, v2
iput v0, v1, Lorg/jbox2d/dynamics/contacts/Velocity;->w:F
.line 216
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v0, v9}, Lorg/jbox2d/pooling/IWorldPool;->pushVec2(I)V
.line 217
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v0, v9}, Lorg/jbox2d/pooling/IWorldPool;->pushMat22(I)V
.line 218
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v0, v9}, Lorg/jbox2d/pooling/IWorldPool;->pushRot(I)V
.line 219
return-void
.line 210
:cond_15b
iget-object v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v1}, Lorg/jbox2d/common/Vec2;->setZero()V
goto :goto_143
.end method
.method public setDampingRatio(F)V
.registers 2
.prologue
.line 137
iput p1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_dampingRatio:F
.line 138
return-void
.end method
.method public setFrequency(F)V
.registers 2
.prologue
.line 128
iput p1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_frequencyHz:F
.line 129
return-void
.end method
.method public setMaxForce(F)V
.registers 2
.prologue
.line 119
iput p1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_maxForce:F
.line 120
return-void
.end method
.method public setTarget(Lorg/jbox2d/common/Vec2;)V
.registers 4
.prologue
.line 107
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
invoke-virtual {v0}, Lorg/jbox2d/dynamics/Body;->isAwake()Z
move-result v0
if-nez v0, :cond_e
.line 108
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_bodyB:Lorg/jbox2d/dynamics/Body;
const/4 v1, 0x1
invoke-virtual {v0, v1}, Lorg/jbox2d/dynamics/Body;->setAwake(Z)V
.line 110
:cond_e
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_targetA:Lorg/jbox2d/common/Vec2;
invoke-virtual {v0, p1}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 111
return-void
.end method
.method public solvePositionConstraints(Lorg/jbox2d/dynamics/SolverData;)Z
.registers 3
.prologue
.line 223
const/4 v0, 0x1
return v0
.end method
.method public solveVelocityConstraints(Lorg/jbox2d/dynamics/SolverData;)V
.registers 9
.prologue
.line 229
iget-object v0, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v1, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v0, v0, v1
iget-object v0, v0, Lorg/jbox2d/dynamics/contacts/Velocity;->v:Lorg/jbox2d/common/Vec2;
.line 230
iget-object v1, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v1, v1, v2
iget v1, v1, Lorg/jbox2d/dynamics/contacts/Velocity;->w:F
.line 233
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v2}, Lorg/jbox2d/pooling/IWorldPool;->popVec2()Lorg/jbox2d/common/Vec2;
move-result-object v2
.line 234
iget-object v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
invoke-static {v1, v3, v2}, Lorg/jbox2d/common/Vec2;->crossToOutUnsafe(FLorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)V
.line 235
invoke-virtual {v2, v0}, Lorg/jbox2d/common/Vec2;->addLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 237
iget-object v3, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v3}, Lorg/jbox2d/pooling/IWorldPool;->popVec2()Lorg/jbox2d/common/Vec2;
move-result-object v3
.line 238
iget-object v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
invoke-interface {v4}, Lorg/jbox2d/pooling/IWorldPool;->popVec2()Lorg/jbox2d/common/Vec2;
move-result-object v4
.line 240
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v4, v5}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v5
iget v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_gamma:F
invoke-virtual {v5, v6}, Lorg/jbox2d/common/Vec2;->mulLocal(F)Lorg/jbox2d/common/Vec2;
move-result-object v5
iget-object v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_C:Lorg/jbox2d/common/Vec2;
invoke-virtual {v5, v6}, Lorg/jbox2d/common/Vec2;->addLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v5
invoke-virtual {v5, v2}, Lorg/jbox2d/common/Vec2;->addLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v2
invoke-virtual {v2}, Lorg/jbox2d/common/Vec2;->negateLocal()Lorg/jbox2d/common/Vec2;
.line 241
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_mass:Lorg/jbox2d/common/Mat22;
invoke-static {v2, v4, v3}, Lorg/jbox2d/common/Mat22;->mulToOutUnsafe(Lorg/jbox2d/common/Mat22;Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)V
.line 244
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v4, v2}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 245
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v2, v3}, Lorg/jbox2d/common/Vec2;->addLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 246
iget-object v2, p1, Lorg/jbox2d/dynamics/SolverData;->step:Lorg/jbox2d/dynamics/TimeStep;
iget v2, v2, Lorg/jbox2d/dynamics/TimeStep;->dt:F
iget v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_maxForce:F
mul-float/2addr v2, v5
.line 247
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v5}, Lorg/jbox2d/common/Vec2;->lengthSquared()F
move-result v5
mul-float v6, v2, v2
cmpl-float v5, v5, v6
if-lez v5, :cond_71
.line 248
iget-object v5, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
iget-object v6, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v6}, Lorg/jbox2d/common/Vec2;->length()F
move-result v6
div-float/2addr v2, v6
invoke-virtual {v5, v2}, Lorg/jbox2d/common/Vec2;->mulLocal(F)Lorg/jbox2d/common/Vec2;
.line 250
:cond_71
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_impulse:Lorg/jbox2d/common/Vec2;
invoke-virtual {v3, v2}, Lorg/jbox2d/common/Vec2;->set(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
move-result-object v2
invoke-virtual {v2, v4}, Lorg/jbox2d/common/Vec2;->subLocal(Lorg/jbox2d/common/Vec2;)Lorg/jbox2d/common/Vec2;
.line 252
iget v2, v0, Lorg/jbox2d/common/Vec2;->x:F
iget v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget v5, v3, Lorg/jbox2d/common/Vec2;->x:F
mul-float/2addr v4, v5
add-float/2addr v2, v4
iput v2, v0, Lorg/jbox2d/common/Vec2;->x:F
.line 253
iget v2, v0, Lorg/jbox2d/common/Vec2;->y:F
iget v4, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invMassB:F
iget v5, v3, Lorg/jbox2d/common/Vec2;->y:F
mul-float/2addr v4, v5
add-float/2addr v2, v4
iput v2, v0, Lorg/jbox2d/common/Vec2;->y:F
.line 254
iget v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_invIB:F
iget-object v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_rB:Lorg/jbox2d/common/Vec2;
invoke-static {v2, v3}, Lorg/jbox2d/common/Vec2;->cross(Lorg/jbox2d/common/Vec2;Lorg/jbox2d/common/Vec2;)F
move-result v2
mul-float/2addr v0, v2
add-float/2addr v0, v1
.line 257
iget-object v1, p1, Lorg/jbox2d/dynamics/SolverData;->velocities:[Lorg/jbox2d/dynamics/contacts/Velocity;
iget v2, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->m_indexB:I
aget-object v1, v1, v2
iput v0, v1, Lorg/jbox2d/dynamics/contacts/Velocity;->w:F
.line 259
iget-object v0, p0, Lorg/jbox2d/dynamics/joints/MouseJoint;->pool:Lorg/jbox2d/pooling/IWorldPool;
const/4 v1, 0x3
invoke-interface {v0, v1}, Lorg/jbox2d/pooling/IWorldPool;->pushVec2(I)V
.line 260
return-void
.end method