Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorThomas Beck <software@plasmasolutions.de>2017-04-28 14:01:03 +0300
committerThomas Beck <software@plasmasolutions.de>2017-04-29 00:44:52 +0300
commitd6963630dc64e94b4f2da21d43c1985f77be88aa (patch)
tree112a4388de2f4acf97d5c815de317071d10f4fd8 /doc
parentaf3f7db4ec3b75043c8aa1e5332145e8910c0849 (diff)
Implementation of custom python entries in all right click menus
Hi Guys, as one of my clients needs the possibility to have custom menu entries in the general right click menu (all over Blender: in the node editor, properties, toolbars,..) I talked with Campbell about expanding our hard coded menu a bit. This is the outcome. As I only need those two, I support currently a button_prop and a button_pointer. {F540397} I tested the changes with a custom script where I added a custom entry and executed an operator on click - it seems to work exactly how it's intended to. The script: {F540435} As I'm not too experienced in rna stuff I would really appreciate any review. Thanks very much Campbell for his open ears & help on this issue! Reviewers: campbellbarton, mont29 Reviewed By: campbellbarton, mont29 Subscribers: sybren, mont29 Tags: #addons Differential Revision: https://developer.blender.org/D2612
Diffstat (limited to 'doc')
-rw-r--r--doc/python_api/examples/bpy.types.Menu.4.py81
1 files changed, 81 insertions, 0 deletions
diff --git a/doc/python_api/examples/bpy.types.Menu.4.py b/doc/python_api/examples/bpy.types.Menu.4.py
new file mode 100644
index 00000000000..a59c710c8e7
--- /dev/null
+++ b/doc/python_api/examples/bpy.types.Menu.4.py
@@ -0,0 +1,81 @@
+"""
+Custom item in the right click menu
++++++++++++++++++++++++++++++++++++
+
+This example enables you to insert your own menu entry into the common
+right click menu that you get while hovering over a value field,
+color, string, etc.
+
+To make the example work, you have to first select an object
+then right click on an user interface element (maybe a color in the
+material properties) and choose "Execute custom action".
+
+Executing the operator will then dump all values directly to a
+console, so make sure to open a terminal by clicking on
+"Help >> Toggle System Console" or execute Blender directly
+from a terminal on your system of choice)
+
+"""
+
+import bpy
+from bpy.types import Header, Menu, Panel
+
+def dump(obj, text):
+ print('-'*40, text, '-'*40)
+ for attr in dir(obj):
+ if hasattr( obj, attr ):
+ print( "obj.%s = %s" % (attr, getattr(obj, attr)))
+
+class TEST_OT_Rmb(bpy.types.Operator):
+ """Right click entry test"""
+ bl_idname = "object.rmb_test_op"
+ bl_label = "Execute custom action"
+
+ @classmethod
+ def poll(cls, context):
+ return context.active_object is not None
+
+ def execute(self, context):
+ if hasattr(context, 'button_pointer'):
+ btn = context.button_pointer
+ dump(btn, 'button_pointer')
+
+ if hasattr(context, 'button_prop'):
+ prop = context.button_prop
+ dump(prop, 'button_prop')
+
+ if hasattr(context, 'button_operator'):
+ op = context.button_operator
+ dump(op, 'button_operator')
+
+ return {'FINISHED'}
+
+# This class has to be exactly named like that to insert an entry in the right click menu
+class WM_MT_button_context(Menu):
+ bl_label = "Add Viddyoze Tag"
+
+ def draw(self, context):
+ pass
+
+def menu_func(self, context):
+ layout = self.layout
+ layout.separator()
+ layout.operator("object.rmb_test_op")
+
+classes = (
+ TEST_OT_Rmb,
+ WM_MT_button_context,
+)
+
+def register():
+ for cls in classes:
+ bpy.utils.register_class(cls)
+ bpy.types.WM_MT_button_context.append(menu_func)
+
+def unregister():
+ for cls in classes:
+ bpy.utils.unregister_class(cls)
+ bpy.types.WM_MT_button_context.remove(menu_func)
+
+if __name__ == "__main__":
+ register() \ No newline at end of file