diff --git a/engine/src/blender/com/jme3/scene/plugins/blender/modifiers/ArmatureModifier.java b/engine/src/blender/com/jme3/scene/plugins/blender/modifiers/ArmatureModifier.java index dc4be4945..dec836874 100644 --- a/engine/src/blender/com/jme3/scene/plugins/blender/modifiers/ArmatureModifier.java +++ b/engine/src/blender/com/jme3/scene/plugins/blender/modifiers/ArmatureModifier.java @@ -118,23 +118,25 @@ import com.jme3.util.BufferUtils; //read animations ArrayList animations = new ArrayList(); List actionHeaders = blenderContext.getFileBlocks(Integer.valueOf(FileBlockHeader.BLOCK_AC00)); - for (FileBlockHeader header : actionHeaders) { - Structure actionStructure = header.getStructure(blenderContext); - String actionName = actionStructure.getName(); - - Track[] tracks = armatureHelper.getTracks(actionStructure, blenderContext); - //determining the animation time - float maximumTrackLength = 0; - for(Track track : tracks) { - float length = track.getLength(); - if(length > maximumTrackLength) { - maximumTrackLength = length; + if(actionHeaders != null) {//it may happen that the model has armature with no actions + for (FileBlockHeader header : actionHeaders) { + Structure actionStructure = header.getStructure(blenderContext); + String actionName = actionStructure.getName(); + + Track[] tracks = armatureHelper.getTracks(actionStructure, blenderContext); + //determining the animation time + float maximumTrackLength = 0; + for(Track track : tracks) { + float length = track.getLength(); + if(length > maximumTrackLength) { + maximumTrackLength = length; + } } + + Animation boneAnimation = new Animation(actionName, maximumTrackLength); + boneAnimation.setTracks(tracks); + animations.add(boneAnimation); } - - Animation boneAnimation = new Animation(actionName, maximumTrackLength); - boneAnimation.setTracks(tracks); - animations.add(boneAnimation); } animData = new AnimData(new Skeleton(bones), animations); }