[Bf-blender-cvs] [5155572fc78] blender2.8: Keymap: add popup keymap
Campbell Barton
noreply at git.blender.org
Thu Nov 22 06:58:55 CET 2018
Commit: 5155572fc78690bdd0927fcb4f73a191b71db9b9
Author: Campbell Barton
Date: Thu Nov 22 16:52:57 2018 +1100
Branches: blender2.8
https://developer.blender.org/rB5155572fc78690bdd0927fcb4f73a191b71db9b9
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.
===================================================================
M release/scripts/modules/bl_keymap_utils/keymap_from_toolbar.py
M release/scripts/presets/keyconfig/keymap_data/blender_default.py
===================================================================
diff --git a/release/scripts/modules/bl_keymap_utils/keymap_from_toolbar.py b/release/scripts/modules/bl_keymap_utils/keymap_from_toolbar.py
index 59939e422aa..3d861763ad6 100644
--- a/release/scripts/modules/bl_keymap_utils/keymap_from_toolbar.py
+++ b/release/scripts/modules/bl_keymap_utils/keymap_from_toolbar.py
@@ -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)
diff --git a/release/scripts/presets/keyconfig/keymap_data/blender_default.py b/release/scripts/presets/keyconfig/keymap_data/blender_default.py
index 2be8a5b9587..9259d3baf12 100644
--- a/release/scripts/presets/keyconfig/keymap_data/blender_default.py
+++ b/release/scripts/presets/keyconfig/keymap_data/blender_default.py
@@ -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),
More information about the Bf-blender-cvs
mailing list