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

git.blender.org/blender-addons.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'space_view3d_pie_menus/pie_select_menu.py')
-rw-r--r--space_view3d_pie_menus/pie_select_menu.py198
1 files changed, 198 insertions, 0 deletions
diff --git a/space_view3d_pie_menus/pie_select_menu.py b/space_view3d_pie_menus/pie_select_menu.py
new file mode 100644
index 00000000..b837b2aa
--- /dev/null
+++ b/space_view3d_pie_menus/pie_select_menu.py
@@ -0,0 +1,198 @@
+# ##### BEGIN GPL LICENSE BLOCK #####
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# ##### END GPL LICENSE BLOCK #####
+
+# <pep8 compliant>
+
+bl_info = {
+ "name": "Hotkey: 'A'",
+ "description": "Object/Edit mode Selection Menu",
+ # "author": "pitiwazou, meta-androcto",
+ # "version": (0, 1, 0),
+ "blender": (2, 77, 0),
+ "location": "3D View",
+ "warning": "",
+ "wiki_url": "",
+ "category": "Select Pie"
+ }
+
+import bpy
+from bpy.types import (
+ Menu,
+ Operator,
+ )
+
+# Pie Selection Object Mode - A
+
+
+class PieSelectionsMore(Menu):
+ bl_idname = "pie.selectionsmore"
+ bl_label = "Pie Selections Object Mode"
+
+ def draw(self, context):
+ layout = self.layout
+ pie = layout.menu_pie()
+ box = pie.split().column()
+ row = box.row(align=True)
+ box.operator("object.select_by_type", text="Select By Type", icon='SNAP_VOLUME')
+ box.operator("object.select_grouped", text="Select Grouped", icon='ROTATE')
+ box.operator("object.select_linked", text="Select Linked", icon='CONSTRAINT_BONE')
+ box.menu("VIEW3D_MT_select_object_more_less", text="More/Less")
+
+# Pie Selection Object Mode - A
+
+
+class PieSelectionsOM(Menu):
+ bl_idname = "pie.selectionsom"
+ bl_label = "Pie Selections Object Mode"
+
+ def draw(self, context):
+ layout = self.layout
+ pie = layout.menu_pie()
+ # 4 - LEFT
+ pie.operator("object.select_by_layer", text="Select By Layer", icon='GROUP_VERTEX')
+ # 6 - RIGHT
+ pie.operator("object.select_random", text="Select Random", icon='GROUP_VERTEX')
+ # 2 - BOTTOM
+ pie.operator("object.select_all", text="Invert Selection", icon='ZOOM_PREVIOUS').action = 'INVERT'
+ # 8 - TOP
+ pie.operator("object.select_all", text="Select All Toggle", icon='RENDER_REGION').action = 'TOGGLE'
+ # 7 - TOP - LEFT
+ pie.operator("view3d.select_circle", text="Circle Select", icon='BORDER_LASSO')
+ # 9 - TOP - RIGHT
+ pie.operator("view3d.select_border", text="Border Select", icon='BORDER_RECT')
+ # 1 - BOTTOM - LEFT
+ pie.operator("object.select_camera", text="Select Camera", icon='CAMERA_DATA')
+ # 3 - BOTTOM - RIGHT
+ pie.menu("pie.selectionsmore", text="Select More", icon='GROUP_VERTEX')
+
+# Pie Selection Edit Mode
+
+
+class PieSelectionsEM(Menu):
+ bl_idname = "pie.selectionsem"
+ bl_label = "Pie Selections Edit Mode"
+
+ def draw(self, context):
+ layout = self.layout
+ pie = layout.menu_pie()
+ # 4 - LEFT
+ pie.operator("mesh.loop_multi_select", text="Select Ring", icon='ZOOM_PREVIOUS').ring = True
+ # 6 - RIGHT
+ pie.operator("mesh.loop_multi_select", text="Select Loop", icon='ZOOM_PREVIOUS').ring = False
+ # 2 - BOTTOM
+ pie.operator("mesh.select_all", text="Invert Selection", icon='ZOOM_PREVIOUS').action = 'INVERT'
+ # 8 - TOP
+ pie.operator("mesh.select_all", text="Select All Toggle", icon='RENDER_REGION').action = 'TOGGLE'
+ # 7 - TOP - LEFT
+ pie.operator("view3d.select_circle", text="Circle Select", icon='BORDER_LASSO')
+ # 9 - TOP - RIGHT
+ pie.operator("view3d.select_border", text="Border Select", icon='BORDER_RECT')
+ # 1 - BOTTOM - LEFT
+ box = pie.split().column()
+ row = box.row(align=True)
+ box.operator("mesh.select_nth", text="Checker Select", icon='PARTICLE_POINT')
+ box.operator("mesh.loop_to_region", text="Select Loop Inner Region", icon='FACESEL')
+ box.operator("mesh.select_similar", text="Select Similar", icon='GHOST')
+ # 3 - BOTTOM - RIGHT
+ pie.menu("object.selectallbyselection", text="Multi Select", icon='RENDER_REGION')
+
+# Select All By Selection
+
+
+class SelectAllBySelection(Menu):
+ bl_idname = "object.selectallbyselection"
+ bl_label = "Verts Edges Faces"
+ bl_options = {'REGISTER', 'UNDO'}
+
+ def draw(self, context):
+ layout = self.layout
+ layout.operator_context = 'INVOKE_REGION_WIN'
+
+ prop = layout.operator("wm.context_set_value", text="Vertex Select",
+ icon='VERTEXSEL')
+ prop.value = "(True, False, False)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ prop = layout.operator("wm.context_set_value", text="Edge Select",
+ icon='EDGESEL')
+ prop.value = "(False, True, False)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ prop = layout.operator("wm.context_set_value", text="Face Select",
+ icon='FACESEL')
+ prop.value = "(False, False, True)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ prop = layout.operator("wm.context_set_value",
+ text="Vertex & Edge & Face Select",
+ icon='SNAP_VOLUME')
+ prop.value = "(True, True, True)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+classes = (
+ PieSelectionsOM,
+ PieSelectionsEM,
+ SelectAllBySelection,
+ PieSelectionsMore,
+ )
+
+addon_keymaps = []
+
+
+def register():
+ for cls in classes:
+ bpy.utils.register_class(cls)
+ wm = bpy.context.window_manager
+
+ if wm.keyconfigs.addon:
+ # Selection Object Mode
+ km = wm.keyconfigs.addon.keymaps.new(name='Object Mode')
+ kmi = km.keymap_items.new('wm.call_menu_pie', 'A', 'PRESS')
+ kmi.properties.name = "pie.selectionsom"
+ addon_keymaps.append((km, kmi))
+
+ # Selection Edit Mode
+ km = wm.keyconfigs.addon.keymaps.new(name='Mesh')
+ kmi = km.keymap_items.new('wm.call_menu_pie', 'A', 'PRESS')
+ kmi.properties.name = "pie.selectionsem"
+ addon_keymaps.append((km, kmi))
+
+
+def unregister():
+ for cls in classes:
+ bpy.utils.unregister_class(cls)
+ wm = bpy.context.window_manager
+
+ kc = wm.keyconfigs.addon
+ if kc:
+ km = kc.keymaps['Object Mode']
+ for kmi in km.keymap_items:
+ if kmi.idname == 'wm.call_menu_pie':
+ if kmi.properties.name == "pie.selectionsom":
+ km.keymap_items.remove(kmi)
+
+ kc = wm.keyconfigs.addon
+ if kc:
+ km = kc.keymaps['Mesh']
+ for kmi in km.keymap_items:
+ if kmi.idname == 'wm.call_menu_pie':
+ if kmi.properties.name == "pie.selectionsem":
+ km.keymap_items.remove(kmi)
+
+if __name__ == "__main__":
+ register()