Jump to content

Model loader with animation support


Hea3veN

Recommended Posts

No, this is not a request thread, I've actually been implementing a model loader for COLLADA files with support for animations, and wanted to show some of the progress and request some help from the community.

 

First of all, what is collada and why use it? COLLADA is an exchange format for 3d assets, created by the Khronos group (the guys behind OpenGL). It is an XML-based format. The main file types I found while looking for something that supported animations are the quake engine format (MD3), which is a binary format, and several other propietary formats like 3DS from autodesk.

 

Currently, the features I've implemented are:

* Loading meshes made up of triangles.

* Loading translation/rotation/scale of meshes in a scene.

* Loading of keyframe animations for the translation/rotation/scale with linear interpolation.

 

I've recorded a sample of it at work:

 

The features I'm looking into implementing before releasing a first version are:

* Load textures file names from the model

* Fully implement polylist and polygons mesh primitive (currently only works when all faces are triangles).

* Implement matrix transform on meshes in a scene and animations (an alternative to translation/rotation/scale).

 

Finally, here are some of the features which I want to implement but are relatively complex and that will probably have to wait for a later version:

* Implement BEZIER and other interpolations for animations

* Implement skinning animations (i.e. animations with bones), this is actually the feature I was interested in and got me into doing this.

 

What I need now is, first of all sample files. I obviously can test on Blender easily and I also have access to 3ds max, but don't have any of the rest of the 3d modelling softwares. So if you can, create a simple scene with a cube that has some kind of animation, and export it to a collada file.

 

Second, there needs to be an api to call to render an animation's frame. My proposal that I've been working so far is adding the following methods to the IModelCustom

 

public interface IModelCustom {
    String getType();

    void renderAll();
    void renderOnly(String... groupNames);
    void renderPart(String partName);
    void renderAllExcept(String... excludedGroupNames);

    int getAnimationLength();
    void renderAnimationAll(int frame);
    void renderAnimationOnly(int frame, String... groupNames);
    void renderAnimationPart(int frame, String partName);
    void renderAnimationAllExcept(int frame, String... excludedGroupNames);
}

 

where frame specifies which frame of the animation to render considering a framerate of 20 frames per second. This api allows simple code, for instance you can have a counter that gets added every tick. This is the way animations are handled in the minecraft code, for reference you can look in the chest tile entity class. Of course, model loaders which don't support animations would return 1 on getAnimationLength() and the "renderAnimation*" methods would call their respective "render*" methods.

If anyone has different ideas of how this api could be defined, I'd be interested in seeing them.

 

Link to comment
Share on other sites

A few notes:

 

* I'd make an IAnimatedModelCustom interface (extends IModelCustom). No need to support all those no-op methods for model types which can't even support them, and you can easily find out if you can call the animation functions via "instanceof".

 

* COLLADA in particular (but also other model formats) supports multiple named animations. I'd suggest getting and using those animations this way:

 

ModelAnimation anim = animatedModel.getAnimationAll("AnimName");
/*
Alternatives:
ModelAnimation anim = animatedModel.getAnimationPart("AnimName", "GroupName");
ModelAnimation anim = animatedModel.getAnimationOnly("AnimName", "GroupName1", "GroupName2", ... "GroupNameX");
ModelAnimation anim = animatedModel.getAnimationAllExcept("AnimName", "ExGroupName1", ..., "ExGroupNameX");
ModelAnimation anim = animatedModel.getAnimationAll(null); // Get all the animations in one timeline
*/

float frame = ((float)tick - startTick + partialTick) / 20.0f * anim.framesPerSecond;
anim.render(frame);
/*
Alternative:
anim.renderTick((float)tick - startTick + partialTick);
*/

/*
Other stuff to do with an animation:

float anim.length - length in seconds
float anim.lengthTicks - length in ticks
int anim.frames - amount of frames (at least 1)
IAnimatedModelCustom anim.model - The model this animation applies to
Set<String> anim.groups - The model groups this animation applies to

// Append another animation to this one, resolving animation channels by name and
// applying them to the original anim's model.
ModelAnimation newAnim = anim.append(ModelAnimation otherAnim);
ModelAnimation newAnim = anim.append(ModelAnimation otherAnim, int blendFrames);

// Blend one animation into another
ModelAnimation newAnim = anim.blend(ModelAnimation otherAnim, float strength);
ModelAnimation newAnim = anim.blend(ModelAnimation otherAnim, float strength, int finalAmountOfFrames);
ModelAnimation newAnim = anim.blend(ModelAnimation otherAnim, AnimationBlender blendMethod);

// Slow down or speed up an animation
ModelAnimation newAnim = anim.forLength(float seconds);
ModelAnimation newAnim = anim.forFPS(float framesPerSecond);

 

ItemBlock is not a Block

ItemStack is not an Item

Damage value is not metadata

 

Stop confusing them.

Link to comment
Share on other sites

  • 3 weeks later...

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.