# Crate skelly[−][src]

Crate for skeleton animation.

Optionally provides inverse-kinematics functionality.

# Example

```// build a skelly with leg and two arms.
let mut skelly = Skelly::<f32>::new();
let leg = skelly.attach(Vector3::z().into(), foot);
let waist = skelly.attach(Vector3::z().into(), leg);

let left_shoulder = skelly.attach(Vector3::z().into(), waist);
let left_arm = skelly.attach((-Vector3::x()).into(), left_shoulder);
let left_palm = skelly.attach((-Vector3::x()).into(), left_arm);

let right_shoulder = skelly.attach(Vector3::z().into(), waist);
let right_arm = skelly.attach(Vector3::x().into(), right_shoulder);
let right_palm = skelly.attach(Vector3::x().into(), right_arm);

// Write global isometries of every joint into an array.
let mut globals = vec![Isometry3::identity(); skelly.len()];
skelly.write_globals(&Isometry3::identity(), &mut globals);
```

# IK example

```
// Using the skelly above, do some inverse-kinematics
let mut posture = Posture::new(&skelly);
let mut solver = RotorSolver::new(0.01);

// move left palm to the foot.
solver.set_position_goal(left_palm, Point3::origin());

// Iteratively solve imposed constraints.
for _ in 0..100 {
solver.solve_step(&skelly, &mut posture);
}

// Write global isometries of every joint in the posture into an array.
let mut globals = vec![Isometry3::identity(); skelly.len()];
posture.write_globals(&skelly, &Isometry3::identity(), &mut globals);```

See `examples/demo.rs` for working example.

## Modules

 ik This module contains inverse-kinematic functionality for the skelly crate.

## Structs

 Posture Collection of bones transformations that represent a skelly posture. Skelly One’s skeleton. Parameterized with numric value and bone userdata type.