diff options
author | Julien Duroure <julien.duroure@gmail.com> | 2019-02-21 16:47:23 +0300 |
---|---|---|
committer | Julien Duroure <julien.duroure@gmail.com> | 2019-02-21 16:47:23 +0300 |
commit | a6df2542ba1031416e792cc978fbe7796f450818 (patch) | |
tree | 90beaadb6213511111eaaeeb4c74f7dd5b5be02d /io_scene_gltf2/blender/imp/gltf2_blender_mesh.py | |
parent | 62af5c68867f187a2c05463890d90eae415c99ba (diff) |
glTF importer: Fix bug importing some morph targsts with no POSITION
Do not create a shapekey in that case, ignoring animation on this morph target too
Diffstat (limited to 'io_scene_gltf2/blender/imp/gltf2_blender_mesh.py')
-rwxr-xr-x | io_scene_gltf2/blender/imp/gltf2_blender_mesh.py | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/io_scene_gltf2/blender/imp/gltf2_blender_mesh.py b/io_scene_gltf2/blender/imp/gltf2_blender_mesh.py index c083d8d6..4439a05c 100755 --- a/io_scene_gltf2/blender/imp/gltf2_blender_mesh.py +++ b/io_scene_gltf2/blender/imp/gltf2_blender_mesh.py @@ -108,9 +108,16 @@ class BlenderMesh(): if max_shape_to_create > 0: obj.shape_key_add(name="Basis") + current_shapekey_index = 0 for i in range(max_shape_to_create): + # Check if this target has POSITION + if 'POSITION' not in prim.targets[i].keys(): + gltf.shapekeys[i] = None + continue + obj.shape_key_add(name="target_" + str(i)) + current_shapekey_index += 1 offset_idx = 0 for prim in pymesh.primitives: @@ -122,7 +129,8 @@ class BlenderMesh(): bm = bmesh.new() bm.from_mesh(mesh) - shape_layer = bm.verts.layers.shape[i + 1] + shape_layer = bm.verts.layers.shape[current_shapekey_index] + gltf.shapekeys[i] = current_shapekey_index pos = BinaryData.get_data_from_accessor(gltf, prim.targets[i]['POSITION']) @@ -145,9 +153,11 @@ class BlenderMesh(): if pymesh.weights is not None: for i in range(max_shape_to_create): if i < len(pymesh.weights): - obj.data.shape_keys.key_blocks[i + 1].value = pymesh.weights[i] + if gltf.shapekeys[i] is None: # No default value if shapekeys was not created + continue + obj.data.shape_keys.key_blocks[gltf.shapekeys[i]].value = pymesh.weights[i] if gltf.data.accessors[pymesh.primitives[0].targets[i]['POSITION']].name is not None: - obj.data.shape_keys.key_blocks[i + 1].name = \ + obj.data.shape_keys.key_blocks[gltf.shapekeys[i]].name = \ gltf.data.accessors[pymesh.primitives[0].targets[i]['POSITION']].name # Apply vertex color. |