forked from bartvdbraak/blender
Separate proportional editing options for graph and action editor.
This commit is contained in:
parent
cca4405437
commit
851ea206d0
@ -135,9 +135,11 @@ class DOPESHEET_HT_header(Header):
|
||||
dopesheet_filter(layout, context, genericFiltersOnly=True)
|
||||
|
||||
row = layout.row(align=True)
|
||||
row.prop(toolsettings, "proportional_edit", icon_only=True)
|
||||
if toolsettings.proportional_edit != 'DISABLED':
|
||||
row.prop(toolsettings, "proportional_edit_falloff", icon_only=True)
|
||||
row.prop(toolsettings, "use_proportional_action",
|
||||
text="", icon_only=True)
|
||||
if toolsettings.use_proportional_action:
|
||||
row.prop(toolsettings, "proportional_edit_falloff",
|
||||
text="", icon_only=True)
|
||||
|
||||
# Grease Pencil mode doesn't need snapping, as it's frame-aligned only
|
||||
if st.mode != 'GPENCIL':
|
||||
|
@ -48,9 +48,12 @@ class GRAPH_HT_header(Header):
|
||||
row.prop(st, "use_auto_normalization", text="Auto")
|
||||
|
||||
row = layout.row(align=True)
|
||||
row.prop(toolsettings, "proportional_edit", icon_only=True)
|
||||
if toolsettings.proportional_edit != 'DISABLED':
|
||||
row.prop(toolsettings, "proportional_edit_falloff", icon_only=True)
|
||||
|
||||
row.prop(toolsettings, "use_proportional_ipo",
|
||||
text="", icon_only=True)
|
||||
if toolsettings.use_proportional_ipo:
|
||||
row.prop(toolsettings, "proportional_edit_falloff",
|
||||
text="", icon_only=True)
|
||||
|
||||
layout.prop(st, "auto_snap", text="")
|
||||
layout.prop(st, "pivot_point", icon_only=True)
|
||||
|
@ -241,10 +241,8 @@ static void action_keymap_keyframes(wmKeyConfig *keyconf, wmKeyMap *keymap)
|
||||
/* transform system */
|
||||
transform_keymap_for_space(keyconf, keymap, SPACE_ACTION);
|
||||
|
||||
kmi = WM_keymap_add_item(keymap, "WM_OT_context_toggle_enum", OKEY, KM_PRESS, 0, 0);
|
||||
RNA_string_set(kmi->ptr, "data_path", "tool_settings.proportional_edit");
|
||||
RNA_string_set(kmi->ptr, "value_1", "DISABLED");
|
||||
RNA_string_set(kmi->ptr, "value_2", "ENABLED");
|
||||
kmi = WM_keymap_add_item(keymap, "WM_OT_context_toggle", OKEY, KM_PRESS, 0, 0);
|
||||
RNA_string_set(kmi->ptr, "data_path", "tool_settings.use_proportional_action");
|
||||
|
||||
/* special markers hotkeys for anim editors: see note in definition of this function */
|
||||
ED_marker_keymap_animedit_conflictfree(keymap);
|
||||
|
@ -608,10 +608,8 @@ static void graphedit_keymap_keyframes(wmKeyConfig *keyconf, wmKeyMap *keymap)
|
||||
/* transform system */
|
||||
transform_keymap_for_space(keyconf, keymap, SPACE_IPO);
|
||||
|
||||
kmi = WM_keymap_add_item(keymap, "WM_OT_context_toggle_enum", OKEY, KM_PRESS, 0, 0);
|
||||
RNA_string_set(kmi->ptr, "data_path", "tool_settings.proportional_edit");
|
||||
RNA_string_set(kmi->ptr, "value_1", "DISABLED");
|
||||
RNA_string_set(kmi->ptr, "value_2", "ENABLED");
|
||||
kmi = WM_keymap_add_item(keymap, "WM_OT_context_toggle", OKEY, KM_PRESS, 0, 0);
|
||||
RNA_string_set(kmi->ptr, "data_path", "tool_settings.use_proportional_ipo");
|
||||
|
||||
/* pivot point settings */
|
||||
kmi = WM_keymap_add_item(keymap, "WM_OT_context_set_enum", COMMAKEY, KM_PRESS, 0, 0);
|
||||
|
@ -1938,7 +1938,11 @@ void saveTransform(bContext *C, TransInfo *t, wmOperator *op)
|
||||
if ((prop = RNA_struct_find_property(op->ptr, "proportional")) &&
|
||||
!RNA_property_is_set(op->ptr, prop))
|
||||
{
|
||||
if (t->obedit)
|
||||
if (t->spacetype == SPACE_IPO)
|
||||
ts->proportional_ipo = proportional;
|
||||
else if (t->spacetype == SPACE_ACTION)
|
||||
ts->proportional_action = proportional;
|
||||
else if (t->obedit)
|
||||
ts->proportional = proportional;
|
||||
else if (t->options & CTX_MASK)
|
||||
ts->proportional_mask = (proportional != PROP_EDIT_OFF);
|
||||
|
@ -1320,8 +1320,11 @@ void initTransInfo(bContext *C, TransInfo *t, wmOperator *op, const wmEvent *eve
|
||||
/* use settings from scene only if modal */
|
||||
if (t->flag & T_MODAL) {
|
||||
if ((t->options & CTX_NO_PET) == 0) {
|
||||
if (ELEM(t->spacetype, SPACE_IPO, SPACE_ACTION)) {
|
||||
t->flag |= initTransInfo_edit_pet_to_flag(ts->proportional);
|
||||
if (t->spacetype == SPACE_IPO) {
|
||||
t->flag |= initTransInfo_edit_pet_to_flag(ts->proportional_ipo);
|
||||
}
|
||||
else if (t->spacetype == SPACE_ACTION) {
|
||||
t->flag |= initTransInfo_edit_pet_to_flag(ts->proportional_action);
|
||||
}
|
||||
else if (t->obedit) {
|
||||
t->flag |= initTransInfo_edit_pet_to_flag(ts->proportional);
|
||||
|
@ -1269,7 +1269,10 @@ typedef struct ToolSettings {
|
||||
short snap_flag, snap_target;
|
||||
short proportional, prop_mode;
|
||||
char proportional_objects; /* proportional edit, object mode */
|
||||
char proportional_mask; /* proportional edit, object mode */
|
||||
char proportional_mask; /* proportional edit, mask editing */
|
||||
char proportional_action; /* proportional edit, action editor */
|
||||
char proportional_ipo; /* proportional edit, graph editor */
|
||||
char pad4[6];
|
||||
|
||||
char auto_normalize; /*auto normalizing mode in wpaint*/
|
||||
char multipaint; /* paint multiple bones in wpaint */
|
||||
|
@ -2168,6 +2168,18 @@ static void rna_def_tool_settings(BlenderRNA *brna)
|
||||
RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
|
||||
RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
|
||||
|
||||
prop = RNA_def_property(srna, "use_proportional_action", PROP_BOOLEAN, PROP_NONE);
|
||||
RNA_def_property_boolean_sdna(prop, NULL, "proportional_action", 0);
|
||||
RNA_def_property_ui_text(prop, "Proportional Editing Actions", "Proportional editing in action editor");
|
||||
RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
|
||||
RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
|
||||
|
||||
prop = RNA_def_property(srna, "use_proportional_ipo", PROP_BOOLEAN, PROP_NONE);
|
||||
RNA_def_property_boolean_sdna(prop, NULL, "proportional_ipo", 0);
|
||||
RNA_def_property_ui_text(prop, "Proportional Editing Ipo Curves", "Proportional editing in ipo editor");
|
||||
RNA_def_property_ui_icon(prop, ICON_PROP_OFF, 1);
|
||||
RNA_def_property_update(prop, NC_SCENE | ND_TOOLSETTINGS, NULL); /* header redraw */
|
||||
|
||||
prop = RNA_def_property(srna, "proportional_edit_falloff", PROP_ENUM, PROP_NONE);
|
||||
RNA_def_property_enum_sdna(prop, NULL, "prop_mode");
|
||||
RNA_def_property_enum_items(prop, proportional_falloff_items);
|
||||
|
Loading…
Reference in New Issue
Block a user