- mesh_bind( &player.mesh );
- float const kleg_upper = 0.53f,
- kleg_lower = 0.5f,
- karm_ratio = 0.75f,
- karm_upper = kleg_upper*karm_ratio,
- karm_lower = kleg_lower*karm_ratio;
-
- /* Create IK targets */
- struct ik_basic ik_leg_l = { .l1 = kleg_upper, .l2 = kleg_lower },
- ik_leg_r = { .l1 = kleg_upper, .l2 = kleg_lower },
- ik_arm_l = { .l1 = karm_upper, .l2 = karm_lower },
- ik_arm_r = { .l1 = karm_upper, .l2 = karm_lower };
-
- v3f butt, fwd;
-
- m4x3_mulv( player.to_world, (v3f){ 0.0f,0.16f,-0.4f }, ik_leg_r.end );
- m4x3_mulv( player.to_world, (v3f){ 0.0f,0.16f, 0.3f }, ik_leg_l.end );
- m4x3_mulv( player.to_world, (v3f){ -0.6f,0.5f,-0.4f }, ik_leg_r.pole );
- m4x3_mulv( player.to_world, (v3f){ -0.6f,0.5f,0.35f }, ik_leg_l.pole );
-
- m3x3_mulv( player.to_world, (v3f){ 0.2f,-0.55f,0.0f}, butt );
- v3_add( butt, player.view, butt );
-
- m3x3_mulv( player.to_world, (v3f){0.0f,0.0f,-1.0f}, fwd );
- v3_muladds( butt, fwd, 0.1f, ik_leg_r.base );
- v3_muladds( butt, fwd,-0.1f, ik_leg_l.base );
-
- /* Compute IK */
- m4x3f mleg_l, mknee_l, mleg_r, mknee_r, mboard;
-
- ik_basic( &ik_leg_r, mleg_r, mknee_r );
- ik_basic( &ik_leg_l, mleg_l, mknee_l );
-
- /* Arms */
- v3f hl, hr, neckl = {0.2f,-0.1f, 0.2f},
- neckr = {0.2f,-0.1f,-0.2f};
-
- v3_lerp( player.handl, player.handl_target, 0.04f, player.handl );
- v3_lerp( player.handr, player.handr_target, 0.04f, player.handr );
-
- m3x3_mulv( player.to_world, neckl, neckl );
- m3x3_mulv( player.to_world, neckr, neckr );
-
- v3_add( player.view, neckl, ik_arm_l.base );
- v3_add( player.view, neckr, ik_arm_r.base );
- m4x3_mulv( player.to_world, player.handl, ik_arm_l.end );
- m4x3_mulv( player.to_world, player.handr, ik_arm_r.end );
- m4x3_mulv( player.to_world, (v3f){ 0.6f,0.7f, 0.4f }, ik_arm_l.pole );
- m4x3_mulv( player.to_world, (v3f){ 0.6f,0.7f,-0.35f }, ik_arm_r.pole );