Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender-addons.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrecht Van Lommel <brechtvanlommel@pandora.be>2013-04-11 23:26:33 +0400
committerBrecht Van Lommel <brechtvanlommel@pandora.be>2013-04-11 23:26:33 +0400
commit068109fe42e2e09d5acce6f40b34de82ce0c8117 (patch)
treed3230f2f2b83e15b44ad1aca19d140429c043adc /io_shape_mdd
parentcc9f663c54eca82b703979b255ea5e285ad96b45 (diff)
Fix #34607: MDD import should default to linear instead of bezier keyframe
interpolation, otherwise the shape key weights do not add up to 1 which gives bad results.
Diffstat (limited to 'io_shape_mdd')
-rw-r--r--io_shape_mdd/import_mdd.py42
1 files changed, 25 insertions, 17 deletions
diff --git a/io_shape_mdd/import_mdd.py b/io_shape_mdd/import_mdd.py
index e671e285..8caedccd 100644
--- a/io_shape_mdd/import_mdd.py
+++ b/io_shape_mdd/import_mdd.py
@@ -34,17 +34,27 @@
import bpy
from struct import unpack
-def obj_update_frame(file, scene, obj, fr, step):
+def set_linear_interpolation(obj, shapekey):
+ anim_data = obj.data.shape_keys.animation_data
+ data_path = "key_blocks[\"" + shapekey.name + "\"].value"
+
+ for fcu in anim_data.action.fcurves:
+ if fcu.data_path == data_path:
+ for keyframe in fcu.keyframe_points:
+ keyframe.interpolation = 'LINEAR'
+
+
+def obj_update_frame(file, scene, obj, start, fr, step):
# Insert new shape key
new_shapekey = obj.shape_key_add()
new_shapekey.name = ("frame_%.4d" % fr)
+ new_shapekey_index = len(obj.data.shape_keys.key_blocks) - 1
- obj.active_shape_key_index = len(obj.data.shape_keys.key_blocks) - 1
- index = len(obj.data.shape_keys.key_blocks) - 1
+ obj.active_shape_key_index = new_shapekey_index
obj.show_only_shape_key = True
- verts = obj.data.shape_keys.key_blocks[len(obj.data.shape_keys.key_blocks) - 1].data
+ verts = new_shapekey.data
for v in verts: # 12 is the size of 3 floats
v.co[:] = unpack('>3f', file.read(12))
@@ -53,19 +63,19 @@ def obj_update_frame(file, scene, obj, fr, step):
obj.show_only_shape_key = False
# insert keyframes
- shape_keys = obj.data.shape_keys
+ new_shapekey = obj.data.shape_keys.key_blocks[new_shapekey_index]
+ frame = start + fr*step
- scene.frame_current -= step
- obj.data.shape_keys.key_blocks[index].value = 0.0
- shape_keys.key_blocks[len(obj.data.shape_keys.key_blocks) - 1].keyframe_insert("value")
+ new_shapekey.value = 0.0
+ new_shapekey.keyframe_insert("value", frame=frame - step)
- scene.frame_current += step
- obj.data.shape_keys.key_blocks[index].value = 1.0
- shape_keys.key_blocks[len(obj.data.shape_keys.key_blocks) - 1].keyframe_insert("value")
+ new_shapekey.value = 1.0
+ new_shapekey.keyframe_insert("value", frame=frame)
- scene.frame_current += step
- obj.data.shape_keys.key_blocks[index].value = 0.0
- shape_keys.key_blocks[len(obj.data.shape_keys.key_blocks) - 1].keyframe_insert("value")
+ new_shapekey.value = 0.0
+ new_shapekey.keyframe_insert("value", frame=frame + step)
+
+ set_linear_interpolation(obj, new_shapekey)
obj.data.update()
@@ -93,9 +103,7 @@ def load(operator, context, filepath, frame_start=0, frame_step=1):
basis.name = "Basis"
obj.data.update()
- scene.frame_current = frame_start
-
for i in range(frames):
- obj_update_frame(file, scene, obj, i, frame_step)
+ obj_update_frame(file, scene, obj, frame_start, i, frame_step)
return {'FINISHED'}