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

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'release/scripts/startup/bl_ui/space_image.py')
-rw-r--r--release/scripts/startup/bl_ui/space_image.py753
1 files changed, 753 insertions, 0 deletions
diff --git a/release/scripts/startup/bl_ui/space_image.py b/release/scripts/startup/bl_ui/space_image.py
new file mode 100644
index 00000000000..b2965d0c37a
--- /dev/null
+++ b/release/scripts/startup/bl_ui/space_image.py
@@ -0,0 +1,753 @@
+# ##### BEGIN GPL LICENSE BLOCK #####
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software Foundation,
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# ##### END GPL LICENSE BLOCK #####
+
+# <pep8 compliant>
+import bpy
+
+
+class BrushButtonsPanel():
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'UI'
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ toolsettings = context.tool_settings.image_paint
+ return sima.show_paint and toolsettings.brush
+
+
+class IMAGE_MT_view(bpy.types.Menu):
+ bl_label = "View"
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ uv = sima.uv_editor
+ toolsettings = context.tool_settings
+
+ show_uvedit = sima.show_uvedit
+
+ layout.operator("image.properties", icon='MENU_PANEL')
+ layout.operator("image.scopes", icon='MENU_PANEL')
+
+ layout.separator()
+
+ layout.prop(sima, "use_realtime_update")
+ if show_uvedit:
+ layout.prop(toolsettings, "show_uv_local_view")
+ layout.prop(uv, "show_other_objects")
+
+ layout.separator()
+
+ layout.operator("image.view_zoom_in")
+ layout.operator("image.view_zoom_out")
+
+ layout.separator()
+
+ ratios = [[1, 8], [1, 4], [1, 2], [1, 1], [2, 1], [4, 1], [8, 1]]
+
+ for a, b in ratios:
+ text = "Zoom %d:%d" % (a, b)
+ layout.operator("image.view_zoom_ratio", text=text).ratio = a / b
+
+ layout.separator()
+
+ if show_uvedit:
+ layout.operator("image.view_selected")
+
+ layout.operator("image.view_all")
+
+ layout.separator()
+
+ layout.operator("screen.area_dupli")
+ layout.operator("screen.screen_full_area")
+
+
+class IMAGE_MT_select(bpy.types.Menu):
+ bl_label = "Select"
+
+ def draw(self, context):
+ layout = self.layout
+
+ layout.operator("uv.select_border")
+ layout.operator("uv.select_border").pinned = True
+
+ layout.separator()
+
+ layout.operator("uv.select_all")
+ layout.operator("uv.select_inverse")
+ layout.operator("uv.unlink_selection")
+
+ layout.separator()
+
+ layout.operator("uv.select_pinned")
+ layout.operator("uv.select_linked")
+
+
+class IMAGE_MT_image(bpy.types.Menu):
+ bl_label = "Image"
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ ima = sima.image
+
+ layout.operator("image.new")
+ layout.operator("image.open")
+
+ show_render = sima.show_render
+
+ if ima:
+ if not show_render:
+ layout.operator("image.replace")
+ layout.operator("image.reload")
+
+ layout.operator("image.save")
+ layout.operator("image.save_as")
+ layout.operator("image.save_as", text="Save a Copy").copy = True
+
+ if ima.source == 'SEQUENCE':
+ layout.operator("image.save_sequence")
+
+ layout.operator("image.external_edit", "Edit Externally")
+
+ layout.separator()
+
+ layout.menu("IMAGE_MT_image_invert")
+
+ if not show_render:
+ layout.separator()
+
+ if ima.packed_file:
+ layout.operator("image.unpack")
+ else:
+ layout.operator("image.pack")
+
+ # only for dirty && specific image types, perhaps
+ # this could be done in operator poll too
+ if ima.is_dirty:
+ if ima.source in {'FILE', 'GENERATED'} and ima.type != 'MULTILAYER':
+ layout.operator("image.pack", text="Pack As PNG").as_png = True
+
+ layout.separator()
+
+ layout.prop(sima, "use_image_paint")
+
+
+class IMAGE_MT_image_invert(bpy.types.Menu):
+ bl_label = "Invert"
+
+ def draw(self, context):
+ layout = self.layout
+
+ op = layout.operator("image.invert", text="Invert Image Colors")
+ op.invert_r = True
+ op.invert_g = True
+ op.invert_b = True
+
+ layout.separator()
+
+ op = layout.operator("image.invert", text="Invert Red Channel")
+ op.invert_r = True
+
+ op = layout.operator("image.invert", text="Invert Green Channel")
+ op.invert_g = True
+
+ op = layout.operator("image.invert", text="Invert Blue Channel")
+ op.invert_b = True
+
+ op = layout.operator("image.invert", text="Invert Alpha Channel")
+ op.invert_a = True
+
+
+class IMAGE_MT_uvs_showhide(bpy.types.Menu):
+ bl_label = "Show/Hide Faces"
+
+ def draw(self, context):
+ layout = self.layout
+
+ layout.operator("uv.reveal")
+ layout.operator("uv.hide", text="Hide Selected")
+ layout.operator("uv.hide", text="Hide Unselected").unselected = True
+
+
+class IMAGE_MT_uvs_transform(bpy.types.Menu):
+ bl_label = "Transform"
+
+ def draw(self, context):
+ layout = self.layout
+
+ layout.operator("transform.translate")
+ layout.operator("transform.rotate")
+ layout.operator("transform.resize")
+
+
+class IMAGE_MT_uvs_snap(bpy.types.Menu):
+ bl_label = "Snap"
+
+ def draw(self, context):
+ layout = self.layout
+ layout.operator_context = 'EXEC_REGION_WIN'
+
+ layout.operator("uv.snap_selection", text="Selected to Pixels").target = 'PIXELS'
+ layout.operator("uv.snap_selection", text="Selected to Cursor").target = 'CURSOR'
+ layout.operator("uv.snap_selection", text="Selected to Adjacent Unselected").target = 'ADJACENT_UNSELECTED'
+
+ layout.separator()
+
+ layout.operator("uv.snap_cursor", text="Cursor to Pixels").target = 'PIXELS'
+ layout.operator("uv.snap_cursor", text="Cursor to Selection").target = 'SELECTION'
+
+
+class IMAGE_MT_uvs_mirror(bpy.types.Menu):
+ bl_label = "Mirror"
+
+ def draw(self, context):
+ layout = self.layout
+ layout.operator_context = 'EXEC_REGION_WIN'
+
+ layout.operator("transform.mirror", text="X Axis").constraint_axis[0] = True
+ layout.operator("transform.mirror", text="Y Axis").constraint_axis[1] = True
+
+
+class IMAGE_MT_uvs_weldalign(bpy.types.Menu):
+ bl_label = "Weld/Align"
+
+ def draw(self, context):
+ layout = self.layout
+
+ layout.operator("uv.weld") # W, 1
+ layout.operator_enum("uv.align", "axis") # W, 2/3/4
+
+
+class IMAGE_MT_uvs(bpy.types.Menu):
+ bl_label = "UVs"
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ uv = sima.uv_editor
+ toolsettings = context.tool_settings
+
+ layout.prop(uv, "use_snap_to_pixels")
+ layout.prop(uv, "lock_bounds")
+
+ layout.separator()
+
+ layout.prop(uv, "use_live_unwrap")
+ layout.operator("uv.unwrap")
+ layout.operator("uv.pin", text="Unpin").clear = True
+ layout.operator("uv.pin")
+
+ layout.separator()
+
+ layout.operator("uv.pack_islands")
+ layout.operator("uv.average_islands_scale")
+ layout.operator("uv.minimize_stretch")
+ layout.operator("uv.stitch")
+ layout.operator("mesh.faces_miror_uv")
+
+ layout.separator()
+
+ layout.menu("IMAGE_MT_uvs_transform")
+ layout.menu("IMAGE_MT_uvs_mirror")
+ layout.menu("IMAGE_MT_uvs_snap")
+ layout.menu("IMAGE_MT_uvs_weldalign")
+
+ layout.separator()
+
+ layout.prop_menu_enum(toolsettings, "proportional_edit")
+ layout.prop_menu_enum(toolsettings, "proportional_edit_falloff")
+
+ layout.separator()
+
+ layout.menu("IMAGE_MT_uvs_showhide")
+
+
+class IMAGE_MT_uvs_select_mode(bpy.types.Menu):
+ bl_label = "UV Select Mode"
+
+ def draw(self, context):
+ layout = self.layout
+
+ layout.operator_context = 'INVOKE_REGION_WIN'
+ toolsettings = context.tool_settings
+
+ # do smart things depending on whether uv_select_sync is on
+
+ if toolsettings.use_uv_select_sync:
+ prop = layout.operator("wm.context_set_value", text="Vertex", icon='VERTEXSEL')
+ prop.value = "(True, False, False)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ prop = layout.operator("wm.context_set_value", text="Edge", icon='EDGESEL')
+ prop.value = "(False, True, False)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ prop = layout.operator("wm.context_set_value", text="Face", icon='FACESEL')
+ prop.value = "(False, False, True)"
+ prop.data_path = "tool_settings.mesh_select_mode"
+
+ else:
+ prop = layout.operator("wm.context_set_string", text="Vertex", icon='UV_VERTEXSEL')
+ prop.value = "VERTEX"
+ prop.data_path = "tool_settings.uv_select_mode"
+
+ prop = layout.operator("wm.context_set_string", text="Edge", icon='UV_EDGESEL')
+ prop.value = "EDGE"
+ prop.data_path = "tool_settings.uv_select_mode"
+
+ prop = layout.operator("wm.context_set_string", text="Face", icon='UV_FACESEL')
+ prop.value = "FACE"
+ prop.data_path = "tool_settings.uv_select_mode"
+
+ prop = layout.operator("wm.context_set_string", text="Island", icon='UV_ISLANDSEL')
+ prop.value = "ISLAND"
+ prop.data_path = "tool_settings.uv_select_mode"
+
+
+class IMAGE_HT_header(bpy.types.Header):
+ bl_space_type = 'IMAGE_EDITOR'
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ ima = sima.image
+ iuser = sima.image_user
+ toolsettings = context.tool_settings
+
+ show_render = sima.show_render
+ # show_paint = sima.show_paint
+ show_uvedit = sima.show_uvedit
+
+ row = layout.row(align=True)
+ row.template_header()
+
+ # menus
+ if context.area.show_menus:
+ sub = row.row(align=True)
+ sub.menu("IMAGE_MT_view")
+
+ if show_uvedit:
+ sub.menu("IMAGE_MT_select")
+
+ if ima and ima.is_dirty:
+ sub.menu("IMAGE_MT_image", text="Image*")
+ else:
+ sub.menu("IMAGE_MT_image", text="Image")
+
+ if show_uvedit:
+ sub.menu("IMAGE_MT_uvs")
+
+ layout.template_ID(sima, "image", new="image.new")
+ if not show_render:
+ layout.prop(sima, "use_image_pin", text="")
+
+ # uv editing
+ if show_uvedit:
+ uvedit = sima.uv_editor
+
+ layout.prop(uvedit, "pivot_point", text="", icon_only=True)
+ layout.prop(toolsettings, "use_uv_select_sync", text="")
+
+ if toolsettings.use_uv_select_sync:
+ row = layout.row(align=True)
+ row.prop(toolsettings, "mesh_select_mode", text="", index=0, icon='VERTEXSEL')
+ row.prop(toolsettings, "mesh_select_mode", text="", index=1, icon='EDGESEL')
+ row.prop(toolsettings, "mesh_select_mode", text="", index=2, icon='FACESEL')
+ else:
+ layout.prop(toolsettings, "uv_select_mode", text="", expand=True)
+ layout.prop(uvedit, "sticky_select_mode", text="", icon_only=True)
+
+ row = layout.row(align=True)
+ row.prop(toolsettings, "proportional_edit", text="", icon_only=True)
+ if toolsettings.proportional_edit != 'DISABLED':
+ row.prop(toolsettings, "proportional_edit_falloff", text="", icon_only=True)
+
+ row = layout.row(align=True)
+ row.prop(toolsettings, "use_snap", text="")
+ row.prop(toolsettings, "snap_element", text="", icon_only=True)
+
+ mesh = context.edit_object.data
+ layout.prop_search(mesh.uv_textures, "active", mesh, "uv_textures", text="")
+
+ if ima:
+ # layers
+ layout.template_image_layers(ima, iuser)
+
+ # painting
+ layout.prop(sima, "use_image_paint", text="")
+
+ # draw options
+ row = layout.row(align=True)
+ row.prop(sima, "draw_channels", text="", expand=True)
+
+ row = layout.row(align=True)
+ if ima.type == 'COMPOSITE':
+ row.operator("image.record_composite", icon='REC')
+ if ima.type == 'COMPOSITE' and ima.source in {'MOVIE', 'SEQUENCE'}:
+ row.operator("image.play_composite", icon='PLAY')
+
+ if show_uvedit or sima.use_image_paint:
+ layout.prop(sima, "use_realtime_update", text="", icon_only=True, icon='LOCKED')
+
+
+class IMAGE_PT_image_properties(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'UI'
+ bl_label = "Image"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima.image)
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ iuser = sima.image_user
+
+ layout.template_image(sima, "image", iuser)
+
+
+class IMAGE_PT_game_properties(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'UI'
+ bl_label = "Game Properties"
+
+ @classmethod
+ def poll(cls, context):
+ rd = context.scene.render
+ sima = context.space_data
+ return (sima and sima.image) and (rd.engine == 'BLENDER_GAME')
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ ima = sima.image
+
+ split = layout.split()
+
+ col = split.column()
+
+ sub = col.column(align=True)
+ sub.prop(ima, "use_animation")
+
+ subsub = sub.column()
+ subsub.active = ima.use_animation
+ subsub.prop(ima, "frame_start", text="Start")
+ subsub.prop(ima, "frame_end", text="End")
+ subsub.prop(ima, "fps", text="Speed")
+
+ col.prop(ima, "use_tiles")
+ sub = col.column(align=True)
+ sub.active = ima.use_tiles or ima.use_animation
+ sub.prop(ima, "tiles_x", text="X")
+ sub.prop(ima, "tiles_y", text="Y")
+
+ col = split.column()
+ col.label(text="Clamp:")
+ col.prop(ima, "use_clamp_x", text="X")
+ col.prop(ima, "use_clamp_y", text="Y")
+ col.separator()
+ col.prop(ima, "mapping", expand=True)
+
+
+class IMAGE_PT_view_histogram(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'PREVIEW'
+ bl_label = "Histogram"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima and sima.image)
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+
+ layout.template_histogram(sima.scopes, "histogram")
+ layout.prop(sima.scopes.histogram, "mode", icon_only=True)
+
+
+class IMAGE_PT_view_waveform(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'PREVIEW'
+ bl_label = "Waveform"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima and sima.image)
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ layout.template_waveform(sima, "scopes")
+ sub = layout.row().split(percentage=0.75)
+ sub.prop(sima.scopes, "waveform_alpha")
+ sub.prop(sima.scopes, "waveform_mode", text="", icon_only=True)
+
+
+class IMAGE_PT_view_vectorscope(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'PREVIEW'
+ bl_label = "Vectorscope"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima and sima.image)
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ layout.template_vectorscope(sima, "scopes")
+ layout.prop(sima.scopes, "vectorscope_alpha")
+
+
+class IMAGE_PT_sample_line(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'PREVIEW'
+ bl_label = "Sample Line"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima and sima.image)
+
+ def draw(self, context):
+ layout = self.layout
+ layout.operator("image.sample_line")
+ sima = context.space_data
+ layout.template_histogram(sima, "sample_histogram")
+ layout.prop(sima.sample_histogram, "mode")
+
+
+class IMAGE_PT_scope_sample(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'PREVIEW'
+ bl_label = "Scope Samples"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return sima
+
+ def draw(self, context):
+ layout = self.layout
+ sima = context.space_data
+ split = layout.split()
+ row = split.row()
+ row.prop(sima.scopes, "use_full_resolution")
+ row = split.row()
+ row.active = not sima.scopes.use_full_resolution
+ row.prop(sima.scopes, "accuracy")
+
+
+class IMAGE_PT_view_properties(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'UI'
+ bl_label = "Display"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return (sima and (sima.image or sima.show_uvedit))
+
+ def draw(self, context):
+ layout = self.layout
+
+ sima = context.space_data
+ ima = sima.image
+ show_uvedit = sima.show_uvedit
+ uvedit = sima.uv_editor
+
+ split = layout.split()
+
+ col = split.column()
+ if ima:
+ col.prop(ima, "display_aspect", text="Aspect Ratio")
+
+ col = split.column()
+ col.label(text="Coordinates:")
+ col.prop(sima, "show_repeat", text="Repeat")
+ if show_uvedit:
+ col.prop(uvedit, "show_normalized_coords", text="Normalized")
+
+ elif show_uvedit:
+ col.label(text="Coordinates:")
+ col.prop(uvedit, "show_normalized_coords", text="Normalized")
+
+ if show_uvedit:
+
+ col = layout.column()
+ col.prop(uvedit, "cursor_location")
+
+ col = layout.column()
+ col.label(text="UVs:")
+ row = col.row()
+ row.prop(uvedit, "edge_draw_type", expand=True)
+
+ split = layout.split()
+ col = split.column()
+ col.prop(uvedit, "show_smooth_edges", text="Smooth")
+ col.prop(uvedit, "show_modified_edges", text="Modified")
+ #col.prop(uvedit, "show_edges")
+ #col.prop(uvedit, "show_faces")
+
+ col = split.column()
+ col.prop(uvedit, "show_stretch", text="Stretch")
+ sub = col.column()
+ sub.active = uvedit.show_stretch
+ sub.row().prop(uvedit, "draw_stretch_type", expand=True)
+
+
+class IMAGE_PT_paint(bpy.types.Panel):
+ bl_space_type = 'IMAGE_EDITOR'
+ bl_region_type = 'UI'
+ bl_label = "Paint"
+
+ @classmethod
+ def poll(cls, context):
+ sima = context.space_data
+ return sima.show_paint
+
+ def draw(self, context):
+ layout = self.layout
+
+ toolsettings = context.tool_settings.image_paint
+ brush = toolsettings.brush
+
+ col = layout.split().column()
+ row = col.row()
+ col.template_ID_preview(toolsettings, "brush", new="brush.add", rows=3, cols=8)
+
+ if brush:
+ col = layout.column()
+ col.template_color_wheel(brush, "color", value_slider=True)
+ col.prop(brush, "color", text="")
+
+ row = col.row(align=True)
+ row.prop(brush, "size", slider=True)
+ row.prop(brush, "use_pressure_size", toggle=True, text="")
+
+ row = col.row(align=True)
+ row.prop(brush, "strength", slider=True)
+ row.prop(brush, "use_pressure_strength", toggle=True, text="")
+
+ row = col.row(align=True)
+ row.prop(brush, "jitter", slider=True)
+ row.prop(brush, "use_pressure_jitter", toggle=True, text="")
+
+ col.prop(brush, "blend", text="Blend")
+
+ if brush.imagepaint_tool == 'CLONE':
+ col.separator()
+ col.prop(brush, "clone_image", text="Image")
+ col.prop(brush, "clone_alpha", text="Alpha")
+
+
+class IMAGE_PT_tools_brush_texture(BrushButtonsPanel, bpy.types.Panel):
+ bl_label = "Texture"
+ bl_options = {'DEFAULT_CLOSED'}
+
+ def draw(self, context):
+ layout = self.layout
+
+ toolsettings = context.tool_settings.image_paint
+ brush = toolsettings.brush
+
+ col = layout.column()
+ col.template_ID_preview(brush, "texture", new="texture.new", rows=3, cols=8)
+ col.prop(brush, "use_fixed_texture")
+
+
+class IMAGE_PT_tools_brush_tool(BrushButtonsPanel, bpy.types.Panel):
+ bl_label = "Tool"
+ bl_options = {'DEFAULT_CLOSED'}
+
+ def draw(self, context):
+ layout = self.layout
+ settings = context.tool_settings.image_paint
+ brush = settings.brush
+
+ col = layout.column(align=True)
+
+ col.prop(brush, "imagepaint_tool", expand=False, text="")
+
+ row = layout.row(align=True)
+ row.prop(brush, "use_paint_sculpt", text="", icon='SCULPTMODE_HLT')
+ row.prop(brush, "use_paint_vertex", text="", icon='VPAINT_HLT')
+ row.prop(brush, "use_paint_weight", text="", icon='WPAINT_HLT')
+ row.prop(brush, "use_paint_texture", text="", icon='TPAINT_HLT')
+
+
+class IMAGE_PT_paint_stroke(BrushButtonsPanel, bpy.types.Panel):
+ bl_label = "Paint Stroke"
+ bl_options = {'DEFAULT_CLOSED'}
+
+ def draw(self, context):
+ layout = self.layout
+
+ toolsettings = context.tool_settings.image_paint
+ brush = toolsettings.brush
+
+ layout.prop(brush, "use_airbrush")
+ col = layout.column()
+ col.active = brush.use_airbrush
+ col.prop(brush, "rate", slider=True)
+
+ layout.prop(brush, "use_space")
+ row = layout.row(align=True)
+ row.active = brush.use_space
+ row.prop(brush, "spacing", text="Distance", slider=True)
+ row.prop(brush, "use_pressure_spacing", toggle=True, text="")
+
+ layout.prop(brush, "use_wrap")
+
+
+class IMAGE_PT_paint_curve(BrushButtonsPanel, bpy.types.Panel):
+ bl_label = "Paint Curve"
+ bl_options = {'DEFAULT_CLOSED'}
+
+ def draw(self, context):
+ layout = self.layout
+
+ toolsettings = context.tool_settings.image_paint
+ brush = toolsettings.brush
+
+ layout.template_curve_mapping(brush, "curve")
+
+ row = layout.row(align=True)
+ row.operator("brush.curve_preset", icon="SMOOTHCURVE", text="").shape = 'SMOOTH'
+ row.operator("brush.curve_preset", icon="SPHERECURVE", text="").shape = 'ROUND'
+ row.operator("brush.curve_preset", icon="ROOTCURVE", text="").shape = 'ROOT'
+ row.operator("brush.curve_preset", icon="SHARPCURVE", text="").shape = 'SHARP'
+ row.operator("brush.curve_preset", icon="LINCURVE", text="").shape = 'LINE'
+ row.operator("brush.curve_preset", icon="NOCURVE", text="").shape = 'MAX'