avatar
Skinnable avatar player model for voxel games
data:image/s3,"s3://crabby-images/53a8b/53a8b68bf84b8ea14bfb4e7c76fc948711b85f77" alt="Screenshot screenshot"
This module is similar to @maxogden's minecraft-skin,
but instead of using three.js, it uses gl-modules.
Returns a gl-vao object
containing the vertices and UV coordinates for the player model,
for use with the provided vertex and fragment shaders.
For an example, run npm start
or check out the live demo.
Try dragging a skin image file from your hard disk onto the demo to change the textures.
The included example uses @substack's skin:
data:image/s3,"s3://crabby-images/13835/138357efcc5cf4ad9b1d5ffd790f5b4cd5c00ac9" alt="example skin screenshot"
Here's how the avatar looks when using changing it to
, @maxogden skin:
data:image/s3,"s3://crabby-images/c7bd1/c7bd1e780b725af9569f046a37048694702addcd" alt="maxogden avatar screenshot"
Or the classic "Steve" skin from Minecraft (not included):
data:image/s3,"s3://crabby-images/aaff5/aaff514f0e42339f788beae440fad17246a78b29" alt="steve avatar screenshot"
Skin formats
Currently supported:
- Minecraft 1.7 and earlier (64x32) skin format
- Minecraft 1.8 (64x64) skin format
- High-resolution multiples of 64x32 or 64x32 (examples)
(Minecraft is property of Mojang Specifications).
Uniforms
mat4 projectionMatrix, modelViewMatrix
: the usual transformation matricessampler2D skin
: skin texture, should be in one of the above supported formats (for example from a gl-texture2d)float rArmRotateX
: right arm rotation X (radians)float lArmRotateX
: left arm rotation X (radians)float rLegRotateX
: right leg rotation X (radians)float lLegRotateX
: left leg rotation X (radians)
Example of setting the rotation uniforms:
data:image/s3,"s3://crabby-images/9acd7/9acd70d3296a0a543593d6640aa9fd55afa6f001" alt="Screenshot rotation screenshot"
License
MIT