Main repository of MikuMikuStudio
Revision | 802c4f9854667eb6794c8068d7f4b356354495cd (tree) |
---|---|
Time | 2013-03-05 18:35:35 |
Author | Kaelthas_Spellsinger@o2.pl <Kaelthas_Spellsinger@o2.p...> |
Commiter | Kaelthas_Spellsinger@o2.pl |
Bugfix: fixed an error that could create wrogn vertex to bone group assignment. This caused animation to be played badly because some vertices remained in their places instead of moving with the proper bone.
git-svn-id: http://jmonkeyengine.googlecode.com/svn/trunk@10463 75d07b2b-3a1a-0410-a2c5-0572b91ccdca
@@ -31,23 +31,23 @@ | ||
31 | 31 | */ |
32 | 32 | package com.jme3.scene.plugins.blender.animations; |
33 | 33 | |
34 | +import java.util.ArrayList; | |
35 | +import java.util.HashMap; | |
36 | +import java.util.List; | |
37 | +import java.util.Map; | |
38 | +import java.util.logging.Level; | |
39 | +import java.util.logging.Logger; | |
40 | + | |
34 | 41 | import com.jme3.animation.Bone; |
35 | 42 | import com.jme3.animation.BoneTrack; |
36 | 43 | import com.jme3.animation.Skeleton; |
37 | 44 | import com.jme3.math.Matrix4f; |
38 | -import com.jme3.scene.Spatial; | |
39 | 45 | import com.jme3.scene.plugins.blender.AbstractBlenderHelper; |
40 | 46 | import com.jme3.scene.plugins.blender.BlenderContext; |
41 | 47 | import com.jme3.scene.plugins.blender.curves.BezierCurve; |
42 | 48 | import com.jme3.scene.plugins.blender.exceptions.BlenderFileException; |
43 | 49 | import com.jme3.scene.plugins.blender.file.Pointer; |
44 | 50 | import com.jme3.scene.plugins.blender.file.Structure; |
45 | -import java.util.ArrayList; | |
46 | -import java.util.HashMap; | |
47 | -import java.util.List; | |
48 | -import java.util.Map; | |
49 | -import java.util.logging.Level; | |
50 | -import java.util.logging.Logger; | |
51 | 51 | |
52 | 52 | /** |
53 | 53 | * This class defines the methods to calculate certain aspects of animation and |
@@ -314,9 +314,10 @@ import com.jme3.util.BufferUtils; | ||
314 | 314 | List<Structure> dw = pDW.fetchData(blenderContext.getInputStream()); |
315 | 315 | for (Structure deformWeight : dw) { |
316 | 316 | Integer boneIndex = groupToBoneIndexMap.get(((Number) deformWeight.getFieldValue("def_nr")).intValue()); |
317 | - // null here means that we came accross group that has no bone attached to | |
318 | - if (boneIndex != null) { | |
319 | - float weight = ((Number) deformWeight.getFieldValue("weight")).floatValue(); | |
317 | + float weight = ((Number) deformWeight.getFieldValue("weight")).floatValue(); | |
318 | + // boneIndex == null: it here means that we came accross group that has no bone attached to, so simply ignore it | |
319 | + // if weight == 0 and weightIndex == 0 then ignore the weight (do not set weight = 0 as a first weight) | |
320 | + if (boneIndex != null && (weight > 0.0f || weightIndex > 0)) { | |
320 | 321 | if (weightIndex < MAXIMUM_WEIGHTS_PER_VERTEX) { |
321 | 322 | if (weight == 0.0f) { |
322 | 323 | boneIndex = Integer.valueOf(0); |
@@ -341,8 +342,8 @@ import com.jme3.util.BufferUtils; | ||
341 | 342 | weightToIndexMap.put(weight, lowestWeightAndIndex.getValue()); |
342 | 343 | } |
343 | 344 | } |
345 | + ++weightIndex; | |
344 | 346 | } |
345 | - ++weightIndex; | |
346 | 347 | } |
347 | 348 | } else { |
348 | 349 | // 0.0 weight indicates, do not transform this vertex, but keep it in bind pose. |