Keymap: add popup keymap

Allow manually mapping keys for the popup toolbar.

Useful for tools that don't have immediate access,
add transform, annotate & measure.
This commit is contained in:
Campbell Barton 2018-11-22 16:52:57 +11:00
parent d0ac13d6b1
commit 5155572fc7
2 changed files with 27 additions and 8 deletions

View File

@ -71,7 +71,8 @@ def generate(context, space_type):
use_release_confirm = True
# Generate items when no keys are mapped.
use_auto_keymap = True
use_auto_keymap_alpha = False # Map manially in the default keymap
use_auto_keymap_num = True
# Temporary, only create so we can pass 'properties' to find_item_from_operator.
use_hack_properties = True
@ -82,8 +83,6 @@ def generate(context, space_type):
keymap = keyconf.keymaps.get(km_name)
if keymap is None:
keymap = keyconf.keymaps.new(km_name, space_type='EMPTY', region_type='TEMPORARY', tool=True)
for kmi in keymap.keymap_items:
keymap.keymap_items.remove(kmi)
kmi_unique_args = set()
@ -266,7 +265,7 @@ def generate(context, space_type):
kmi.properties.name = item.text
item_container[2] = kmi
if use_auto_keymap:
if use_auto_keymap_alpha:
# Map all unmapped keys to numbers,
# while this is a bit strange it means users will not confuse regular key bindings to ordered bindings.
@ -291,6 +290,7 @@ def generate(context, space_type):
item_container[2] = kmi
del kmi_type_alpha_char, kmi_type_alpha_args, kmi_type_alpha_args_tuple
if use_auto_keymap_num:
# Free events (last used first).
kmi_type_auto = ('ONE', 'TWO', 'THREE', 'FOUR', 'FIVE', 'SIX', 'SEVEN', 'EIGHT', 'NINE', 'ZERO')
# Map both numbers and num-pad.
@ -334,8 +334,7 @@ def generate(context, space_type):
kmi = keymap.keymap_items.new(idname="wm.tool_set_by_name", value='PRESS', **kmi_args)
kmi.properties.name = item.text
item_container[2] = kmi
if use_auto_keymap:
kmi_unique_args.add(kmi_tuple)
kmi_unique_args.add(kmi_tuple)
key = kmi_type_dupe.get(kmi_args["type"])
if key is not None:
@ -344,8 +343,7 @@ def generate(context, space_type):
if not kmi_tuple in kmi_unique_args:
kmi = keymap.keymap_items.new(idname="wm.tool_set_by_name", value='PRESS', **kmi_args)
kmi.properties.name = item.text
if use_auto_keymap:
kmi_unique_args.add(kmi_tuple)
kmi_unique_args.add(kmi_tuple)
if use_hack_properties:
keymap.keymap_items.remove(kmi_hack)

View File

@ -4875,6 +4875,24 @@ def km_backdrop_transform_widget(_params):
return keymap
# ------------------------------------------------------------------------------
# Popup Keymaps
def km_popup_toolbar(params):
return (
"Toolbar Popup",
{"space_type": 'EMPTY', "region_type": 'TEMPORARY'},
{"items": [
("wm.tool_set_by_name", {"type": 'T', "value": 'PRESS'},
{"properties": [("name", "Transform")]}),
("wm.tool_set_by_name", {"type": 'D', "value": 'PRESS'},
{"properties": [("name", "Annotate")]}),
("wm.tool_set_by_name", {"type": 'M', "value": 'PRESS'},
{"properties": [("name", "Measure")]}),
]},
)
# ------------------------------------------------------------------------------
# Tool System Keymaps
#
@ -5858,6 +5876,9 @@ def generate_keymaps(params=None):
km_armature_spline_widgets_tweak_modal_map(params),
km_backdrop_transform_widget(params),
# Pop-Up Keymaps.
km_popup_toolbar(params),
# Tool System.
km_image_editor_tool_uv_cursor(params),
km_image_editor_tool_uv_select_box(params),