Compare commits
1 Commits
486b23b378
...
6b799a4663
Author | SHA1 | Date | |
---|---|---|---|
6b799a4663 |
47
common.py
47
common.py
@ -62,16 +62,6 @@ def createFcurve(context, bone_name, transform, index_int):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
def findKeyframe(context, bone, active_frame):
|
|
||||||
arm_object, pose_library = getArmatureData(context)
|
|
||||||
|
|
||||||
for fcu in pose_library.fcurves:
|
|
||||||
if fcu.data_path.startswith('pose.bones["'+bone.name+'"]'):
|
|
||||||
for kp in fcu.keyframe_points:
|
|
||||||
if kp.co.x == active_frame:
|
|
||||||
return fcu.data_path
|
|
||||||
|
|
||||||
|
|
||||||
def createKeyframe(context, bone_name, transform, index_int, new_marker, loc):
|
def createKeyframe(context, bone_name, transform, index_int, new_marker, loc):
|
||||||
arm_object, pose_library = getArmatureData(context)
|
arm_object, pose_library = getArmatureData(context)
|
||||||
pose_markers = pose_library.pose_markers
|
pose_markers = pose_library.pose_markers
|
||||||
@ -94,7 +84,15 @@ def setKeyframesFromBones(context, arm_object, new_marker):
|
|||||||
if bone.bone.select or none_selected == True:
|
if bone.bone.select or none_selected == True:
|
||||||
bone_name = bone.name
|
bone_name = bone.name
|
||||||
|
|
||||||
if bone.rotation_mode in ("XYZ", "XZY", "YXZ", "YZX", "ZXY", "ZYX"):
|
if bone.rotation_mode == "XYZ":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "XZY":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "YXZ":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "YZX":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "ZXY":
|
||||||
rot_mode = "rotation_euler"
|
rot_mode = "rotation_euler"
|
||||||
elif bone.rotation_mode == "QUATERNION":
|
elif bone.rotation_mode == "QUATERNION":
|
||||||
rot_mode = "rotation_quaternion"
|
rot_mode = "rotation_quaternion"
|
||||||
@ -155,10 +153,15 @@ def setBonesfromKeyframes(context, arm_object, active_marker):
|
|||||||
if bone.bone.select or none_selected == True:
|
if bone.bone.select or none_selected == True:
|
||||||
bone_name = bone.name
|
bone_name = bone.name
|
||||||
|
|
||||||
if findKeyframe(context, bone, active_marker.frame) is None:
|
if bone.rotation_mode == "XYZ":
|
||||||
continue
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "XZY":
|
||||||
if bone.rotation_mode in ("XYZ", "XZY", "YXZ", "YZX", "ZXY", "ZYX"):
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "YXZ":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "YZX":
|
||||||
|
rot_mode = "rotation_euler"
|
||||||
|
elif bone.rotation_mode == "ZXY":
|
||||||
rot_mode = "rotation_euler"
|
rot_mode = "rotation_euler"
|
||||||
elif bone.rotation_mode == "QUATERNION":
|
elif bone.rotation_mode == "QUATERNION":
|
||||||
rot_mode = "rotation_quaternion"
|
rot_mode = "rotation_quaternion"
|
||||||
@ -183,9 +186,21 @@ def setBonesfromKeyframes(context, arm_object, active_marker):
|
|||||||
scl_z = findFcurve(context, bone_name, "scale", 2) or 1.0
|
scl_z = findFcurve(context, bone_name, "scale", 2) or 1.0
|
||||||
|
|
||||||
bone.location = mathutils.Vector((loc_x, loc_y, loc_z))
|
bone.location = mathutils.Vector((loc_x, loc_y, loc_z))
|
||||||
if rot_mode == "rotation_euler":
|
if bone.rotation_mode == "XYZ":
|
||||||
bone.rotation_euler = mathutils.Euler(
|
bone.rotation_euler = mathutils.Euler(
|
||||||
(rot_x, rot_y, rot_z))
|
(rot_x, rot_y, rot_z))
|
||||||
|
elif bone.rotation_mode == "YZX":
|
||||||
|
bone.rotation_euler = mathutils.Euler(
|
||||||
|
(rot_x, rot_y, rot_z))
|
||||||
|
elif bone.rotation_mode == "ZXY":
|
||||||
|
bone.rotation_euler = mathutils.Euler(
|
||||||
|
(rot_z, rot_x, rot_y))
|
||||||
|
elif bone.rotation_mode == "YXZ":
|
||||||
|
bone.rotation_euler = mathutils.Euler(
|
||||||
|
(rot_y, rot_x, rot_z))
|
||||||
|
elif bone.rotation_mode == "XZY":
|
||||||
|
bone.rotation_euler = mathutils.Euler(
|
||||||
|
(rot_x, rot_z, rot_y))
|
||||||
elif rot_mode == "rotation_quaternion":
|
elif rot_mode == "rotation_quaternion":
|
||||||
bone.rotation_quaternion = mathutils.Quaternion(
|
bone.rotation_quaternion = mathutils.Quaternion(
|
||||||
(rot_w, rot_x, rot_y, rot_z))
|
(rot_w, rot_x, rot_y, rot_z))
|
||||||
|
Reference in New Issue
Block a user