1 Commits

Author SHA1 Message Date
34cfaea0c1 Function to select bones in pose 2025-01-19 03:19:39 -06:00

View File

@ -105,7 +105,11 @@ 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 == "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"
@ -169,7 +173,11 @@ def setBonesfromKeyframes(context, arm_object, active_marker):
if findKeyframe(context, bone, active_marker.frame) is None: if findKeyframe(context, bone, active_marker.frame) is None:
continue continue
if bone.rotation_mode in ("XYZ", "XZY", "YXZ", "YZX", "ZXY", "ZYX"): if bone.rotation_mode == "XYZ":
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"
@ -194,9 +202,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))