2009-11-01 15:21:20 +00:00
|
|
|
# ##### 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.
|
2009-11-03 07:23:02 +00:00
|
|
|
#
|
2009-11-01 15:21:20 +00:00
|
|
|
# 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.
|
2009-11-03 07:23:02 +00:00
|
|
|
#
|
2009-11-01 15:21:20 +00:00
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software Foundation,
|
2010-02-12 13:34:04 +00:00
|
|
|
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2009-11-01 15:21:20 +00:00
|
|
|
#
|
|
|
|
# ##### END GPL LICENSE BLOCK #####
|
2009-10-31 20:16:59 +00:00
|
|
|
|
2009-10-31 23:35:56 +00:00
|
|
|
# <pep8 compliant>
|
2009-08-18 12:58:51 +00:00
|
|
|
import bpy
|
2018-02-01 14:58:05 +11:00
|
|
|
from bpy.types import (
|
|
|
|
Header,
|
|
|
|
Menu,
|
|
|
|
Panel,
|
|
|
|
)
|
2013-02-10 10:29:38 +00:00
|
|
|
from bpy.app.translations import pgettext_iface as iface_
|
2013-03-28 15:41:43 +00:00
|
|
|
from bpy.app.translations import contexts as i18n_contexts
|
2013-02-10 09:09:26 +00:00
|
|
|
|
2011-06-24 03:30:50 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_HT_header(Header):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
2012-07-29 12:07:06 +00:00
|
|
|
|
2018-05-31 16:44:20 +02:00
|
|
|
# No need to show type selector.
|
|
|
|
# layout.template_header()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
|
2018-08-20 15:37:19 +02:00
|
|
|
if userpref.active_section == 'INPUT':
|
2018-11-02 03:15:38 +01:00
|
|
|
layout.operator("wm.keyconfig_import", icon='IMPORT')
|
|
|
|
layout.operator("wm.keyconfig_export", icon='EXPORT')
|
2010-02-26 14:28:29 +00:00
|
|
|
elif userpref.active_section == 'ADDONS':
|
2018-10-01 10:45:50 +02:00
|
|
|
layout.operator("wm.addon_install", icon='FILEBROWSER')
|
2013-08-30 11:49:35 +00:00
|
|
|
layout.operator("wm.addon_refresh", icon='FILE_REFRESH')
|
2016-01-08 04:58:22 +11:00
|
|
|
layout.menu("USERPREF_MT_addons_online_resources")
|
2018-06-08 14:30:11 +02:00
|
|
|
elif userpref.active_section == 'LIGHTS':
|
2018-11-02 03:15:38 +01:00
|
|
|
layout.operator('wm.studiolight_install', text="Add MatCap").orientation = 'MATCAP'
|
|
|
|
layout.operator('wm.studiolight_install', text="Add World HDRI").orientation = 'WORLD'
|
|
|
|
layout.operator('wm.studiolight_install', text="Add Camera HDRI").orientation = 'CAMERA'
|
2010-04-04 14:52:15 +00:00
|
|
|
elif userpref.active_section == 'THEMES':
|
2018-11-02 03:15:38 +01:00
|
|
|
layout.operator("wm.theme_install", icon='FILEBROWSER')
|
|
|
|
layout.operator("ui.reset_default_theme", icon='LOOP_BACK')
|
|
|
|
|
|
|
|
layout.separator_spacer()
|
|
|
|
|
|
|
|
layout.operator_context = 'EXEC_AREA'
|
|
|
|
layout.operator("wm.save_userpref")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-04-17 19:05:53 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_tabs(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_label = ""
|
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-08-18 12:58:51 +00:00
|
|
|
|
2009-10-31 19:31:45 +00:00
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
2009-08-18 12:58:51 +00:00
|
|
|
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
|
2017-06-01 16:38:32 +03:00
|
|
|
layout.row().prop(userpref, "active_section", expand=True)
|
2009-08-18 12:58:51 +00:00
|
|
|
|
2009-10-31 23:35:56 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_interface(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "Interface"
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'INTERFACE')
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
view = userpref.view
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
split = layout.split()
|
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Display:")
|
2017-03-11 03:27:08 +01:00
|
|
|
col.prop(view, "ui_scale", text="Scale")
|
2017-08-07 22:42:47 +02:00
|
|
|
col.prop(view, "ui_line_width", text="Line Width")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(view, "show_tooltips")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(view, "show_object_info", text="Object Info")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(view, "show_large_cursors")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(view, "show_view_name", text="View Name")
|
|
|
|
col.prop(view, "show_playback_fps", text="Playback FPS")
|
2009-12-08 19:08:35 +00:00
|
|
|
col.prop(view, "object_origin_size")
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-07-14 23:49:00 +02:00
|
|
|
# col.prop(view, "show_gizmo_navigate")
|
2018-06-25 12:58:24 +02:00
|
|
|
|
|
|
|
sub = col.column(align=True)
|
|
|
|
|
2018-08-28 12:34:51 +10:00
|
|
|
sub.label(text="3D Viewport Axis:")
|
2018-08-14 19:27:59 +02:00
|
|
|
sub.row().prop(view, "mini_axis_type", text="")
|
2018-06-25 12:58:24 +02:00
|
|
|
|
|
|
|
sub = col.column(align=True)
|
2018-07-11 10:38:01 +02:00
|
|
|
sub.active = view.mini_axis_type == 'MINIMAL'
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.prop(view, "mini_axis_size", text="Size")
|
|
|
|
sub.prop(view, "mini_axis_brightness", text="Brightness")
|
2010-06-09 19:12:03 +00:00
|
|
|
|
2010-05-16 10:21:00 +00:00
|
|
|
col.separator()
|
2015-02-25 13:51:53 +01:00
|
|
|
|
2018-06-25 12:58:24 +02:00
|
|
|
# Toolbox doesn't exist yet
|
|
|
|
# col.label(text="Toolbox:")
|
|
|
|
#col.prop(view, "show_column_layout")
|
|
|
|
#col.label(text="Open Toolbox Delay:")
|
|
|
|
#col.prop(view, "open_left_mouse_delay", text="Hold LMB")
|
|
|
|
#col.prop(view, "open_right_mouse_delay", text="Hold RMB")
|
2018-07-14 23:49:00 +02:00
|
|
|
col.prop(view, "show_gizmo", text="Gizmos")
|
2018-06-25 12:58:24 +02:00
|
|
|
sub = col.column()
|
2018-07-14 23:49:00 +02:00
|
|
|
sub.active = view.show_gizmo
|
|
|
|
sub.prop(view, "gizmo_size", text="Size")
|
2018-06-25 12:58:24 +02:00
|
|
|
|
|
|
|
col.separator()
|
|
|
|
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text="Development:")
|
2018-06-25 12:58:24 +02:00
|
|
|
col.prop(view, "show_tooltips_python")
|
|
|
|
col.prop(view, "show_developer_ui")
|
2015-02-25 13:51:53 +01:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
row.separator()
|
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2018-07-14 22:29:35 +02:00
|
|
|
col.label(text="View Gizmos:")
|
2012-08-10 10:34:24 +00:00
|
|
|
col.prop(view, "use_mouse_depth_cursor")
|
2017-07-29 01:28:58 +10:00
|
|
|
col.prop(view, "use_cursor_lock_adjust")
|
2012-08-10 10:34:24 +00:00
|
|
|
col.prop(view, "use_mouse_depth_navigate")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(view, "use_zoom_to_mouse")
|
|
|
|
col.prop(view, "use_rotate_around_active")
|
2011-05-23 02:53:30 +00:00
|
|
|
col.prop(view, "use_camera_lock_parent")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(view, "use_auto_perspective")
|
2009-12-08 19:08:35 +00:00
|
|
|
col.prop(view, "smooth_view")
|
|
|
|
col.prop(view, "rotation_angle")
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-30 04:43:36 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="2D Viewports:")
|
|
|
|
col.prop(view, "view2d_grid_spacing_min", text="Minimum Grid Spacing")
|
2010-01-30 04:43:36 +00:00
|
|
|
col.prop(view, "timecode_style")
|
2015-05-13 20:30:53 +02:00
|
|
|
col.prop(view, "view_frame_type")
|
2018-02-01 14:58:05 +11:00
|
|
|
if view.view_frame_type == 'SECONDS':
|
2015-05-13 20:30:53 +02:00
|
|
|
col.prop(view, "view_frame_seconds")
|
2018-02-01 14:58:05 +11:00
|
|
|
elif view.view_frame_type == 'KEYFRAMES':
|
2015-05-13 20:30:53 +02:00
|
|
|
col.prop(view, "view_frame_keyframes")
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
row.separator()
|
|
|
|
col = row.column()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Menus:")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(view, "use_mouse_over_open")
|
2013-12-02 15:23:06 +01:00
|
|
|
sub = col.column()
|
|
|
|
sub.active = view.use_mouse_over_open
|
|
|
|
|
|
|
|
sub.prop(view, "open_toplevel_delay", text="Top Level")
|
|
|
|
sub.prop(view, "open_sublevel_delay", text="Sub Level")
|
2010-03-14 23:26:17 +00:00
|
|
|
|
Pie Menus C code backend.
This commit merges the code in the pie-menu branch.
As per decisions taken the last few days, there are no pie menus
included and there will be an official add-on including overrides of
some keys with pie menus. However, people will now be able to use the
new code in python.
Full Documentation is in http://wiki.blender.org/index.php/Dev:Ref/
Thanks:
Campbell Barton, Dalai Felinto and Ton Roosendaal for the code review
and design comments
Jonathan Williamson, Pawel Lyczkowski, Pablo Vazquez among others for
suggestions during the development.
Special Thanks to Sean Olson, for his support, suggestions, testing and
merciless bugging so that I would finish the pie menu code. Without him
we wouldn't be here. Also to the rest of the developers of the original
python add-on, Patrick Moore and Dan Eicher and finally to Matt Ebb, who
did the research and first implementation and whose code I used to get
started.
2014-08-11 10:39:59 +02:00
|
|
|
col.separator()
|
|
|
|
col.label(text="Pie Menus:")
|
|
|
|
sub = col.column(align=True)
|
|
|
|
sub.prop(view, "pie_animation_timeout")
|
|
|
|
sub.prop(view, "pie_initial_timeout")
|
|
|
|
sub.prop(view, "pie_menu_radius")
|
|
|
|
sub.prop(view, "pie_menu_threshold")
|
2014-10-10 19:13:40 +02:00
|
|
|
sub.prop(view, "pie_menu_confirm")
|
2013-12-02 15:23:06 +01:00
|
|
|
col.separator()
|
2018-01-12 12:30:58 +11:00
|
|
|
|
|
|
|
col.prop(view, "show_splash")
|
2018-06-25 12:58:24 +02:00
|
|
|
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text="Warnings:")
|
2018-06-25 12:58:24 +02:00
|
|
|
col.prop(view, "use_quit_dialog")
|
|
|
|
|
2010-03-14 18:08:12 +00:00
|
|
|
col.separator()
|
2010-03-14 23:26:17 +00:00
|
|
|
|
2018-01-12 12:30:58 +11:00
|
|
|
col.label(text="App Template:")
|
|
|
|
col.label(text="Options intended for use with app-templates only.")
|
2018-01-11 16:08:55 +11:00
|
|
|
col.prop(view, "show_layout_ui")
|
2018-01-12 12:41:03 +11:00
|
|
|
col.prop(view, "show_view3d_cursor")
|
2018-01-11 16:08:55 +11:00
|
|
|
|
2009-08-18 12:58:51 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_edit(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "Edit"
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'EDITING')
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
edit = userpref.edit
|
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
split = layout.split()
|
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Link Materials To:")
|
2010-01-09 15:49:27 +00:00
|
|
|
col.prop(edit, "material_link", text="")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="New Objects:")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(edit, "use_enter_edit_mode")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Align To:")
|
2010-01-09 15:49:27 +00:00
|
|
|
col.prop(edit, "object_align", text="")
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Undo:")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(edit, "use_global_undo")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "undo_steps", text="Steps")
|
|
|
|
col.prop(edit, "undo_memory_limit", text="Memory Limit")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
row.separator()
|
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2018-07-31 10:22:19 +02:00
|
|
|
col.label(text="Grease Pencil/Annotations:")
|
|
|
|
col.separator()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "grease_pencil_manhattan_distance", text="Manhattan Distance")
|
|
|
|
col.prop(edit, "grease_pencil_euclidean_distance", text="Euclidean Distance")
|
2013-11-06 10:59:05 +00:00
|
|
|
col.separator()
|
2018-10-11 19:14:18 +02:00
|
|
|
|
|
|
|
col.label(text="Annotations:")
|
|
|
|
sub = col.row()
|
|
|
|
sub.prop(edit, "grease_pencil_default_color", text="Default Color")
|
|
|
|
col.prop(edit, "grease_pencil_eraser_radius", text="Eraser Radius")
|
2010-02-18 00:29:08 +00:00
|
|
|
col.separator()
|
2018-10-11 19:14:18 +02:00
|
|
|
col.prop(edit, "use_grease_pencil_simplify_stroke", text="Simplify Stroke")
|
|
|
|
col.separator()
|
|
|
|
|
2010-02-18 00:29:08 +00:00
|
|
|
col.separator()
|
2012-03-22 12:19:31 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2018-10-11 19:14:18 +02:00
|
|
|
col.label(text="Playback:")
|
|
|
|
col.prop(edit, "use_negative_frames")
|
2012-03-22 12:19:31 +00:00
|
|
|
col.separator()
|
2015-08-01 17:39:48 +02:00
|
|
|
col.label(text="Node Editor:")
|
|
|
|
col.prop(edit, "node_margin")
|
2012-03-22 12:19:31 +00:00
|
|
|
col.label(text="Animation Editors:")
|
|
|
|
col.prop(edit, "fcurve_unselected_alpha", text="F-Curve Visibility")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
row.separator()
|
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Keyframing:")
|
2009-12-08 19:08:35 +00:00
|
|
|
col.prop(edit, "use_visual_keying")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "use_keyframe_insert_needed", text="Only Insert Needed")
|
2009-12-08 19:08:35 +00:00
|
|
|
|
|
|
|
col.separator()
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "use_auto_keying", text="Auto Keyframing:")
|
2012-10-09 00:59:40 +00:00
|
|
|
col.prop(edit, "use_auto_keying_warning")
|
2009-12-08 19:08:35 +00:00
|
|
|
|
|
|
|
sub = col.column()
|
|
|
|
|
2018-06-05 16:32:11 +02:00
|
|
|
# ~ sub.active = edit.use_keyframe_insert_auto # incorrect, time-line can enable
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.prop(edit, "use_keyframe_insert_available", text="Only Insert Available")
|
2009-12-08 19:08:35 +00:00
|
|
|
|
2010-02-17 15:14:09 +00:00
|
|
|
col.separator()
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="New F-Curve Defaults:")
|
|
|
|
col.prop(edit, "keyframe_new_interpolation_type", text="Interpolation")
|
|
|
|
col.prop(edit, "keyframe_new_handle_type", text="Handles")
|
|
|
|
col.prop(edit, "use_insertkey_xyz_to_rgb", text="XYZ to RGB")
|
2010-02-17 15:14:09 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Transform:")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(edit, "use_drag_immediately")
|
2018-07-11 16:31:28 +02:00
|
|
|
col.prop(edit, "use_numeric_input_advanced")
|
2009-12-08 19:08:35 +00:00
|
|
|
|
2018-08-14 19:27:59 +02:00
|
|
|
row = split.row()
|
2009-12-15 14:22:34 +00:00
|
|
|
row.separator()
|
|
|
|
col = row.column()
|
2018-08-14 19:27:59 +02:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "sculpt_paint_overlay_color", text="Sculpt Overlay Color")
|
2010-07-14 14:11:03 +00:00
|
|
|
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Duplicate Data:")
|
|
|
|
col.prop(edit, "use_duplicate_mesh", text="Mesh")
|
|
|
|
col.prop(edit, "use_duplicate_surface", text="Surface")
|
|
|
|
col.prop(edit, "use_duplicate_curve", text="Curve")
|
|
|
|
col.prop(edit, "use_duplicate_text", text="Text")
|
|
|
|
col.prop(edit, "use_duplicate_metaball", text="Metaball")
|
|
|
|
col.prop(edit, "use_duplicate_armature", text="Armature")
|
2018-06-27 14:41:53 +02:00
|
|
|
col.prop(edit, "use_duplicate_light", text="Light")
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(edit, "use_duplicate_material", text="Material")
|
|
|
|
col.prop(edit, "use_duplicate_texture", text="Texture")
|
|
|
|
#col.prop(edit, "use_duplicate_fcurve", text="F-Curve")
|
|
|
|
col.prop(edit, "use_duplicate_action", text="Action")
|
|
|
|
col.prop(edit, "use_duplicate_particle", text="Particle")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-10-31 23:35:56 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_system(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "System"
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'SYSTEM')
|
|
|
|
|
|
|
|
def draw(self, context):
|
2013-02-08 13:15:30 +00:00
|
|
|
import sys
|
2009-10-31 19:31:45 +00:00
|
|
|
layout = self.layout
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
system = userpref.system
|
|
|
|
|
|
|
|
split = layout.split()
|
|
|
|
|
2010-01-09 15:49:27 +00:00
|
|
|
# 1. Column
|
2009-12-08 19:08:35 +00:00
|
|
|
column = split.column()
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = column.split(factor=0.85)
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col = colsplit.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="General:")
|
2014-09-30 18:29:32 +02:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.prop(system, "scrollback", text="Console Scrollback")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Sound:")
|
2015-07-24 15:44:17 +02:00
|
|
|
col.row().prop(system, "audio_device", expand=False)
|
2009-12-08 19:08:35 +00:00
|
|
|
sub = col.column()
|
2017-09-02 15:42:29 +10:00
|
|
|
sub.active = system.audio_device not in {'NONE', 'Null'}
|
2010-08-17 13:14:41 +00:00
|
|
|
#sub.prop(system, "use_preview_images")
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.prop(system, "audio_channels", text="Channels")
|
|
|
|
sub.prop(system, "audio_mixing_buffer", text="Mixing Buffer")
|
|
|
|
sub.prop(system, "audio_sample_rate", text="Sample Rate")
|
|
|
|
sub.prop(system, "audio_sample_format", text="Sample Format")
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2016-11-24 11:14:45 +11:00
|
|
|
if bpy.app.build_options.cycles:
|
|
|
|
addon = userpref.addons.get("cycles")
|
|
|
|
if addon is not None:
|
|
|
|
addon.preferences.draw_impl(col, context)
|
|
|
|
del addon
|
2016-11-19 01:15:08 +01:00
|
|
|
|
2015-07-20 16:08:06 +02:00
|
|
|
if hasattr(system, "opensubdiv_compute_type"):
|
|
|
|
col.label(text="OpenSubdiv compute:")
|
|
|
|
col.row().prop(system, "opensubdiv_compute_type", text="")
|
|
|
|
|
2010-01-09 15:49:27 +00:00
|
|
|
# 2. Column
|
2009-12-08 19:08:35 +00:00
|
|
|
column = split.column()
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = column.split(factor=0.85)
|
2009-12-08 19:08:35 +00:00
|
|
|
|
|
|
|
col = colsplit.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="OpenGL:")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(system, "gl_clip_alpha", slider=True)
|
2012-12-05 11:46:13 +00:00
|
|
|
col.prop(system, "use_gpu_mipmap")
|
2012-01-17 16:31:13 +00:00
|
|
|
col.prop(system, "use_16bit_textures")
|
2013-12-31 18:09:20 -06:00
|
|
|
|
2015-11-24 02:20:38 -05:00
|
|
|
col.separator()
|
2018-07-10 09:56:57 +02:00
|
|
|
col.label(text="Selection:")
|
2015-11-24 02:20:38 -05:00
|
|
|
col.prop(system, "select_method", text="")
|
2017-03-09 05:17:55 +11:00
|
|
|
col.prop(system, "use_select_pick_depth")
|
2014-07-23 15:24:07 +02:00
|
|
|
|
2013-12-31 18:09:20 -06:00
|
|
|
col.separator()
|
|
|
|
|
2018-07-10 09:56:57 +02:00
|
|
|
col.label(text="Anisotropic Filtering:")
|
2011-06-24 03:30:50 +00:00
|
|
|
col.prop(system, "anisotropic_filter", text="")
|
2013-12-31 18:09:20 -06:00
|
|
|
|
|
|
|
col.separator()
|
|
|
|
|
2012-11-11 10:55:32 +00:00
|
|
|
col.prop(system, "multi_sample", text="")
|
2013-02-08 13:15:30 +00:00
|
|
|
if sys.platform == "linux" and system.multi_sample != 'NONE':
|
|
|
|
col.label(text="Might fail for Mesh editing selection!")
|
|
|
|
col.separator()
|
Holiday coding log :)
Nice formatted version (pictures soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.66/Usability
Short list of main changes:
- Transparent region option (over main region), added code to blend in/out such panels.
- Min size window now 640 x 480
- Fixed DPI for ui - lots of cleanup and changes everywhere. Icon image need correct size still, layer-in-use icon needs remake.
- Macbook retina support, use command line --no-native-pixels to disable it
- Timeline Marker label was drawing wrong
- Trackpad and magic mouse: supports zoom (hold ctrl)
- Fix for splash position: removed ghost function and made window size update after creation immediate
- Fast undo buffer save now adds UI as well. Could be checked for regular file save even...
Quit.blend and temp file saving use this now.
- Dixed filename in window on reading quit.blend or temp saves, and they now add a warning in window title: "(Recovered)"
- New Userpref option "Keep Session" - this always saves quit.blend, and loads on start.
This allows keeping UI and data without actual saves, until you actually save.
When you load startup.blend and quit, it recognises the quit.blend as a startup (no file name in header)
- Added 3D view copy/paste buffers (selected objects). Shortcuts ctrl-c, ctrl-v (OSX, cmd-c, cmd-v).
Coded partial file saving for it. Could be used for other purposes. Todo: use OS clipboards.
- User preferences (themes, keymaps, user settings) now can be saved as a separate file.
Old option is called "Save Startup File" the new one "Save User Settings".
To visualise this difference, the 'save startup file' button has been removed from user preferences window. That option is available as CTRL+U and in File menu still.
- OSX: fixed bug that stopped giving mouse events outside window.
This also fixes "Continuous Grab" for OSX. (error since 2009)
2012-12-12 18:58:11 +00:00
|
|
|
col.prop(system, "use_region_overlap")
|
2014-01-27 18:38:53 +11:00
|
|
|
|
2018-06-18 08:51:29 +02:00
|
|
|
col.separator()
|
2018-06-27 12:55:49 +02:00
|
|
|
col.prop(system, "gpu_viewport_quality")
|
2018-06-18 08:51:29 +02:00
|
|
|
|
2013-12-31 18:09:20 -06:00
|
|
|
col.separator()
|
2018-07-31 10:22:19 +02:00
|
|
|
col.label(text="Grease Pencil Options:")
|
|
|
|
col.prop(system, "gpencil_multi_sample", text="")
|
2013-12-31 18:09:20 -06:00
|
|
|
|
2018-07-31 10:22:19 +02:00
|
|
|
col.separator()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Text Draw Options:")
|
2018-08-14 17:53:27 +02:00
|
|
|
col.prop(system, "use_text_antialiasing", text="Anti-aliasing")
|
|
|
|
sub = col.column()
|
|
|
|
sub.active = system.use_text_antialiasing
|
|
|
|
sub.prop(system, "text_hinting", text="Hinting")
|
2014-01-27 18:38:53 +11:00
|
|
|
|
2010-01-09 15:49:27 +00:00
|
|
|
# 3. Column
|
2009-12-15 14:22:34 +00:00
|
|
|
column = split.column()
|
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
column.label(text="Textures:")
|
|
|
|
column.prop(system, "gl_texture_limit", text="Limit Size")
|
|
|
|
column.prop(system, "texture_time_out", text="Time Out")
|
|
|
|
column.prop(system, "texture_collection_rate", text="Collection Rate")
|
2009-12-15 14:22:34 +00:00
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
column.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
column.label(text="Images Draw Method:")
|
|
|
|
column.prop(system, "image_draw_method", text="")
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
column.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
column.label(text="Sequencer/Clip Editor:")
|
|
|
|
# currently disabled in the code
|
|
|
|
# column.prop(system, "prefetch_frames")
|
|
|
|
column.prop(system, "memory_cache_limit")
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2009-12-15 14:22:34 +00:00
|
|
|
column.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
column.label(text="Color Picker Type:")
|
2010-01-09 15:49:27 +00:00
|
|
|
column.row().prop(system, "color_picker_type", text="")
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-09 06:44:54 +00:00
|
|
|
column.separator()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
column.prop(system, "use_weight_color_range", text="Custom Weight Paint Range")
|
2010-01-09 15:49:27 +00:00
|
|
|
sub = column.column()
|
2009-12-15 14:22:34 +00:00
|
|
|
sub.active = system.use_weight_color_range
|
|
|
|
sub.template_color_ramp(system, "weight_color_range", expand=True)
|
|
|
|
|
2014-06-14 02:23:32 +10:00
|
|
|
column.separator()
|
|
|
|
column.prop(system, "font_path_ui")
|
2015-12-01 16:57:52 +11:00
|
|
|
column.prop(system, "font_path_ui_mono")
|
2014-06-14 02:23:32 +10:00
|
|
|
|
2013-01-04 04:43:49 +00:00
|
|
|
if bpy.app.build_options.international:
|
2012-12-18 18:25:48 +00:00
|
|
|
column.prop(system, "use_international_fonts")
|
2018-11-21 12:04:09 +01:00
|
|
|
sub_col = column.column()
|
|
|
|
sub_col.active = system.use_international_fonts
|
|
|
|
sub_col.prop(system, "language")
|
|
|
|
row = sub_col.row()
|
|
|
|
row.label(text="Translate:", text_ctxt=i18n_contexts.id_windowmanager)
|
|
|
|
row = sub_col.row(align=True)
|
|
|
|
row.prop(system, "use_translate_tooltips", text="Tooltips", toggle=True)
|
|
|
|
row.prop(system, "use_translate_interface", text="Interface", toggle=True)
|
|
|
|
row.prop(system, "use_translate_new_dataname", text="New Data", toggle=True)
|
2011-09-15 13:20:18 +00:00
|
|
|
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2012-01-10 15:08:12 +00:00
|
|
|
class USERPREF_MT_interface_theme_presets(Menu):
|
|
|
|
bl_label = "Presets"
|
|
|
|
preset_subdir = "interface_theme"
|
|
|
|
preset_operator = "script.execute_preset"
|
|
|
|
preset_type = 'XML'
|
2013-06-07 00:27:21 +00:00
|
|
|
preset_xml_map = (
|
|
|
|
("user_preferences.themes[0]", "Theme"),
|
|
|
|
("user_preferences.ui_styles[0]", "ThemeStyle"),
|
2018-02-01 14:58:05 +11:00
|
|
|
)
|
2012-01-10 15:08:12 +00:00
|
|
|
draw = Menu.draw_preset
|
|
|
|
|
2018-10-10 18:11:11 +02:00
|
|
|
def reset_cb(context):
|
2018-10-08 19:19:05 +02:00
|
|
|
bpy.ops.ui.reset_default_theme()
|
|
|
|
|
2012-01-10 15:08:12 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_theme(Panel):
|
2009-11-02 17:18:17 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "Themes"
|
2009-11-02 17:18:17 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-11-02 17:18:17 +00:00
|
|
|
|
2016-02-20 13:46:53 +01:00
|
|
|
# not essential, hard-coded UI delimiters for the theme layout
|
|
|
|
ui_delimiters = {
|
|
|
|
'VIEW_3D': {
|
|
|
|
"text_grease_pencil",
|
|
|
|
"text_keyframe",
|
|
|
|
"speaker",
|
|
|
|
"freestyle_face_mark",
|
|
|
|
"split_normal",
|
|
|
|
"bone_solid",
|
|
|
|
"paint_curve_pivot",
|
2018-02-01 14:58:05 +11:00
|
|
|
},
|
2016-02-20 13:46:53 +01:00
|
|
|
'GRAPH_EDITOR': {
|
|
|
|
"handle_vertex_select",
|
2018-02-01 14:58:05 +11:00
|
|
|
},
|
2016-02-20 13:46:53 +01:00
|
|
|
'IMAGE_EDITOR': {
|
|
|
|
"paint_curve_pivot",
|
2018-02-01 14:58:05 +11:00
|
|
|
},
|
2016-02-20 13:46:53 +01:00
|
|
|
'NODE_EDITOR': {
|
|
|
|
"layout_node",
|
2018-02-01 14:58:05 +11:00
|
|
|
},
|
2016-02-20 13:46:53 +01:00
|
|
|
'CLIP_EDITOR': {
|
|
|
|
"handle_vertex_select",
|
|
|
|
}
|
2018-02-01 14:58:05 +11:00
|
|
|
}
|
2016-02-20 13:46:53 +01:00
|
|
|
|
2010-06-26 17:24:01 +00:00
|
|
|
@staticmethod
|
2016-02-20 13:46:53 +01:00
|
|
|
def _theme_generic(split, themedata, theme_area):
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
col = split.column()
|
|
|
|
|
|
|
|
def theme_generic_recurse(data):
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text=data.rna_type.name)
|
2012-01-14 03:24:41 +00:00
|
|
|
row = col.row()
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding1 = subsplit.split(factor=0.15)
|
2012-01-14 03:24:41 +00:00
|
|
|
padding1.column()
|
2010-06-26 22:23:54 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
2010-06-26 22:23:54 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding2 = subsplit.split(factor=0.15)
|
2012-01-14 03:24:41 +00:00
|
|
|
padding2.column()
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
colsub_pair = padding1.column(), padding2.column()
|
2010-06-26 22:23:54 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
props_type = {}
|
2010-06-26 22:23:54 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
for i, prop in enumerate(data.rna_type.properties):
|
|
|
|
if prop.identifier == "rna_type":
|
|
|
|
continue
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
props_type.setdefault((prop.type, prop.subtype), []).append(prop)
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2016-02-20 13:46:53 +01:00
|
|
|
th_delimiters = USERPREF_PT_theme.ui_delimiters.get(theme_area)
|
2012-01-14 03:24:41 +00:00
|
|
|
for props_type, props_ls in sorted(props_type.items()):
|
|
|
|
if props_type[0] == 'POINTER':
|
|
|
|
for i, prop in enumerate(props_ls):
|
|
|
|
theme_generic_recurse(getattr(data, prop.identifier))
|
|
|
|
else:
|
2016-02-20 13:46:53 +01:00
|
|
|
if th_delimiters is None:
|
|
|
|
# simple, no delimiters
|
|
|
|
for i, prop in enumerate(props_ls):
|
|
|
|
colsub_pair[i % 2].row().prop(data, prop.identifier)
|
|
|
|
else:
|
|
|
|
# add hard coded delimiters
|
|
|
|
i = 0
|
|
|
|
for prop in props_ls:
|
|
|
|
colsub = colsub_pair[i]
|
|
|
|
colsub.row().prop(data, prop.identifier)
|
|
|
|
i = (i + 1) % 2
|
|
|
|
if prop.identifier in th_delimiters:
|
|
|
|
if i:
|
|
|
|
colsub = colsub_pair[1]
|
2018-08-28 12:34:51 +10:00
|
|
|
colsub.row().label(text="")
|
|
|
|
colsub_pair[0].row().label(text="")
|
|
|
|
colsub_pair[1].row().label(text="")
|
2016-02-20 13:46:53 +01:00
|
|
|
i = 0
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2012-01-14 03:24:41 +00:00
|
|
|
theme_generic_recurse(themedata)
|
2010-06-26 17:24:01 +00:00
|
|
|
|
2013-06-06 20:36:28 +00:00
|
|
|
@staticmethod
|
|
|
|
def _theme_widget_style(layout, widget_style):
|
|
|
|
|
|
|
|
row = layout.row()
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
2013-06-06 20:36:28 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2013-06-06 20:36:28 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(widget_style, "outline")
|
|
|
|
colsub.row().prop(widget_style, "item", slider=True)
|
|
|
|
colsub.row().prop(widget_style, "inner", slider=True)
|
|
|
|
colsub.row().prop(widget_style, "inner_sel", slider=True)
|
2018-04-22 13:57:42 +02:00
|
|
|
colsub.row().prop(widget_style, "roundness")
|
2013-06-06 20:36:28 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
2013-06-06 20:36:28 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2013-06-06 20:36:28 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(widget_style, "text")
|
|
|
|
colsub.row().prop(widget_style, "text_sel")
|
|
|
|
colsub.prop(widget_style, "show_shaded")
|
|
|
|
subsub = colsub.column(align=True)
|
|
|
|
subsub.active = widget_style.show_shaded
|
|
|
|
subsub.prop(widget_style, "shadetop")
|
|
|
|
subsub.prop(widget_style, "shadedown")
|
|
|
|
|
|
|
|
layout.separator()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def _ui_font_style(layout, font_style):
|
|
|
|
|
|
|
|
split = layout.split()
|
|
|
|
|
|
|
|
col = split.column()
|
|
|
|
col.label(text="Kerning Style:")
|
|
|
|
col.row().prop(font_style, "font_kerning_style", expand=True)
|
|
|
|
col.prop(font_style, "points")
|
|
|
|
|
|
|
|
col = split.column()
|
|
|
|
col.label(text="Shadow Offset:")
|
|
|
|
col.prop(font_style, "shadow_offset_x", text="X")
|
|
|
|
col.prop(font_style, "shadow_offset_y", text="Y")
|
|
|
|
|
|
|
|
col = split.column()
|
|
|
|
col.prop(font_style, "shadow")
|
|
|
|
col.prop(font_style, "shadow_alpha")
|
|
|
|
col.prop(font_style, "shadow_value")
|
|
|
|
|
|
|
|
layout.separator()
|
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-11-02 17:18:17 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'THEMES')
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2009-11-02 17:18:17 +00:00
|
|
|
theme = context.user_preferences.themes[0]
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
split_themes = layout.split(factor=0.2)
|
2012-01-10 16:30:16 +00:00
|
|
|
|
|
|
|
sub = split_themes.column()
|
|
|
|
|
|
|
|
sub.label(text="Presets:")
|
|
|
|
subrow = sub.row(align=True)
|
|
|
|
|
|
|
|
subrow.menu("USERPREF_MT_interface_theme_presets", text=USERPREF_MT_interface_theme_presets.bl_label)
|
2018-10-01 10:45:50 +02:00
|
|
|
subrow.operator("wm.interface_theme_preset_add", text="", icon='ADD')
|
|
|
|
subrow.operator("wm.interface_theme_preset_add", text="", icon='REMOVE').remove_active = True
|
2012-01-10 16:30:16 +00:00
|
|
|
sub.separator()
|
|
|
|
|
|
|
|
sub.prop(theme, "theme_area", expand=True)
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
split = layout.split(factor=0.4)
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2010-06-26 17:06:55 +00:00
|
|
|
layout.separator()
|
|
|
|
layout.separator()
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2010-06-26 20:00:45 +00:00
|
|
|
split = split_themes.split()
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-09 18:17:40 +00:00
|
|
|
if theme.theme_area == 'USER_INTERFACE':
|
2009-11-03 07:23:02 +00:00
|
|
|
col = split.column()
|
2013-06-06 20:36:28 +00:00
|
|
|
ui = theme.user_interface
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Regular:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_regular)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Tool:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_tool)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2018-04-26 21:17:33 +02:00
|
|
|
col.label(text="Toolbar Item:")
|
|
|
|
self._theme_widget_style(col, ui.wcol_toolbar_item)
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Radio Buttons:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_radio)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Text:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_text)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Option:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_option)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Toggle:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_toggle)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Number Field:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_num)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Value Slider:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_numslider)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Box:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_box)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Menu:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_menu)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
Pie Menus C code backend.
This commit merges the code in the pie-menu branch.
As per decisions taken the last few days, there are no pie menus
included and there will be an official add-on including overrides of
some keys with pie menus. However, people will now be able to use the
new code in python.
Full Documentation is in http://wiki.blender.org/index.php/Dev:Ref/
Thanks:
Campbell Barton, Dalai Felinto and Ton Roosendaal for the code review
and design comments
Jonathan Williamson, Pawel Lyczkowski, Pablo Vazquez among others for
suggestions during the development.
Special Thanks to Sean Olson, for his support, suggestions, testing and
merciless bugging so that I would finish the pie menu code. Without him
we wouldn't be here. Also to the rest of the developers of the original
python add-on, Patrick Moore and Dan Eicher and finally to Matt Ebb, who
did the research and first implementation and whose code I used to get
started.
2014-08-11 10:39:59 +02:00
|
|
|
col.label(text="Pie Menu:")
|
|
|
|
self._theme_widget_style(col, ui.wcol_pie_menu)
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Pulldown:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_pulldown)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Menu Back:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_menu_back)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2012-03-19 22:29:16 +00:00
|
|
|
col.label(text="Tooltip:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_tooltip)
|
2012-03-19 22:29:16 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Menu Item:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_menu_item)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Scroll Bar:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_scroll)
|
2010-06-09 19:12:03 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Progress Bar:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_progress)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="List Item:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._theme_widget_style(col, ui.wcol_list_item)
|
2009-11-03 07:23:02 +00:00
|
|
|
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
col.label(text="Tab:")
|
|
|
|
self._theme_widget_style(col, ui.wcol_tab)
|
|
|
|
|
2013-06-06 20:36:28 +00:00
|
|
|
ui_state = theme.user_interface.wcol_state
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="State:")
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2010-01-09 18:17:40 +00:00
|
|
|
row = col.row()
|
2010-06-26 17:06:55 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2010-06-26 17:06:55 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
2013-06-06 20:36:28 +00:00
|
|
|
colsub.row().prop(ui_state, "inner_anim")
|
|
|
|
colsub.row().prop(ui_state, "inner_anim_sel")
|
|
|
|
colsub.row().prop(ui_state, "inner_driven")
|
|
|
|
colsub.row().prop(ui_state, "inner_driven_sel")
|
2017-11-29 15:47:37 +01:00
|
|
|
colsub.row().prop(ui_state, "blend")
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2010-06-26 17:06:55 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
2013-06-06 20:36:28 +00:00
|
|
|
colsub.row().prop(ui_state, "inner_key")
|
|
|
|
colsub.row().prop(ui_state, "inner_key_sel")
|
2017-11-29 15:47:37 +01:00
|
|
|
colsub.row().prop(ui_state, "inner_overridden")
|
|
|
|
colsub.row().prop(ui_state, "inner_overridden_sel")
|
2010-06-26 17:06:55 +00:00
|
|
|
|
2011-11-19 20:57:53 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text="Styles:")
|
2012-12-20 16:50:39 +00:00
|
|
|
|
|
|
|
row = col.row()
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
2012-12-20 16:50:39 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2012-12-20 16:50:39 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "menu_shadow_fac")
|
2014-10-27 18:11:55 +01:00
|
|
|
colsub.row().prop(ui, "icon_alpha")
|
2018-04-28 13:34:52 +02:00
|
|
|
colsub.row().prop(ui, "icon_saturation")
|
2018-04-22 22:55:05 +02:00
|
|
|
colsub.row().prop(ui, "editor_outline")
|
2011-11-19 20:57:53 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
2011-11-19 20:57:53 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2011-11-19 20:57:53 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
2018-04-22 22:55:05 +02:00
|
|
|
colsub.row().prop(ui, "menu_shadow_width")
|
2014-12-08 00:38:36 +01:00
|
|
|
colsub.row().prop(ui, "widget_emboss")
|
2011-11-19 20:57:53 +00:00
|
|
|
|
2010-01-09 18:17:40 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2010-07-05 22:22:22 +00:00
|
|
|
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text="Axis & Gizmo Colors:")
|
Axis Colours are now Themeable
This commit allows you to set the RGB <-> XYZ axis colours used for things like
the mini axis indicator, grid axis indicators, manipulators, transform
constraint indicators, F-Curves (when using XYZ to RGB colouring option), and
perhaps something else I've missed. Previously, these places all used hardcoded
defines (220 * i/j/k), but the readability of these colours was often quite
poor, especially when used with certain themes.
The settings for these colours can be found under the "User Interface" section
of the themes (i.e. same set of colours is used across editors). I could have
made these per editor, but since it's unlikely that these will need to be too
different across editors in practice (+ being easier to version patch), they are
stored under the UI section.
2012-11-09 06:36:11 +00:00
|
|
|
|
|
|
|
row = col.row()
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
Axis Colours are now Themeable
This commit allows you to set the RGB <-> XYZ axis colours used for things like
the mini axis indicator, grid axis indicators, manipulators, transform
constraint indicators, F-Curves (when using XYZ to RGB colouring option), and
perhaps something else I've missed. Previously, these places all used hardcoded
defines (220 * i/j/k), but the readability of these colours was often quite
poor, especially when used with certain themes.
The settings for these colours can be found under the "User Interface" section
of the themes (i.e. same set of colours is used across editors). I could have
made these per editor, but since it's unlikely that these will need to be too
different across editors in practice (+ being easier to version patch), they are
stored under the UI section.
2012-11-09 06:36:11 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
Axis Colours are now Themeable
This commit allows you to set the RGB <-> XYZ axis colours used for things like
the mini axis indicator, grid axis indicators, manipulators, transform
constraint indicators, F-Curves (when using XYZ to RGB colouring option), and
perhaps something else I've missed. Previously, these places all used hardcoded
defines (220 * i/j/k), but the readability of these colours was often quite
poor, especially when used with certain themes.
The settings for these colours can be found under the "User Interface" section
of the themes (i.e. same set of colours is used across editors). I could have
made these per editor, but since it's unlikely that these will need to be too
different across editors in practice (+ being easier to version patch), they are
stored under the UI section.
2012-11-09 06:36:11 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "axis_x")
|
|
|
|
colsub.row().prop(ui, "axis_y")
|
|
|
|
colsub.row().prop(ui, "axis_z")
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
Axis Colours are now Themeable
This commit allows you to set the RGB <-> XYZ axis colours used for things like
the mini axis indicator, grid axis indicators, manipulators, transform
constraint indicators, F-Curves (when using XYZ to RGB colouring option), and
perhaps something else I've missed. Previously, these places all used hardcoded
defines (220 * i/j/k), but the readability of these colours was often quite
poor, especially when used with certain themes.
The settings for these colours can be found under the "User Interface" section
of the themes (i.e. same set of colours is used across editors). I could have
made these per editor, but since it's unlikely that these will need to be too
different across editors in practice (+ being easier to version patch), they are
stored under the UI section.
2012-11-09 06:36:11 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
Axis Colours are now Themeable
This commit allows you to set the RGB <-> XYZ axis colours used for things like
the mini axis indicator, grid axis indicators, manipulators, transform
constraint indicators, F-Curves (when using XYZ to RGB colouring option), and
perhaps something else I've missed. Previously, these places all used hardcoded
defines (220 * i/j/k), but the readability of these colours was often quite
poor, especially when used with certain themes.
The settings for these colours can be found under the "User Interface" section
of the themes (i.e. same set of colours is used across editors). I could have
made these per editor, but since it's unlikely that these will need to be too
different across editors in practice (+ being easier to version patch), they are
stored under the UI section.
2012-11-09 06:36:11 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
2018-07-14 23:49:00 +02:00
|
|
|
colsub.row().prop(ui, "gizmo_primary")
|
|
|
|
colsub.row().prop(ui, "gizmo_secondary")
|
|
|
|
colsub.row().prop(ui, "gizmo_a")
|
|
|
|
colsub.row().prop(ui, "gizmo_b")
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2017-08-08 17:06:24 +10:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2018-10-02 19:04:38 +02:00
|
|
|
|
|
|
|
col.label(text="Icon Colors:")
|
|
|
|
|
|
|
|
row = col.row()
|
|
|
|
|
|
|
|
subsplit = row.split(factor=0.95)
|
|
|
|
|
|
|
|
padding = subsplit.split(factor=0.15)
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "icon_collection")
|
|
|
|
colsub.row().prop(ui, "icon_object")
|
|
|
|
colsub.row().prop(ui, "icon_object_data")
|
|
|
|
|
|
|
|
subsplit = row.split(factor=0.85)
|
|
|
|
|
|
|
|
padding = subsplit.split(factor=0.15)
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "icon_modifier")
|
|
|
|
colsub.row().prop(ui, "icon_shading")
|
|
|
|
|
|
|
|
col.separator()
|
|
|
|
col.separator()
|
2011-03-28 11:01:24 +00:00
|
|
|
elif theme.theme_area == 'BONE_COLOR_SETS':
|
2011-02-14 03:43:28 +00:00
|
|
|
col = split.column()
|
2009-11-03 07:23:02 +00:00
|
|
|
|
2018-02-01 14:58:05 +11:00
|
|
|
for i, ui in enumerate(theme.bone_color_sets, 1):
|
2018-08-28 12:34:51 +10:00
|
|
|
col.label(text=iface_(f"Color Set {i:d}"), translate=False)
|
2011-02-16 02:25:03 +00:00
|
|
|
|
2011-02-14 03:43:28 +00:00
|
|
|
row = col.row()
|
2011-02-16 02:25:03 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.95)
|
2011-02-14 03:43:28 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2011-02-14 03:43:28 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "normal")
|
|
|
|
colsub.row().prop(ui, "select")
|
|
|
|
colsub.row().prop(ui, "active")
|
2011-02-16 02:25:03 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = row.split(factor=0.85)
|
2011-02-14 03:43:28 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
padding = subsplit.split(factor=0.15)
|
2011-02-14 03:43:28 +00:00
|
|
|
colsub = padding.column()
|
|
|
|
colsub = padding.column()
|
|
|
|
colsub.row().prop(ui, "show_colored_constraints")
|
2012-12-24 00:29:24 +00:00
|
|
|
elif theme.theme_area == 'STYLE':
|
|
|
|
col = split.column()
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2012-12-24 00:29:24 +00:00
|
|
|
style = context.user_preferences.ui_styles[0]
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2013-01-23 16:01:35 +00:00
|
|
|
col.label(text="Panel Title:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._ui_font_style(col, style.panel_title)
|
2013-01-23 16:01:35 +00:00
|
|
|
|
|
|
|
col.separator()
|
|
|
|
|
2012-12-24 00:29:24 +00:00
|
|
|
col.label(text="Widget:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._ui_font_style(col, style.widget)
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2012-12-24 00:29:24 +00:00
|
|
|
col.separator()
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2012-12-24 00:29:24 +00:00
|
|
|
col.label(text="Widget Label:")
|
2013-06-06 20:36:28 +00:00
|
|
|
self._ui_font_style(col, style.widget_label)
|
2010-06-26 17:24:01 +00:00
|
|
|
else:
|
2016-02-20 13:46:53 +01:00
|
|
|
self._theme_generic(split, getattr(theme, theme.theme_area.lower()), theme.theme_area)
|
2009-11-02 17:18:17 +00:00
|
|
|
|
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_file(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "Files"
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'FILES')
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
paths = userpref.filepaths
|
2012-01-09 16:58:01 +00:00
|
|
|
system = userpref.system
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
split = layout.split(factor=0.7)
|
2009-10-31 19:31:45 +00:00
|
|
|
|
|
|
|
col = split.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="File Paths:")
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = col.split(factor=0.95)
|
|
|
|
col1 = colsplit.split(factor=0.3)
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
sub = col1.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.label(text="Fonts:")
|
|
|
|
sub.label(text="Textures:")
|
|
|
|
sub.label(text="Render Output:")
|
|
|
|
sub.label(text="Scripts:")
|
|
|
|
sub.label(text="Sounds:")
|
|
|
|
sub.label(text="Temp:")
|
2014-06-28 19:13:54 +02:00
|
|
|
sub.label(text="Render Cache:")
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
sub.label(text="I18n Branches:")
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.label(text="Image Editor:")
|
|
|
|
sub.label(text="Animation Player:")
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
sub = col1.column()
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.prop(paths, "font_directory", text="")
|
|
|
|
sub.prop(paths, "texture_directory", text="")
|
2009-12-08 19:08:35 +00:00
|
|
|
sub.prop(paths, "render_output_directory", text="")
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.prop(paths, "script_directory", text="")
|
|
|
|
sub.prop(paths, "sound_directory", text="")
|
2009-11-23 00:27:30 +00:00
|
|
|
sub.prop(paths, "temporary_directory", text="")
|
2014-06-28 19:13:54 +02:00
|
|
|
sub.prop(paths, "render_cache_directory", text="")
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
sub.prop(paths, "i18n_branches_directory", text="")
|
2010-03-07 09:23:57 +00:00
|
|
|
sub.prop(paths, "image_editor", text="")
|
2018-08-28 12:38:54 +10:00
|
|
|
subsplit = sub.split(factor=0.3)
|
2009-12-11 08:05:05 +00:00
|
|
|
subsplit.prop(paths, "animation_player_preset", text="")
|
|
|
|
subsplit.prop(paths, "animation_player", text="")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2012-01-09 16:58:01 +00:00
|
|
|
col.separator()
|
|
|
|
col.separator()
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = col.split(factor=0.95)
|
2012-01-09 16:58:01 +00:00
|
|
|
sub = colsplit.column()
|
2013-06-18 18:11:52 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
row = sub.split(factor=0.3)
|
2013-06-18 18:11:52 +00:00
|
|
|
row.label(text="Auto Execution:")
|
|
|
|
row.prop(system, "use_scripts_auto_execute")
|
|
|
|
|
|
|
|
if system.use_scripts_auto_execute:
|
|
|
|
box = sub.box()
|
|
|
|
row = box.row()
|
|
|
|
row.label(text="Excluded Paths:")
|
2018-10-01 10:45:50 +02:00
|
|
|
row.operator("wm.userpref_autoexec_path_add", text="", icon='ADD', emboss=False)
|
2013-06-18 18:11:52 +00:00
|
|
|
for i, path_cmp in enumerate(userpref.autoexec_paths):
|
|
|
|
row = box.row()
|
|
|
|
row.prop(path_cmp, "path", text="")
|
|
|
|
row.prop(path_cmp, "use_glob", text="", icon='FILTER')
|
|
|
|
row.operator("wm.userpref_autoexec_path_remove", text="", icon='X', emboss=False).index = i
|
2012-01-09 16:58:01 +00:00
|
|
|
|
2009-10-31 19:31:45 +00:00
|
|
|
col = split.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Save & Load:")
|
2009-12-08 19:08:35 +00:00
|
|
|
col.prop(paths, "use_relative_paths")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(paths, "use_file_compression")
|
|
|
|
col.prop(paths, "use_load_ui")
|
|
|
|
col.prop(paths, "use_filter_files")
|
|
|
|
col.prop(paths, "show_hidden_files_datablocks")
|
2010-11-06 18:54:15 +00:00
|
|
|
col.prop(paths, "hide_recent_locations")
|
2012-10-21 14:47:16 +00:00
|
|
|
col.prop(paths, "hide_system_bookmarks")
|
2010-11-06 18:54:15 +00:00
|
|
|
col.prop(paths, "show_thumbnails")
|
2009-12-13 13:59:16 +00:00
|
|
|
|
2009-12-08 19:08:35 +00:00
|
|
|
col.separator()
|
|
|
|
|
|
|
|
col.prop(paths, "save_version")
|
|
|
|
col.prop(paths, "recent_files")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(paths, "use_save_preview_images")
|
2014-01-27 18:38:53 +11:00
|
|
|
|
2013-12-31 18:09:20 -06:00
|
|
|
col.separator()
|
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Auto Save:")
|
Holiday coding log :)
Nice formatted version (pictures soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.66/Usability
Short list of main changes:
- Transparent region option (over main region), added code to blend in/out such panels.
- Min size window now 640 x 480
- Fixed DPI for ui - lots of cleanup and changes everywhere. Icon image need correct size still, layer-in-use icon needs remake.
- Macbook retina support, use command line --no-native-pixels to disable it
- Timeline Marker label was drawing wrong
- Trackpad and magic mouse: supports zoom (hold ctrl)
- Fix for splash position: removed ghost function and made window size update after creation immediate
- Fast undo buffer save now adds UI as well. Could be checked for regular file save even...
Quit.blend and temp file saving use this now.
- Dixed filename in window on reading quit.blend or temp saves, and they now add a warning in window title: "(Recovered)"
- New Userpref option "Keep Session" - this always saves quit.blend, and loads on start.
This allows keeping UI and data without actual saves, until you actually save.
When you load startup.blend and quit, it recognises the quit.blend as a startup (no file name in header)
- Added 3D view copy/paste buffers (selected objects). Shortcuts ctrl-c, ctrl-v (OSX, cmd-c, cmd-v).
Coded partial file saving for it. Could be used for other purposes. Todo: use OS clipboards.
- User preferences (themes, keymaps, user settings) now can be saved as a separate file.
Old option is called "Save Startup File" the new one "Save User Settings".
To visualise this difference, the 'save startup file' button has been removed from user preferences window. That option is available as CTRL+U and in File menu still.
- OSX: fixed bug that stopped giving mouse events outside window.
This also fixes "Continuous Grab" for OSX. (error since 2009)
2012-12-12 18:58:11 +00:00
|
|
|
col.prop(paths, "use_keep_session")
|
2010-08-17 13:14:41 +00:00
|
|
|
col.prop(paths, "use_auto_save_temporary_files")
|
2009-12-08 19:08:35 +00:00
|
|
|
sub = col.column()
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.active = paths.use_auto_save_temporary_files
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.prop(paths, "auto_save_time", text="Timer (mins)")
|
2009-08-18 12:58:51 +00:00
|
|
|
|
2012-01-09 16:58:01 +00:00
|
|
|
col.separator()
|
|
|
|
|
2013-06-18 18:11:52 +00:00
|
|
|
col.label(text="Text Editor:")
|
2012-01-09 16:58:01 +00:00
|
|
|
col.prop(system, "use_tabs_as_spaces")
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = col.split(factor=0.95)
|
|
|
|
col1 = colsplit.split(factor=0.3)
|
2013-12-31 18:12:51 -06:00
|
|
|
|
|
|
|
sub = col1.column()
|
|
|
|
sub.label(text="Author:")
|
|
|
|
sub = col1.column()
|
|
|
|
sub.prop(system, "author", text="")
|
2013-06-18 18:11:52 +00:00
|
|
|
|
2012-01-09 16:58:01 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_MT_ndof_settings(Menu):
|
2012-02-08 04:37:37 +00:00
|
|
|
# accessed from the window key-bindings in C (only)
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "3D Mouse Settings"
|
2011-08-05 14:53:13 +00:00
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
2012-07-29 12:07:06 +00:00
|
|
|
|
2011-08-05 14:53:13 +00:00
|
|
|
input_prefs = context.user_preferences.inputs
|
|
|
|
|
2014-02-18 11:39:26 +11:00
|
|
|
is_view3d = context.space_data.type == 'VIEW_3D'
|
|
|
|
|
2014-02-20 10:00:16 +11:00
|
|
|
layout.prop(input_prefs, "ndof_sensitivity")
|
2014-03-11 23:40:11 +11:00
|
|
|
layout.prop(input_prefs, "ndof_orbit_sensitivity")
|
2015-07-01 13:45:19 +10:00
|
|
|
layout.prop(input_prefs, "ndof_deadzone")
|
2014-02-20 10:00:16 +11:00
|
|
|
|
2014-02-18 11:39:26 +11:00
|
|
|
if is_view3d:
|
2011-08-05 14:53:13 +00:00
|
|
|
layout.separator()
|
|
|
|
layout.prop(input_prefs, "ndof_show_guide")
|
|
|
|
|
|
|
|
layout.separator()
|
2017-09-02 15:42:29 +10:00
|
|
|
layout.label(text="Orbit Style")
|
2014-02-20 10:00:16 +11:00
|
|
|
layout.row().prop(input_prefs, "ndof_view_navigate_method", text="")
|
2012-09-28 12:37:14 +00:00
|
|
|
layout.row().prop(input_prefs, "ndof_view_rotate_method", text="")
|
2014-02-20 10:00:16 +11:00
|
|
|
layout.separator()
|
2017-09-02 15:42:29 +10:00
|
|
|
layout.label(text="Orbit Options")
|
2014-02-18 23:51:11 +11:00
|
|
|
layout.prop(input_prefs, "ndof_rotx_invert_axis")
|
|
|
|
layout.prop(input_prefs, "ndof_roty_invert_axis")
|
|
|
|
layout.prop(input_prefs, "ndof_rotz_invert_axis")
|
2011-09-07 10:33:46 +00:00
|
|
|
|
2014-02-18 11:39:26 +11:00
|
|
|
# view2d use pan/zoom
|
|
|
|
layout.separator()
|
2017-09-02 15:42:29 +10:00
|
|
|
layout.label(text="Pan Options")
|
2014-02-18 11:39:26 +11:00
|
|
|
layout.prop(input_prefs, "ndof_panx_invert_axis")
|
|
|
|
layout.prop(input_prefs, "ndof_pany_invert_axis")
|
|
|
|
layout.prop(input_prefs, "ndof_panz_invert_axis")
|
|
|
|
layout.prop(input_prefs, "ndof_pan_yz_swap_axis")
|
|
|
|
|
2017-09-02 15:42:29 +10:00
|
|
|
layout.label(text="Zoom Options")
|
2014-02-18 11:39:26 +11:00
|
|
|
layout.prop(input_prefs, "ndof_zoom_invert")
|
2011-11-14 14:02:19 +00:00
|
|
|
|
2014-02-18 11:39:26 +11:00
|
|
|
if is_view3d:
|
2011-08-05 14:53:13 +00:00
|
|
|
layout.separator()
|
2017-09-02 15:42:29 +10:00
|
|
|
layout.label(text="Fly/Walk Options")
|
2011-08-05 14:53:13 +00:00
|
|
|
layout.prop(input_prefs, "ndof_fly_helicopter", icon='NDOF_FLY')
|
|
|
|
layout.prop(input_prefs, "ndof_lock_horizon", icon='NDOF_DOM')
|
|
|
|
|
|
|
|
|
2013-07-08 07:25:33 +00:00
|
|
|
class USERPREF_MT_keyconfigs(Menu):
|
|
|
|
bl_label = "KeyPresets"
|
|
|
|
preset_subdir = "keyconfig"
|
|
|
|
preset_operator = "wm.keyconfig_activate"
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
Menu.draw_preset(self, context)
|
|
|
|
|
|
|
|
|
|
|
|
class USERPREF_PT_input(Panel):
|
2009-10-31 19:31:45 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2011-09-15 13:20:18 +00:00
|
|
|
bl_label = "Input"
|
2013-07-08 07:25:33 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
|
|
|
bl_options = {'HIDE_HEADER'}
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2009-10-31 19:31:45 +00:00
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'INPUT')
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2015-06-07 17:40:39 +10:00
|
|
|
@staticmethod
|
|
|
|
def draw_input_prefs(inputs, layout):
|
2013-02-08 12:12:57 +00:00
|
|
|
import sys
|
|
|
|
|
2009-12-16 10:13:26 +00:00
|
|
|
# General settings
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column()
|
2010-04-17 19:05:53 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.label(text="Mouse:")
|
2018-11-16 08:28:58 +11:00
|
|
|
sub.prop(inputs, "use_mouse_emulate_3_button")
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.prop(inputs, "use_mouse_continuous")
|
2011-01-03 17:01:08 +00:00
|
|
|
sub.prop(inputs, "drag_threshold")
|
2012-02-20 15:29:02 +00:00
|
|
|
sub.prop(inputs, "tweak_threshold")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column()
|
2015-04-07 14:08:30 +02:00
|
|
|
sub.label(text="Double Click:")
|
|
|
|
sub.prop(inputs, "mouse_double_click_time", text="Speed")
|
|
|
|
|
2009-11-23 00:27:30 +00:00
|
|
|
sub.separator()
|
2009-11-22 16:33:47 +00:00
|
|
|
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.prop(inputs, "use_emulate_numpad")
|
2009-11-22 16:33:47 +00:00
|
|
|
|
2009-11-23 00:27:30 +00:00
|
|
|
sub.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.label(text="Orbit Style:")
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.row().prop(inputs, "view_rotate_method", expand=True)
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2013-12-31 18:53:12 -06:00
|
|
|
sub.separator()
|
2014-01-27 18:38:53 +11:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.label(text="Zoom Style:")
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.row().prop(inputs, "view_zoom_method", text="")
|
2011-04-22 14:47:35 +00:00
|
|
|
if inputs.view_zoom_method in {'DOLLY', 'CONTINUE'}:
|
2010-08-17 13:14:41 +00:00
|
|
|
sub.row().prop(inputs, "view_zoom_axis", expand=True)
|
2013-12-31 18:53:12 -06:00
|
|
|
sub.prop(inputs, "invert_mouse_zoom", text="Invert Mouse Zoom Direction")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2010-08-17 13:14:41 +00:00
|
|
|
#sub.prop(inputs, "use_mouse_mmb_paste")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
# layout.separator()
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column()
|
2011-09-21 15:18:38 +00:00
|
|
|
sub.prop(inputs, "invert_zoom_wheel", text="Invert Wheel Zoom Direction")
|
2009-11-23 00:27:30 +00:00
|
|
|
#sub.prop(view, "wheel_scroll_lines", text="Scroll Lines")
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2013-02-08 12:12:57 +00:00
|
|
|
if sys.platform == "darwin":
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column()
|
2013-12-31 18:53:12 -06:00
|
|
|
sub.prop(inputs, "use_trackpad_natural", text="Natural Trackpad Direction")
|
2013-02-08 12:12:57 +00:00
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
layout.separator()
|
|
|
|
sub = layout.column()
|
2013-12-03 03:14:09 -02:00
|
|
|
sub.label(text="View Navigation:")
|
|
|
|
sub.row().prop(inputs, "navigation_mode", expand=True)
|
|
|
|
|
2017-04-10 17:44:03 -04:00
|
|
|
sub.label(text="Walk Navigation:")
|
2013-12-03 03:14:09 -02:00
|
|
|
|
2017-04-10 17:44:03 -04:00
|
|
|
walk = inputs.walk_navigation
|
2013-12-03 03:14:09 -02:00
|
|
|
|
2017-04-10 17:44:03 -04:00
|
|
|
sub.prop(walk, "use_mouse_reverse")
|
|
|
|
sub.prop(walk, "mouse_speed")
|
|
|
|
sub.prop(walk, "teleport_time")
|
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column(align=True)
|
2017-04-10 17:44:03 -04:00
|
|
|
sub.prop(walk, "walk_speed")
|
|
|
|
sub.prop(walk, "walk_speed_factor")
|
|
|
|
|
|
|
|
sub.separator()
|
|
|
|
sub.prop(walk, "use_gravity")
|
2018-11-18 11:16:25 +11:00
|
|
|
sub = layout.column(align=True)
|
2017-04-10 17:44:03 -04:00
|
|
|
sub.active = walk.use_gravity
|
|
|
|
sub.prop(walk, "view_height")
|
|
|
|
sub.prop(walk, "jump_height")
|
2013-12-03 03:14:09 -02:00
|
|
|
|
2018-11-20 15:35:59 +03:00
|
|
|
sub.separator()
|
|
|
|
sub = layout.column()
|
|
|
|
sub.label(text="Tablet Pressure:")
|
|
|
|
sub.prop(inputs, "pressure_threshold_max")
|
|
|
|
sub.prop(inputs, "pressure_softness")
|
|
|
|
|
2016-08-18 00:21:55 -04:00
|
|
|
if inputs.use_ndof:
|
2018-11-18 11:16:25 +11:00
|
|
|
layout.separator()
|
|
|
|
layout.label(text="NDOF Device:")
|
|
|
|
sub = layout.column(align=True)
|
2016-12-29 01:09:11 -05:00
|
|
|
sub.prop(inputs, "ndof_sensitivity", text="Pan Sensitivity")
|
|
|
|
sub.prop(inputs, "ndof_orbit_sensitivity", text="Orbit Sensitivity")
|
|
|
|
sub.prop(inputs, "ndof_deadzone", text="Deadzone")
|
|
|
|
|
|
|
|
sub.separator()
|
2018-11-18 11:16:25 +11:00
|
|
|
layout.label(text="Navigation Style:")
|
|
|
|
sub = layout.column(align=True)
|
2016-08-18 00:21:55 -04:00
|
|
|
sub.row().prop(inputs, "ndof_view_navigate_method", expand=True)
|
2016-12-29 01:09:11 -05:00
|
|
|
|
|
|
|
sub.separator()
|
2018-11-18 11:16:25 +11:00
|
|
|
layout.label(text="Rotation Style:")
|
|
|
|
sub = layout.column(align=True)
|
2016-08-18 00:21:55 -04:00
|
|
|
sub.row().prop(inputs, "ndof_view_rotate_method", expand=True)
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-16 10:13:26 +00:00
|
|
|
def draw(self, context):
|
2013-07-08 22:57:51 +00:00
|
|
|
from rna_keymap_ui import draw_keymaps
|
2013-07-08 07:25:33 +00:00
|
|
|
|
2009-12-16 10:13:26 +00:00
|
|
|
layout = self.layout
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-29 02:01:02 +00:00
|
|
|
#import time
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-29 02:01:02 +00:00
|
|
|
#start = time.time()
|
2009-12-16 10:13:26 +00:00
|
|
|
|
|
|
|
userpref = context.user_preferences
|
2009-10-31 19:31:45 +00:00
|
|
|
|
2009-12-16 10:13:26 +00:00
|
|
|
inputs = userpref.inputs
|
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
split = layout.split(factor=0.25)
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2018-11-18 11:16:25 +11:00
|
|
|
row = split.row()
|
|
|
|
col = row.column()
|
|
|
|
|
2009-12-16 10:13:26 +00:00
|
|
|
# Input settings
|
2018-11-18 11:16:25 +11:00
|
|
|
self.draw_input_prefs(inputs, col)
|
|
|
|
|
|
|
|
row.separator()
|
2009-12-17 01:21:55 +00:00
|
|
|
|
2009-10-31 19:31:45 +00:00
|
|
|
# Keymap Settings
|
2018-11-20 09:15:53 +11:00
|
|
|
col = split.column()
|
|
|
|
draw_keymaps(context, col)
|
2010-01-31 14:46:28 +00:00
|
|
|
|
2010-01-29 02:01:02 +00:00
|
|
|
#print("runtime", time.time() - start)
|
Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
to .py files as well to make creating distributable configurations
easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
2009-10-08 18:40:03 +00:00
|
|
|
|
2011-01-01 07:20:34 +00:00
|
|
|
|
2016-01-08 04:58:22 +11:00
|
|
|
class USERPREF_MT_addons_online_resources(Menu):
|
|
|
|
bl_label = "Online Resources"
|
2010-11-28 18:22:23 +00:00
|
|
|
|
2012-02-08 04:37:37 +00:00
|
|
|
# menu to open web-pages with addons development guides
|
2010-11-28 18:22:23 +00:00
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
2012-07-29 12:07:06 +00:00
|
|
|
|
2016-01-08 04:58:22 +11:00
|
|
|
layout.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.url_open", text="Add-ons Catalog", icon='URL',
|
|
|
|
).url = "http://wiki.blender.org/index.php/Extensions:2.6/Py/Scripts"
|
2016-01-08 04:58:22 +11:00
|
|
|
|
|
|
|
layout.separator()
|
|
|
|
|
|
|
|
layout.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.url_open", text="How to share your add-on", icon='URL',
|
|
|
|
).url = "http://wiki.blender.org/index.php/Dev:Py/Sharing"
|
|
|
|
layout.operator(
|
|
|
|
"wm.url_open", text="Add-on Guidelines", icon='URL',
|
|
|
|
).url = "http://wiki.blender.org/index.php/Dev:2.5/Py/Scripts/Guidelines/Addons"
|
2016-01-08 04:58:22 +11:00
|
|
|
layout.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.url_open", text="API Concepts", icon='URL',
|
|
|
|
).url = bpy.types.WM_OT_doc_view._prefix + "/info_quickstart.html"
|
2016-01-08 04:58:22 +11:00
|
|
|
layout.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.url_open", text="Add-on Tutorial", icon='URL',
|
|
|
|
).url = bpy.types.WM_OT_doc_view._prefix + "/info_tutorial_addon.html"
|
2010-11-28 18:22:23 +00:00
|
|
|
|
Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
to .py files as well to make creating distributable configurations
easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
2009-10-08 18:40:03 +00:00
|
|
|
|
2011-08-12 06:57:00 +00:00
|
|
|
class USERPREF_PT_addons(Panel):
|
2010-02-14 23:33:18 +00:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
2014-11-14 12:17:25 +01:00
|
|
|
bl_label = "Add-ons"
|
2010-02-14 23:33:18 +00:00
|
|
|
bl_region_type = 'WINDOW'
|
2010-08-26 01:05:37 +00:00
|
|
|
bl_options = {'HIDE_HEADER'}
|
2010-09-07 15:17:42 +00:00
|
|
|
|
2011-11-17 20:11:20 +00:00
|
|
|
_support_icon_mapping = {
|
|
|
|
'OFFICIAL': 'FILE_BLEND',
|
2018-11-22 15:31:19 +11:00
|
|
|
'COMMUNITY': 'COMUNITY',
|
|
|
|
'TESTING': 'EXPERIMENTAL',
|
2018-06-05 16:32:11 +02:00
|
|
|
}
|
2011-11-17 20:11:20 +00:00
|
|
|
|
2010-08-09 01:37:09 +00:00
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
2010-02-14 23:33:18 +00:00
|
|
|
userpref = context.user_preferences
|
2010-02-26 14:28:29 +00:00
|
|
|
return (userpref.active_section == 'ADDONS')
|
2010-02-14 23:33:18 +00:00
|
|
|
|
2011-06-29 15:56:22 +00:00
|
|
|
@staticmethod
|
|
|
|
def is_user_addon(mod, user_addon_paths):
|
2013-02-08 11:23:22 +00:00
|
|
|
import os
|
|
|
|
|
2011-06-29 15:56:22 +00:00
|
|
|
if not user_addon_paths:
|
2018-02-01 14:58:05 +11:00
|
|
|
for path in (
|
|
|
|
bpy.utils.script_path_user(),
|
|
|
|
bpy.utils.script_path_pref(),
|
|
|
|
):
|
2012-07-29 01:02:25 +00:00
|
|
|
if path is not None:
|
|
|
|
user_addon_paths.append(os.path.join(path, "addons"))
|
2011-07-01 12:33:34 +00:00
|
|
|
|
2011-06-29 15:56:22 +00:00
|
|
|
for path in user_addon_paths:
|
|
|
|
if bpy.path.is_subdir(mod.__file__, path):
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
2011-07-18 05:41:46 +00:00
|
|
|
@staticmethod
|
|
|
|
def draw_error(layout, message):
|
|
|
|
lines = message.split("\n")
|
|
|
|
box = layout.box()
|
2013-04-13 22:52:28 +00:00
|
|
|
sub = box.row()
|
2018-08-28 12:34:51 +10:00
|
|
|
sub.label(text=lines[0])
|
2013-04-13 22:52:28 +00:00
|
|
|
sub.label(icon='ERROR')
|
2011-07-18 05:41:46 +00:00
|
|
|
for l in lines[1:]:
|
2018-08-28 12:34:51 +10:00
|
|
|
box.label(text=l)
|
2011-07-18 05:41:46 +00:00
|
|
|
|
2010-02-14 23:33:18 +00:00
|
|
|
def draw(self, context):
|
2013-02-08 11:23:22 +00:00
|
|
|
import os
|
2012-10-01 02:04:06 +00:00
|
|
|
import addon_utils
|
|
|
|
|
2010-02-14 23:33:18 +00:00
|
|
|
layout = self.layout
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
2010-02-26 14:28:29 +00:00
|
|
|
used_ext = {ext.module for ext in userpref.addons}
|
2010-03-14 23:26:17 +00:00
|
|
|
|
2018-11-08 09:54:13 +11:00
|
|
|
addon_user_dirs = tuple(
|
|
|
|
p for p in (
|
|
|
|
os.path.join(userpref.filepaths.script_directory, "addons"),
|
|
|
|
bpy.utils.user_resource('SCRIPTS', "addons"),
|
|
|
|
)
|
|
|
|
if p
|
|
|
|
)
|
2013-01-15 23:15:32 +00:00
|
|
|
|
2018-11-08 10:10:08 +11:00
|
|
|
# Development option for 2.8x, don't show users bundled addons
|
|
|
|
# unless they have been updated for 2.8x.
|
|
|
|
# Developers can turn them on with '--debug'
|
|
|
|
show_official_27x_addons = bpy.app.debug
|
|
|
|
|
2010-03-13 00:14:36 +00:00
|
|
|
# collect the categories that can be filtered on
|
2018-02-01 14:58:05 +11:00
|
|
|
addons = [
|
|
|
|
(mod, addon_utils.module_bl_info(mod))
|
|
|
|
for mod in addon_utils.modules(refresh=False)
|
|
|
|
]
|
2010-03-14 20:07:15 +00:00
|
|
|
|
2018-08-28 12:38:54 +10:00
|
|
|
split = layout.split(factor=0.2)
|
2010-06-27 19:04:44 +00:00
|
|
|
col = split.column()
|
2010-09-09 14:22:03 +00:00
|
|
|
col.prop(context.window_manager, "addon_search", text="", icon='VIEWZOOM')
|
2011-01-01 07:20:34 +00:00
|
|
|
|
2011-09-21 15:18:38 +00:00
|
|
|
col.label(text="Supported Level")
|
2011-01-14 16:49:43 +00:00
|
|
|
col.prop(context.window_manager, "addon_support", expand=True)
|
2010-06-27 19:04:44 +00:00
|
|
|
|
2011-11-17 20:11:20 +00:00
|
|
|
col.label(text="Categories")
|
|
|
|
col.prop(context.window_manager, "addon_filter", expand=True)
|
|
|
|
|
2010-06-27 19:04:44 +00:00
|
|
|
col = split.column()
|
2010-02-14 23:33:18 +00:00
|
|
|
|
2013-08-28 06:36:54 +00:00
|
|
|
# set in addon_utils.modules_refresh()
|
2011-07-18 05:41:46 +00:00
|
|
|
if addon_utils.error_duplicates:
|
2017-02-27 03:54:12 +11:00
|
|
|
box = col.box()
|
|
|
|
row = box.row()
|
2018-08-28 12:34:51 +10:00
|
|
|
row.label(text="Multiple add-ons with the same name found!")
|
2017-02-27 03:54:12 +11:00
|
|
|
row.label(icon='ERROR')
|
2018-09-04 18:44:05 +10:00
|
|
|
box.label(text="Delete one of each pair to resolve:")
|
2017-02-27 03:54:12 +11:00
|
|
|
for (addon_name, addon_file, addon_path) in addon_utils.error_duplicates:
|
|
|
|
box.separator()
|
|
|
|
sub_col = box.column(align=True)
|
2018-08-28 12:34:51 +10:00
|
|
|
sub_col.label(text=addon_name + ":")
|
|
|
|
sub_col.label(text=" " + addon_file)
|
|
|
|
sub_col.label(text=" " + addon_path)
|
2017-02-27 03:54:12 +11:00
|
|
|
|
2011-08-07 04:55:58 +00:00
|
|
|
if addon_utils.error_encoding:
|
2018-02-01 14:58:05 +11:00
|
|
|
self.draw_error(
|
|
|
|
col,
|
|
|
|
"One or more addons do not have UTF-8 encoding\n"
|
|
|
|
"(see console for details)",
|
|
|
|
)
|
2011-08-07 04:55:58 +00:00
|
|
|
|
2010-09-09 14:22:03 +00:00
|
|
|
filter = context.window_manager.addon_filter
|
|
|
|
search = context.window_manager.addon_search.lower()
|
2011-01-14 16:49:43 +00:00
|
|
|
support = context.window_manager.addon_support
|
2010-03-14 20:07:15 +00:00
|
|
|
|
2011-06-29 15:56:22 +00:00
|
|
|
# initialized on demand
|
|
|
|
user_addon_paths = []
|
|
|
|
|
2010-03-14 23:19:44 +00:00
|
|
|
for mod, info in addons:
|
2010-03-14 20:07:15 +00:00
|
|
|
module_name = mod.__name__
|
2010-03-14 23:19:44 +00:00
|
|
|
|
2010-04-21 16:50:51 +00:00
|
|
|
is_enabled = module_name in used_ext
|
|
|
|
|
2011-01-14 16:49:43 +00:00
|
|
|
if info["support"] not in support:
|
|
|
|
continue
|
|
|
|
|
2011-10-23 17:52:20 +00:00
|
|
|
# check if addon should be visible with current filters
|
2018-06-20 18:21:01 +02:00
|
|
|
if (
|
|
|
|
(filter == "All") or
|
|
|
|
(filter == info["category"]) or
|
|
|
|
(filter == "Enabled" and is_enabled) or
|
2018-06-05 16:32:11 +02:00
|
|
|
(filter == "Disabled" and not is_enabled) or
|
2018-11-08 09:54:13 +11:00
|
|
|
(filter == "User" and (mod.__file__.startswith(addon_user_dirs)))
|
2018-06-20 18:21:01 +02:00
|
|
|
):
|
2010-04-21 16:50:51 +00:00
|
|
|
if search and search not in info["name"].lower():
|
|
|
|
if info["author"]:
|
|
|
|
if search not in info["author"].lower():
|
|
|
|
continue
|
|
|
|
else:
|
2010-03-13 00:14:36 +00:00
|
|
|
continue
|
2010-04-21 16:50:51 +00:00
|
|
|
|
2018-11-08 10:10:08 +11:00
|
|
|
# Skip 2.7x add-ons included with Blender, unless in debug mode.
|
|
|
|
is_addon_27x = info.get("blender", (0,)) < (2, 80)
|
|
|
|
if (
|
|
|
|
is_addon_27x and
|
|
|
|
(not show_official_27x_addons) and
|
|
|
|
(not mod.__file__.startswith(addon_user_dirs))
|
|
|
|
):
|
|
|
|
continue
|
|
|
|
|
2010-04-21 16:50:51 +00:00
|
|
|
# Addon UI Code
|
2012-12-29 10:24:42 +00:00
|
|
|
col_box = col.column()
|
|
|
|
box = col_box.box()
|
2010-06-27 19:04:44 +00:00
|
|
|
colsub = box.column()
|
2016-01-11 20:22:14 +11:00
|
|
|
row = colsub.row(align=True)
|
2010-04-21 16:50:51 +00:00
|
|
|
|
2016-01-11 20:22:14 +11:00
|
|
|
row.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.addon_expand",
|
2018-11-22 15:31:19 +11:00
|
|
|
icon='DISCLOSURE_TRI_DOWN' if info["show_expanded"] else 'DISCLOSURE_TRI_RIGHT',
|
2018-02-01 14:58:05 +11:00
|
|
|
emboss=False,
|
|
|
|
).module = module_name
|
2016-01-11 20:22:14 +11:00
|
|
|
|
|
|
|
row.operator(
|
2018-02-01 14:58:05 +11:00
|
|
|
"wm.addon_disable" if is_enabled else "wm.addon_enable",
|
|
|
|
icon='CHECKBOX_HLT' if is_enabled else 'CHECKBOX_DEHLT', text="",
|
|
|
|
emboss=False,
|
|
|
|
).module = module_name
|
2010-06-17 02:38:49 +00:00
|
|
|
|
2013-04-13 22:52:28 +00:00
|
|
|
sub = row.row()
|
|
|
|
sub.active = is_enabled
|
2017-09-02 15:42:29 +10:00
|
|
|
sub.label(text="%s: %s" % (info["category"], info["name"]))
|
2018-07-03 07:58:10 +02:00
|
|
|
|
|
|
|
# WARNING: 2.8x exception, may be removed
|
|
|
|
# use disabled state for old add-ons, chances are they are broken.
|
2018-11-08 10:10:08 +11:00
|
|
|
if is_addon_27x:
|
2018-07-03 07:58:10 +02:00
|
|
|
sub.label(text="upgrade to 2.8x required")
|
|
|
|
sub.label(icon='ERROR')
|
|
|
|
# Remove code above after 2.8x migration is complete.
|
|
|
|
elif info["warning"]:
|
2013-04-13 22:52:28 +00:00
|
|
|
sub.label(icon='ERROR')
|
2010-06-17 02:38:49 +00:00
|
|
|
|
2011-01-14 16:49:43 +00:00
|
|
|
# icon showing support level.
|
2013-04-13 22:52:28 +00:00
|
|
|
sub.label(icon=self._support_icon_mapping.get(info["support"], 'QUESTION'))
|
2011-01-14 16:49:43 +00:00
|
|
|
|
2012-02-08 04:37:37 +00:00
|
|
|
# Expanded UI (only if additional info is available)
|
2010-08-17 17:03:52 +00:00
|
|
|
if info["show_expanded"]:
|
2010-06-17 02:38:49 +00:00
|
|
|
if info["description"]:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Description:")
|
2010-06-17 02:38:49 +00:00
|
|
|
split.label(text=info["description"])
|
|
|
|
if info["location"]:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Location:")
|
2010-06-17 02:38:49 +00:00
|
|
|
split.label(text=info["location"])
|
2012-04-11 11:22:19 +00:00
|
|
|
if mod:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2012-04-11 11:22:19 +00:00
|
|
|
split.label(text="File:")
|
2013-02-08 16:41:02 +00:00
|
|
|
split.label(text=mod.__file__, translate=False)
|
2010-04-21 16:50:51 +00:00
|
|
|
if info["author"]:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Author:")
|
2013-02-08 16:41:02 +00:00
|
|
|
split.label(text=info["author"], translate=False)
|
2010-04-21 16:50:51 +00:00
|
|
|
if info["version"]:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Version:")
|
2017-09-02 15:42:29 +10:00
|
|
|
split.label(text=".".join(str(x) for x in info["version"]), translate=False)
|
2010-06-17 02:38:49 +00:00
|
|
|
if info["warning"]:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Warning:")
|
2017-09-02 15:42:29 +10:00
|
|
|
split.label(text=" " + info["warning"], icon='ERROR')
|
2011-06-29 15:56:22 +00:00
|
|
|
|
2011-07-11 05:50:49 +00:00
|
|
|
user_addon = USERPREF_PT_addons.is_user_addon(mod, user_addon_paths)
|
2013-11-16 03:08:51 +01:00
|
|
|
tot_row = bool(info["wiki_url"]) + bool(user_addon)
|
2011-06-29 15:56:22 +00:00
|
|
|
|
|
|
|
if tot_row:
|
2018-08-28 12:38:54 +10:00
|
|
|
split = colsub.row().split(factor=0.15)
|
2011-09-21 15:18:38 +00:00
|
|
|
split.label(text="Internet:")
|
2010-05-30 20:48:09 +00:00
|
|
|
if info["wiki_url"]:
|
2018-02-01 14:58:05 +11:00
|
|
|
split.operator(
|
|
|
|
"wm.url_open", text="Documentation", icon='HELP',
|
|
|
|
).url = info["wiki_url"]
|
2018-03-09 21:17:43 +01:00
|
|
|
# Only add "Report a Bug" button if tracker_url is set
|
|
|
|
# or the add-on is bundled (use official tracker then).
|
|
|
|
if info.get("tracker_url") or not user_addon:
|
|
|
|
split.operator(
|
|
|
|
"wm.url_open", text="Report a Bug", icon='URL',
|
|
|
|
).url = info.get(
|
|
|
|
"tracker_url",
|
|
|
|
"https://developer.blender.org/maniphest/task/edit/form/2",
|
|
|
|
)
|
2011-06-29 15:56:22 +00:00
|
|
|
if user_addon:
|
2018-02-01 14:58:05 +11:00
|
|
|
split.operator(
|
|
|
|
"wm.addon_remove", text="Remove", icon='CANCEL',
|
|
|
|
).module = mod.__name__
|
2010-06-09 19:12:03 +00:00
|
|
|
|
2018-10-25 12:03:34 +11:00
|
|
|
for _ in range(4 - tot_row):
|
2010-05-30 20:48:09 +00:00
|
|
|
split.separator()
|
2010-02-14 23:33:18 +00:00
|
|
|
|
2012-12-29 10:24:42 +00:00
|
|
|
# Show addon user preferences
|
|
|
|
if is_enabled:
|
|
|
|
addon_preferences = userpref.addons[module_name].preferences
|
|
|
|
if addon_preferences is not None:
|
|
|
|
draw = getattr(addon_preferences, "draw", None)
|
|
|
|
if draw is not None:
|
|
|
|
addon_preferences_class = type(addon_preferences)
|
|
|
|
box_prefs = col_box.box()
|
2018-08-28 12:34:51 +10:00
|
|
|
box_prefs.label(text="Preferences:")
|
2012-12-29 10:24:42 +00:00
|
|
|
addon_preferences_class.layout = box_prefs
|
|
|
|
try:
|
|
|
|
draw(context)
|
|
|
|
except:
|
|
|
|
import traceback
|
|
|
|
traceback.print_exc()
|
|
|
|
box_prefs.label(text="Error (see console)", icon='ERROR')
|
|
|
|
del addon_preferences_class.layout
|
|
|
|
|
merge own commits into render branch into trunk since 27560
27562, 27570, 27571, 27574, 27576, 27577, 27579, 27590, 27591, 27594, 27595, 27596, 27599, 27605, 27611, 27612, 27613, 27614, 27623
2010-03-20 16:41:01 +00:00
|
|
|
# Append missing scripts
|
|
|
|
# First collect scripts that are used but have no script file.
|
|
|
|
module_names = {mod.__name__ for mod, info in addons}
|
|
|
|
missing_modules = {ext for ext in used_ext if ext not in module_names}
|
|
|
|
|
2011-03-07 13:23:45 +00:00
|
|
|
if missing_modules and filter in {"All", "Enabled"}:
|
2010-06-27 19:04:44 +00:00
|
|
|
col.column().separator()
|
2011-09-21 15:18:38 +00:00
|
|
|
col.column().label(text="Missing script files")
|
merge own commits into render branch into trunk since 27560
27562, 27570, 27571, 27574, 27576, 27577, 27579, 27590, 27591, 27594, 27595, 27596, 27599, 27605, 27611, 27612, 27613, 27614, 27623
2010-03-20 16:41:01 +00:00
|
|
|
|
|
|
|
module_names = {mod.__name__ for mod, info in addons}
|
2010-09-25 06:36:01 +00:00
|
|
|
for module_name in sorted(missing_modules):
|
|
|
|
is_enabled = module_name in used_ext
|
merge own commits into render branch into trunk since 27560
27562, 27570, 27571, 27574, 27576, 27577, 27579, 27590, 27591, 27594, 27595, 27596, 27599, 27605, 27611, 27612, 27613, 27614, 27623
2010-03-20 16:41:01 +00:00
|
|
|
# Addon UI Code
|
2010-06-27 19:04:44 +00:00
|
|
|
box = col.column().box()
|
|
|
|
colsub = box.column()
|
2016-03-03 18:50:15 +11:00
|
|
|
row = colsub.row(align=True)
|
merge own commits into render branch into trunk since 27560
27562, 27570, 27571, 27574, 27576, 27577, 27579, 27590, 27591, 27594, 27595, 27596, 27599, 27605, 27611, 27612, 27613, 27614, 27623
2010-03-20 16:41:01 +00:00
|
|
|
|
2016-03-03 18:50:15 +11:00
|
|
|
row.label(text="", icon='ERROR')
|
2010-09-25 06:36:01 +00:00
|
|
|
|
|
|
|
if is_enabled:
|
2018-02-01 14:58:05 +11:00
|
|
|
row.operator(
|
|
|
|
"wm.addon_disable", icon='CHECKBOX_HLT', text="", emboss=False,
|
|
|
|
).module = module_name
|
2010-09-25 06:36:01 +00:00
|
|
|
|
2016-03-03 18:50:15 +11:00
|
|
|
row.label(text=module_name, translate=False)
|
|
|
|
|
|
|
|
|
2018-06-08 14:30:11 +02:00
|
|
|
class StudioLightPanelMixin():
|
2018-06-07 16:01:57 +02:00
|
|
|
bl_space_type = 'USER_PREFERENCES'
|
|
|
|
bl_region_type = 'WINDOW'
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'LIGHTS')
|
|
|
|
|
2018-06-08 15:34:13 +02:00
|
|
|
def _get_lights(self, userpref):
|
|
|
|
return [light for light in userpref.studio_lights if light.is_user_defined and light.orientation == self.sl_orientation]
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
|
|
|
userpref = context.user_preferences
|
|
|
|
lights = self._get_lights(userpref)
|
|
|
|
if lights:
|
2018-10-29 22:27:12 +01:00
|
|
|
flow = layout.column_flow(columns=4)
|
2018-06-08 15:34:13 +02:00
|
|
|
for studio_light in lights:
|
|
|
|
self.draw_studio_light(flow, studio_light)
|
|
|
|
else:
|
2018-08-28 12:34:51 +10:00
|
|
|
layout.label(text="No custom {} configured".format(self.bl_label))
|
2018-06-08 15:34:13 +02:00
|
|
|
|
2018-06-07 16:01:57 +02:00
|
|
|
def draw_studio_light(self, layout, studio_light):
|
|
|
|
box = layout.box()
|
|
|
|
row = box.row()
|
|
|
|
|
2018-06-14 10:38:17 +02:00
|
|
|
row.template_icon(layout.icon(studio_light), scale=6.0)
|
2018-10-29 22:27:12 +01:00
|
|
|
op = row.operator('wm.studiolight_uninstall', text="", icon='REMOVE')
|
2018-06-07 16:01:57 +02:00
|
|
|
op.index = studio_light.index
|
|
|
|
|
2018-06-19 14:00:34 +02:00
|
|
|
box.label(text=studio_light.name)
|
|
|
|
|
2018-06-07 16:01:57 +02:00
|
|
|
|
2018-06-08 14:30:11 +02:00
|
|
|
class USERPREF_PT_studiolight_matcaps(Panel, StudioLightPanelMixin):
|
|
|
|
bl_label = "MatCaps"
|
2018-06-08 15:34:13 +02:00
|
|
|
sl_orientation = 'MATCAP'
|
2018-06-07 16:01:57 +02:00
|
|
|
|
2018-06-08 14:30:11 +02:00
|
|
|
|
|
|
|
class USERPREF_PT_studiolight_world(Panel, StudioLightPanelMixin):
|
|
|
|
bl_label = "World HDRI"
|
2018-06-08 15:34:13 +02:00
|
|
|
sl_orientation = 'WORLD'
|
2018-06-08 14:30:11 +02:00
|
|
|
|
|
|
|
|
|
|
|
class USERPREF_PT_studiolight_camera(Panel, StudioLightPanelMixin):
|
|
|
|
bl_label = "Camera HDRI"
|
2018-06-08 15:34:13 +02:00
|
|
|
sl_orientation = 'CAMERA'
|
2018-06-08 14:30:11 +02:00
|
|
|
|
2018-06-07 16:01:57 +02:00
|
|
|
|
2018-07-17 13:58:08 +02:00
|
|
|
class USERPREF_PT_studiolight_specular(Panel, StudioLightPanelMixin):
|
|
|
|
bl_label = "Specular Lights"
|
|
|
|
sl_orientation = 'CAMERA'
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def poll(cls, context):
|
|
|
|
userpref = context.user_preferences
|
|
|
|
return (userpref.active_section == 'LIGHTS')
|
|
|
|
|
|
|
|
def opengl_light_buttons(self, column, light):
|
|
|
|
split = column.split()
|
|
|
|
|
|
|
|
col = split.column()
|
|
|
|
col.prop(light, "use", text="Use", icon='OUTLINER_OB_LIGHT' if light.use else 'LIGHT_DATA')
|
|
|
|
|
|
|
|
sub = col.column()
|
|
|
|
sub.active = light.use
|
|
|
|
sub.prop(light, "specular_color")
|
|
|
|
|
|
|
|
col = split.column()
|
|
|
|
col.active = light.use
|
|
|
|
col.prop(light, "direction", text="")
|
|
|
|
|
|
|
|
def draw(self, context):
|
|
|
|
layout = self.layout
|
|
|
|
column = layout.split()
|
|
|
|
|
|
|
|
userpref = context.user_preferences
|
|
|
|
system = userpref.system
|
|
|
|
|
|
|
|
light = system.solid_lights[0]
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = column.split(factor=0.85)
|
2018-07-17 13:58:08 +02:00
|
|
|
self.opengl_light_buttons(colsplit, light)
|
|
|
|
|
|
|
|
light = system.solid_lights[1]
|
2018-08-28 12:38:54 +10:00
|
|
|
colsplit = column.split(factor=0.85)
|
2018-07-17 13:58:08 +02:00
|
|
|
self.opengl_light_buttons(colsplit, light)
|
|
|
|
|
|
|
|
light = system.solid_lights[2]
|
|
|
|
self.opengl_light_buttons(column, light)
|
|
|
|
|
|
|
|
|
2017-03-18 20:03:24 +11:00
|
|
|
classes = (
|
|
|
|
USERPREF_HT_header,
|
2017-03-20 02:34:32 +11:00
|
|
|
USERPREF_PT_tabs,
|
2017-03-18 20:03:24 +11:00
|
|
|
USERPREF_PT_interface,
|
2017-03-20 02:34:32 +11:00
|
|
|
USERPREF_PT_edit,
|
2017-03-18 20:03:24 +11:00
|
|
|
USERPREF_PT_system,
|
2017-03-20 02:34:32 +11:00
|
|
|
USERPREF_MT_interface_theme_presets,
|
2017-03-18 20:03:24 +11:00
|
|
|
USERPREF_PT_theme,
|
2017-03-20 02:34:32 +11:00
|
|
|
USERPREF_PT_file,
|
|
|
|
USERPREF_MT_ndof_settings,
|
|
|
|
USERPREF_MT_keyconfigs,
|
|
|
|
USERPREF_PT_input,
|
|
|
|
USERPREF_MT_addons_online_resources,
|
|
|
|
USERPREF_PT_addons,
|
2018-06-08 14:30:11 +02:00
|
|
|
USERPREF_PT_studiolight_matcaps,
|
|
|
|
USERPREF_PT_studiolight_world,
|
|
|
|
USERPREF_PT_studiolight_camera,
|
2018-07-17 13:58:08 +02:00
|
|
|
USERPREF_PT_studiolight_specular,
|
2017-03-18 20:03:24 +11:00
|
|
|
)
|
|
|
|
|
2011-04-04 10:13:04 +00:00
|
|
|
if __name__ == "__main__": # only for live edit.
|
2017-03-18 20:03:24 +11:00
|
|
|
from bpy.utils import register_class
|
|
|
|
for cls in classes:
|
|
|
|
register_class(cls)
|