From ac4eceb150563357f251f62910e3440131ddeb8d Mon Sep 17 00:00:00 2001 From: Christoph Lendenfeld Date: Thu, 23 Nov 2023 12:47:15 +0100 Subject: [PATCH 1/4] the fix --- source/blender/animrig/intern/action.cc | 21 ++++++++++++ source/blender/animrig/intern/keyframing.cc | 14 -------- .../blender/editors/animation/keyframing.cc | 5 --- .../blender/editors/animation/keyingsets.cc | 5 --- source/blender/makesdna/DNA_anim_types.h | 2 -- .../blender/makesrna/intern/rna_animation.cc | 33 ------------------- 6 files changed, 21 insertions(+), 59 deletions(-) diff --git a/source/blender/animrig/intern/action.cc b/source/blender/animrig/intern/action.cc index 45ffc04e7fc..441af27aa52 100644 --- a/source/blender/animrig/intern/action.cc +++ b/source/blender/animrig/intern/action.cc @@ -13,7 +13,12 @@ #include "BLI_string.h" #include "DEG_depsgraph_build.hh" #include "DNA_anim_types.h" + +#include "RNA_access.hh" +#include "RNA_define.hh" +#include "RNA_path.hh" #include "RNA_prototypes.h" +#include "RNA_types.hh" namespace blender::animrig { @@ -57,6 +62,22 @@ FCurve *action_fcurve_ensure(Main *bmain, fcu->rna_path = BLI_strdup(rna_path); fcu->array_index = array_index; + if (U.autokey_flag & AUTOKEY_FLAG_XYZ2RGB) { + /* For Loc/Rot/Scale and also Color F-Curves, the color of the F-Curve in the Graph Editor, + * is determined by the array index for the F-Curve. + */ + PropertyRNA *prop; + PointerRNA r_ptr; + RNA_path_resolve_property(ptr, rna_path, &r_ptr, &prop); + PropertySubType prop_subtype = RNA_property_subtype(prop); + if (ELEM(prop_subtype, PROP_TRANSLATION, PROP_XYZ, PROP_EULER, PROP_COLOR, PROP_COORDS)) { + fcu->color_mode = FCURVE_COLOR_AUTO_RGB; + } + else if (ELEM(prop_subtype, PROP_QUATERNION)) { + fcu->color_mode = FCURVE_COLOR_AUTO_YRGB; + } + } + if (group) { bActionGroup *agrp = BKE_action_group_find_name(act, group); diff --git a/source/blender/animrig/intern/keyframing.cc b/source/blender/animrig/intern/keyframing.cc index c66c3128ec3..62255899b53 100644 --- a/source/blender/animrig/intern/keyframing.cc +++ b/source/blender/animrig/intern/keyframing.cc @@ -547,20 +547,6 @@ static bool insert_keyframe_fcurve_value(Main *bmain, const bool is_new_curve = (fcu->totvert == 0); - /* Set color mode if the F-Curve is new (i.e. without any keyframes). */ - if (is_new_curve && (flag & INSERTKEY_XYZ2RGB)) { - /* For Loc/Rot/Scale and also Color F-Curves, the color of the F-Curve in the Graph Editor, - * is determined by the array index for the F-Curve - */ - PropertySubType prop_subtype = RNA_property_subtype(prop); - if (ELEM(prop_subtype, PROP_TRANSLATION, PROP_XYZ, PROP_EULER, PROP_COLOR, PROP_COORDS)) { - fcu->color_mode = FCURVE_COLOR_AUTO_RGB; - } - else if (ELEM(prop_subtype, PROP_QUATERNION)) { - fcu->color_mode = FCURVE_COLOR_AUTO_YRGB; - } - } - /* If the curve has only one key, make it cyclic if appropriate. */ const bool is_cyclic_action = (flag & INSERTKEY_CYCLE_AWARE) && BKE_action_is_cyclic(act); diff --git a/source/blender/editors/animation/keyframing.cc b/source/blender/editors/animation/keyframing.cc index 7189abf2562..278352835ac 100644 --- a/source/blender/editors/animation/keyframing.cc +++ b/source/blender/editors/animation/keyframing.cc @@ -91,11 +91,6 @@ eInsertKeyFlags ANIM_get_keyframing_flags(Scene *scene, const bool use_autokey_m if (is_autokey_flag(scene, AUTOKEY_FLAG_INSERTNEEDED)) { flag |= INSERTKEY_NEEDED; } - - /* default F-Curve color mode - RGB from XYZ indices */ - if (is_autokey_flag(scene, AUTOKEY_FLAG_XYZ2RGB)) { - flag |= INSERTKEY_XYZ2RGB; - } } /* only if including settings from the autokeying mode... */ diff --git a/source/blender/editors/animation/keyingsets.cc b/source/blender/editors/animation/keyingsets.cc index 9ae16a191e6..5bd7471bc94 100644 --- a/source/blender/editors/animation/keyingsets.cc +++ b/source/blender/editors/animation/keyingsets.cc @@ -294,10 +294,6 @@ static int add_keyingset_button_exec(bContext *C, wmOperator *op) keyingflag |= ANIM_get_keyframing_flags(scene, false); - if (blender::animrig::is_autokey_flag(scene, AUTOKEY_FLAG_XYZ2RGB)) { - keyingflag |= INSERTKEY_XYZ2RGB; - } - /* call the API func, and set the active keyingset index */ ks = BKE_keyingset_add( &scene->keyingsets, "ButtonKeyingSet", "Button Keying Set", flag, keyingflag); @@ -1011,7 +1007,6 @@ static eInsertKeyFlags keyingset_apply_keying_flags(const eInsertKeyFlags base_f */ APPLY_KEYINGFLAG_OVERRIDE(INSERTKEY_NEEDED) APPLY_KEYINGFLAG_OVERRIDE(INSERTKEY_MATRIX) - APPLY_KEYINGFLAG_OVERRIDE(INSERTKEY_XYZ2RGB) #undef APPLY_KEYINGFLAG_OVERRIDE diff --git a/source/blender/makesdna/DNA_anim_types.h b/source/blender/makesdna/DNA_anim_types.h index 70699fcb655..0e4fa90e127 100644 --- a/source/blender/makesdna/DNA_anim_types.h +++ b/source/blender/makesdna/DNA_anim_types.h @@ -1035,8 +1035,6 @@ typedef enum eInsertKeyFlags { /* INSERTKEY_FASTR = (1 << 3), */ /* UNUSED */ /** only replace an existing keyframe (this overrides INSERTKEY_NEEDED) */ INSERTKEY_REPLACE = (1 << 4), - /** transform F-Curves should have XYZ->RGB color mode */ - INSERTKEY_XYZ2RGB = (1 << 5), /** ignore user-prefs (needed for predictable API use) */ INSERTKEY_NO_USERPREF = (1 << 6), /** diff --git a/source/blender/makesrna/intern/rna_animation.cc b/source/blender/makesrna/intern/rna_animation.cc index fd4823a469a..2f3394986ad 100644 --- a/source/blender/makesrna/intern/rna_animation.cc +++ b/source/blender/makesrna/intern/rna_animation.cc @@ -51,12 +51,6 @@ const EnumPropertyItem rna_enum_keying_flag_items[] = { 0, "Visual Keying", "Insert keyframes based on 'visual transforms'"}, - {INSERTKEY_XYZ2RGB, - "INSERTKEY_XYZ_TO_RGB", - 0, - "XYZ=RGB Colors", - "Color for newly added transformation F-Curves (Location, Rotation, Scale) " - "and also Color is based on the transform axis"}, {0, nullptr, 0, nullptr, nullptr}, }; @@ -72,12 +66,6 @@ const EnumPropertyItem rna_enum_keying_flag_api_items[] = { 0, "Visual Keying", "Insert keyframes based on 'visual transforms'"}, - {INSERTKEY_XYZ2RGB, - "INSERTKEY_XYZ_TO_RGB", - 0, - "XYZ=RGB Colors", - "Color for newly added transformation F-Curves (Location, Rotation, Scale) " - "and also Color is based on the transform axis"}, {INSERTKEY_REPLACE, "INSERTKEY_REPLACE", 0, @@ -877,17 +865,6 @@ static void rna_def_common_keying_flags(StructRNA *srna, short reg) RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL); } - prop = RNA_def_property(srna, "use_insertkey_override_xyz_to_rgb", PROP_BOOLEAN, PROP_NONE); - RNA_def_property_boolean_sdna(prop, nullptr, "keyingoverride", INSERTKEY_XYZ2RGB); - RNA_def_property_ui_text( - prop, - "Override F-Curve Colors - XYZ to RGB", - "Override default setting to set color for newly added transformation F-Curves " - "(Location, Rotation, Scale) to be based on the transform axis"); - if (reg) { - RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL); - } - /* value to override defaults with */ prop = RNA_def_property(srna, "use_insertkey_needed", PROP_BOOLEAN, PROP_NONE); RNA_def_property_boolean_sdna(prop, nullptr, "keyingflag", INSERTKEY_NEEDED); @@ -905,16 +882,6 @@ static void rna_def_common_keying_flags(StructRNA *srna, short reg) if (reg) { RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL); } - - prop = RNA_def_property(srna, "use_insertkey_xyz_to_rgb", PROP_BOOLEAN, PROP_NONE); - RNA_def_property_boolean_sdna(prop, nullptr, "keyingflag", INSERTKEY_XYZ2RGB); - RNA_def_property_ui_text(prop, - "F-Curve Colors - XYZ to RGB", - "Color for newly added transformation F-Curves (Location, Rotation, " - "Scale) is based on the transform axis"); - if (reg) { - RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL); - } } /* --- */ -- 2.30.2 From 0d667d9c9e444a9304993619bdfc25b8e46481d4 Mon Sep 17 00:00:00 2001 From: Christoph Lendenfeld Date: Thu, 23 Nov 2023 13:18:05 +0100 Subject: [PATCH 2/4] remove unused includes --- source/blender/animrig/intern/action.cc | 2 -- 1 file changed, 2 deletions(-) diff --git a/source/blender/animrig/intern/action.cc b/source/blender/animrig/intern/action.cc index 441af27aa52..378df112b91 100644 --- a/source/blender/animrig/intern/action.cc +++ b/source/blender/animrig/intern/action.cc @@ -15,10 +15,8 @@ #include "DNA_anim_types.h" #include "RNA_access.hh" -#include "RNA_define.hh" #include "RNA_path.hh" #include "RNA_prototypes.h" -#include "RNA_types.hh" namespace blender::animrig { -- 2.30.2 From 48d0c789e4edb3d6bdb86b7b0603f15600346f89 Mon Sep 17 00:00:00 2001 From: Christoph Lendenfeld Date: Thu, 23 Nov 2023 13:23:25 +0100 Subject: [PATCH 3/4] remove unused imports --- source/blender/animrig/intern/keyframing.cc | 2 -- 1 file changed, 2 deletions(-) diff --git a/source/blender/animrig/intern/keyframing.cc b/source/blender/animrig/intern/keyframing.cc index 62255899b53..91c300db5e4 100644 --- a/source/blender/animrig/intern/keyframing.cc +++ b/source/blender/animrig/intern/keyframing.cc @@ -37,10 +37,8 @@ #include "ED_keyframing.hh" #include "MEM_guardedalloc.h" #include "RNA_access.hh" -#include "RNA_define.hh" #include "RNA_path.hh" #include "RNA_prototypes.h" -#include "RNA_types.hh" #include "WM_api.hh" #include "WM_types.hh" -- 2.30.2 From ff18c92ccb01580554091b8af52c13ee9e5098e0 Mon Sep 17 00:00:00 2001 From: Christoph Lendenfeld Date: Thu, 23 Nov 2023 16:50:00 +0100 Subject: [PATCH 4/4] remove python usage of keying set override --- scripts/startup/bl_ui/properties_scene.py | 4 ---- 1 file changed, 4 deletions(-) diff --git a/scripts/startup/bl_ui/properties_scene.py b/scripts/startup/bl_ui/properties_scene.py index 2a980812d7a..4598804d884 100644 --- a/scripts/startup/bl_ui/properties_scene.py +++ b/scripts/startup/bl_ui/properties_scene.py @@ -95,10 +95,6 @@ class SceneKeyingSetsPanel: "use_insertkey_override_visual", "use_insertkey_visual", userpref_fallback="use_visual_keying", ) - SceneKeyingSetsPanel._draw_keyframing_setting( - context, layout, ks, ksp, iface_("XYZ to RGB"), - "use_insertkey_override_xyz_to_rgb", "use_insertkey_xyz_to_rgb", - ) @staticmethod def _draw_keyframing_setting(context, layout, ks, ksp, label, toggle_prop, prop, userpref_fallback=None): -- 2.30.2