Moving classes to separate listing broke panel order
[blender-staging.git] / release / scripts / startup / bl_ui / properties_data_curve.py
1 # ##### BEGIN GPL LICENSE BLOCK #####
2 #
3 #  This program is free software; you can redistribute it and/or
4 #  modify it under the terms of the GNU General Public License
5 #  as published by the Free Software Foundation; either version 2
6 #  of the License, or (at your option) any later version.
7 #
8 #  This program is distributed in the hope that it will be useful,
9 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
10 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 #  GNU General Public License for more details.
12 #
13 #  You should have received a copy of the GNU General Public License
14 #  along with this program; if not, write to the Free Software Foundation,
15 #  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 #
17 # ##### END GPL LICENSE BLOCK #####
18
19 # <pep8 compliant>
20 import bpy
21 from bpy.types import Panel
22 from rna_prop_ui import PropertyPanel
23
24 from bpy.types import Curve, SurfaceCurve, TextCurve
25
26
27 class CurveButtonsPanel:
28     bl_space_type = 'PROPERTIES'
29     bl_region_type = 'WINDOW'
30     bl_context = "data"
31
32     @classmethod
33     def poll(cls, context):
34         return (context.curve is not None)
35
36
37 class CurveButtonsPanelCurve(CurveButtonsPanel):
38     @classmethod
39     def poll(cls, context):
40         return (type(context.curve) is Curve)
41
42
43 class CurveButtonsPanelSurface(CurveButtonsPanel):
44     @classmethod
45     def poll(cls, context):
46         return (type(context.curve) is SurfaceCurve)
47
48
49 class CurveButtonsPanelText(CurveButtonsPanel):
50     @classmethod
51     def poll(cls, context):
52         return (type(context.curve) is TextCurve)
53
54
55 class CurveButtonsPanelActive(CurveButtonsPanel):
56     """Same as above but for curves only"""
57
58     @classmethod
59     def poll(cls, context):
60         curve = context.curve
61         return (curve and type(curve) is not TextCurve and curve.splines.active)
62
63
64 class DATA_PT_context_curve(CurveButtonsPanel, Panel):
65     bl_label = ""
66     bl_options = {'HIDE_HEADER'}
67
68     def draw(self, context):
69         layout = self.layout
70
71         obj = context.object
72         curve = context.curve
73         space = context.space_data
74
75         if obj:
76             layout.template_ID(obj, "data")
77         elif curve:
78             layout.template_ID(space, "pin_id")
79
80
81 class DATA_PT_shape_curve(CurveButtonsPanel, Panel):
82     bl_label = "Shape"
83
84     def draw(self, context):
85         layout = self.layout
86
87         curve = context.curve
88         is_surf = type(curve) is SurfaceCurve
89         is_curve = type(curve) is Curve
90         is_text = type(curve) is TextCurve
91
92         if is_curve:
93             row = layout.row()
94             row.prop(curve, "dimensions", expand=True)
95
96         split = layout.split()
97
98         col = split.column()
99         col.label(text="Resolution:")
100         sub = col.column(align=True)
101         sub.prop(curve, "resolution_u", text="Preview U")
102         sub.prop(curve, "render_resolution_u", text="Render U")
103         if is_curve:
104             col.label(text="Twisting:")
105             col.prop(curve, "twist_mode", text="")
106             col.prop(curve, "twist_smooth", text="Smooth")
107         elif is_text:
108             col.label(text="Display:")
109             col.prop(curve, "use_fast_edit", text="Fast Editing")
110
111         col = split.column()
112
113         if is_surf:
114             sub = col.column()
115             sub.label(text="")
116             sub = col.column(align=True)
117             sub.prop(curve, "resolution_v", text="Preview V")
118             sub.prop(curve, "render_resolution_v", text="Render V")
119
120         if is_curve or is_text:
121             col.label(text="Fill:")
122             sub = col.column()
123             sub.active = (curve.dimensions == '2D' or (curve.bevel_object is None and curve.dimensions == '3D'))
124             sub.prop(curve, "fill_mode", text="")
125             col.prop(curve, "use_fill_deform")
126
127         if is_curve:
128             col.label(text="Path/Curve-Deform:")
129             sub = col.column()
130             subsub = sub.row()
131             subsub.prop(curve, "use_radius")
132             subsub.prop(curve, "use_stretch")
133             sub.prop(curve, "use_deform_bounds")
134
135
136 class DATA_PT_curve_texture_space(CurveButtonsPanel, Panel):
137     bl_label = "Texture Space"
138     bl_options = {'DEFAULT_CLOSED'}
139     COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_GAME'}
140
141     def draw(self, context):
142         layout = self.layout
143
144         curve = context.curve
145
146         row = layout.row()
147         row.prop(curve, "use_auto_texspace")
148         row.prop(curve, "use_uv_as_generated")
149
150         row = layout.row()
151         row.column().prop(curve, "texspace_location", text="Location")
152         row.column().prop(curve, "texspace_size", text="Size")
153
154         layout.operator("curve.match_texture_space")
155
156
157 class DATA_PT_geometry_curve(CurveButtonsPanelCurve, Panel):
158     bl_label = "Geometry"
159
160     @classmethod
161     def poll(cls, context):
162         return (type(context.curve) in {Curve, TextCurve})
163
164     def draw(self, context):
165         layout = self.layout
166
167         curve = context.curve
168
169         split = layout.split()
170
171         col = split.column()
172         col.label(text="Modification:")
173         col.prop(curve, "offset")
174         col.prop(curve, "extrude")
175         col.label(text="Taper Object:")
176         col.prop(curve, "taper_object", text="")
177
178         col = split.column()
179         col.label(text="Bevel:")
180         col.prop(curve, "bevel_depth", text="Depth")
181         col.prop(curve, "bevel_resolution", text="Resolution")
182         col.label(text="Bevel Object:")
183         col.prop(curve, "bevel_object", text="")
184
185         if type(curve) is not TextCurve:
186             col = layout.column(align=True)
187             row = col.row()
188             row.label(text="Bevel Factor:")
189
190             col = layout.column()
191             col.active = (
192                     (curve.bevel_depth > 0.0) or
193                     (curve.extrude > 0.0) or
194                     (curve.bevel_object is not None))
195             row = col.row(align=True)
196             row.prop(curve, "bevel_factor_mapping_start", text="")
197             row.prop(curve, "bevel_factor_start", text="Start")
198             row = col.row(align=True)
199             row.prop(curve, "bevel_factor_mapping_end", text="")
200             row.prop(curve, "bevel_factor_end", text="End")
201
202             row = layout.row()
203             sub = row.row()
204             sub.active = curve.taper_object is not None
205             sub.prop(curve, "use_map_taper")
206             sub = row.row()
207             sub.active = curve.bevel_object is not None
208             sub.prop(curve, "use_fill_caps")
209
210
211 class DATA_PT_pathanim(CurveButtonsPanelCurve, Panel):
212     bl_label = "Path Animation"
213
214     def draw_header(self, context):
215         curve = context.curve
216
217         self.layout.prop(curve, "use_path", text="")
218
219     def draw(self, context):
220         layout = self.layout
221
222         curve = context.curve
223
224         layout.active = curve.use_path
225
226         col = layout.column()
227         col.prop(curve, "path_duration", text="Frames")
228         col.prop(curve, "eval_time")
229
230         # these are for paths only
231         row = layout.row()
232         row.prop(curve, "use_path_follow")
233
234
235 class DATA_PT_active_spline(CurveButtonsPanelActive, Panel):
236     bl_label = "Active Spline"
237
238     def draw(self, context):
239         layout = self.layout
240
241         curve = context.curve
242         act_spline = curve.splines.active
243         is_surf = type(curve) is SurfaceCurve
244         is_poly = (act_spline.type == 'POLY')
245
246         split = layout.split()
247
248         if is_poly:
249             # These settings are below but its easier to have
250             # polys set aside since they use so few settings
251             row = layout.row()
252             row.label(text="Cyclic:")
253             row.prop(act_spline, "use_cyclic_u", text="U")
254
255             layout.prop(act_spline, "use_smooth")
256         else:
257             col = split.column()
258             col.label(text="Cyclic:")
259             if act_spline.type == 'NURBS':
260                 col.label(text="Bezier:")
261                 col.label(text="Endpoint:")
262                 col.label(text="Order:")
263
264             col.label(text="Resolution:")
265
266             col = split.column()
267             col.prop(act_spline, "use_cyclic_u", text="U")
268
269             if act_spline.type == 'NURBS':
270                 sub = col.column()
271                 # sub.active = (not act_spline.use_cyclic_u)
272                 sub.prop(act_spline, "use_bezier_u", text="U")
273                 sub.prop(act_spline, "use_endpoint_u", text="U")
274
275                 sub = col.column()
276                 sub.prop(act_spline, "order_u", text="U")
277             col.prop(act_spline, "resolution_u", text="U")
278
279             if is_surf:
280                 col = split.column()
281                 col.prop(act_spline, "use_cyclic_v", text="V")
282
283                 # its a surface, assume its a nurbs
284                 sub = col.column()
285                 sub.active = (not act_spline.use_cyclic_v)
286                 sub.prop(act_spline, "use_bezier_v", text="V")
287                 sub.prop(act_spline, "use_endpoint_v", text="V")
288                 sub = col.column()
289                 sub.prop(act_spline, "order_v", text="V")
290                 sub.prop(act_spline, "resolution_v", text="V")
291
292             if act_spline.type == 'BEZIER':
293                 col = layout.column()
294                 col.label(text="Interpolation:")
295
296                 sub = col.column()
297                 sub.active = (curve.dimensions == '3D')
298                 sub.prop(act_spline, "tilt_interpolation", text="Tilt")
299
300                 col.prop(act_spline, "radius_interpolation", text="Radius")
301
302             layout.prop(act_spline, "use_smooth")
303
304
305 class DATA_PT_font(CurveButtonsPanelText, Panel):
306     bl_label = "Font"
307
308     def draw(self, context):
309         layout = self.layout
310
311         text = context.curve
312         char = context.curve.edit_format
313
314         row = layout.split(percentage=0.25)
315         row.label(text="Regular")
316         row.template_ID(text, "font", open="font.open", unlink="font.unlink")
317         row = layout.split(percentage=0.25)
318         row.label(text="Bold")
319         row.template_ID(text, "font_bold", open="font.open", unlink="font.unlink")
320         row = layout.split(percentage=0.25)
321         row.label(text="Italic")
322         row.template_ID(text, "font_italic", open="font.open", unlink="font.unlink")
323         row = layout.split(percentage=0.25)
324         row.label(text="Bold & Italic")
325         row.template_ID(text, "font_bold_italic", open="font.open", unlink="font.unlink")
326
327         # layout.prop(text, "font")
328
329         split = layout.split()
330
331         col = split.column()
332         col.prop(text, "size", text="Size")
333         col = split.column()
334         col.prop(text, "shear")
335
336         split = layout.split()
337
338         col = split.column()
339         col.label(text="Object Font:")
340         col.prop(text, "family", text="")
341
342         col = split.column()
343         col.label(text="Text on Curve:")
344         col.prop(text, "follow_curve", text="")
345
346         split = layout.split()
347
348         col = split.column()
349         sub = col.column(align=True)
350         sub.label(text="Underline:")
351         sub.prop(text, "underline_position", text="Position")
352         sub.prop(text, "underline_height", text="Thickness")
353
354         col = split.column()
355         col.label(text="Character:")
356         col.prop(char, "use_bold")
357         col.prop(char, "use_italic")
358         col.prop(char, "use_underline")
359
360         row = layout.row()
361         row.prop(text, "small_caps_scale", text="Small Caps")
362         row.prop(char, "use_small_caps")
363
364
365 class DATA_PT_paragraph(CurveButtonsPanelText, Panel):
366     bl_label = "Paragraph"
367
368     def draw(self, context):
369         layout = self.layout
370
371         text = context.curve
372
373         layout.label(text="Horizontal Alignment:")
374         layout.prop(text, "align_x", expand=True)
375
376         layout.label(text="Vertical Alignment:")
377         layout.prop(text, "align_y", expand=True)
378
379         split = layout.split()
380
381         col = split.column(align=True)
382         col.label(text="Spacing:")
383         col.prop(text, "space_character", text="Letter")
384         col.prop(text, "space_word", text="Word")
385         col.prop(text, "space_line", text="Line")
386
387         col = split.column(align=True)
388         col.label(text="Offset:")
389         col.prop(text, "offset_x", text="X")
390         col.prop(text, "offset_y", text="Y")
391
392
393 class DATA_PT_text_boxes(CurveButtonsPanelText, Panel):
394     bl_label = "Text Boxes"
395
396     def draw(self, context):
397         layout = self.layout
398
399         text = context.curve
400
401         split = layout.split()
402         col = split.column()
403         col.operator("font.textbox_add", icon='ZOOMIN')
404         col = split.column()
405
406         for i, box in enumerate(text.text_boxes):
407
408             boxy = layout.box()
409
410             row = boxy.row()
411
412             split = row.split()
413
414             col = split.column(align=True)
415
416             col.label(text="Dimensions:")
417             col.prop(box, "width", text="Width")
418             col.prop(box, "height", text="Height")
419
420             col = split.column(align=True)
421
422             col.label(text="Offset:")
423             col.prop(box, "x", text="X")
424             col.prop(box, "y", text="Y")
425
426             row.operator("font.textbox_remove", text="", icon='X', emboss=False).index = i
427
428
429 class DATA_PT_custom_props_curve(CurveButtonsPanel, PropertyPanel, Panel):
430     COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_GAME'}
431     _context_path = "object.data"
432     _property_type = bpy.types.Curve
433
434
435 classes = (
436     DATA_PT_context_curve,
437     DATA_PT_shape_curve,
438     DATA_PT_curve_texture_space,
439     DATA_PT_geometry_curve,
440     DATA_PT_pathanim,
441     DATA_PT_active_spline,
442     DATA_PT_font,
443     DATA_PT_paragraph,
444     DATA_PT_text_boxes,
445     DATA_PT_custom_props_curve,
446 )
447
448 if __name__ == "__main__":  # only for live edit.
449     from bpy.utils import register_class
450     for cls in classes:
451         register_class(cls)