Object transparency setting should only show on MESH type
[blender-staging.git] / release / scripts / ui / properties_object.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 rna_prop_ui import PropertyPanel
22
23
24 class ObjectButtonsPanel():
25     bl_space_type = 'PROPERTIES'
26     bl_region_type = 'WINDOW'
27     bl_context = "object"
28
29
30 class OBJECT_PT_context_object(ObjectButtonsPanel, bpy.types.Panel):
31     bl_label = ""
32     bl_options = {'HIDE_HEADER'}
33
34     def draw(self, context):
35         layout = self.layout
36         space = context.space_data
37         ob = context.object
38
39         row = layout.row()
40         row.label(text="", icon='OBJECT_DATA')
41         if space.use_pin_id:
42             row.template_ID(space, "pin_id")
43         else:
44             row.prop(ob, "name", text="")
45
46
47 class OBJECT_PT_transform(ObjectButtonsPanel, bpy.types.Panel):
48     bl_label = "Transform"
49
50     def draw(self, context):
51         layout = self.layout
52
53         ob = context.object
54
55         row = layout.row()
56
57         row.column().prop(ob, "location")
58         if ob.rotation_mode == 'QUATERNION':
59             row.column().prop(ob, "rotation_quaternion", text="Rotation")
60         elif ob.rotation_mode == 'AXIS_ANGLE':
61             #row.column().label(text="Rotation")
62             #row.column().prop(pchan, "rotation_angle", text="Angle")
63             #row.column().prop(pchan, "rotation_axis", text="Axis")
64             row.column().prop(ob, "rotation_axis_angle", text="Rotation")
65         else:
66             row.column().prop(ob, "rotation_euler", text="Rotation")
67
68         row.column().prop(ob, "scale")
69
70         layout.prop(ob, "rotation_mode")
71                 
72 class OBJECT_PT_delta_transform(ObjectButtonsPanel, bpy.types.Panel):
73     bl_label = "Delta Transform"
74     bl_options = {'DEFAULT_CLOSED'}
75
76     def draw(self, context):
77         layout = self.layout
78
79         ob = context.object
80
81         row = layout.row()
82
83         row.column().prop(ob, "delta_location")
84         if ob.rotation_mode == 'QUATERNION':
85             row.column().prop(ob, "delta_rotation_quaternion", text="Rotation")
86         elif ob.rotation_mode == 'AXIS_ANGLE':
87             #row.column().label(text="Rotation")
88             #row.column().prop(pchan, "delta_rotation_angle", text="Angle")
89             #row.column().prop(pchan, "delta_rotation_axis", text="Axis")
90             #row.column().prop(ob, "delta_rotation_axis_angle", text="Rotation")
91             row.column().label(ob, text="Not for Axis-Angle")
92         else:
93             row.column().prop(ob, "delta_rotation_euler", text="Rotation")
94
95         row.column().prop(ob, "delta_scale")
96
97
98 class OBJECT_PT_transform_locks(ObjectButtonsPanel, bpy.types.Panel):
99     bl_label = "Transform Locks"
100     bl_options = {'DEFAULT_CLOSED'}
101
102     def draw(self, context):
103         layout = self.layout
104
105         ob = context.object
106
107         row = layout.row()
108
109         col = row.column()
110         col.prop(ob, "lock_location", text="Location")
111
112         col = row.column()
113         if ob.rotation_mode in ('QUATERNION', 'AXIS_ANGLE'):
114             col.prop(ob, "lock_rotations_4d", text="Rotation")
115             if ob.lock_rotations_4d:
116                 col.prop(ob, "lock_rotation_w", text="W")
117             col.prop(ob, "lock_rotation", text="")
118         else:
119             col.prop(ob, "lock_rotation", text="Rotation")
120
121         row.column().prop(ob, "lock_scale", text="Scale")
122
123
124 class OBJECT_PT_relations(ObjectButtonsPanel, bpy.types.Panel):
125     bl_label = "Relations"
126
127     def draw(self, context):
128         layout = self.layout
129
130         ob = context.object
131
132         split = layout.split()
133
134         col = split.column()
135         col.prop(ob, "layers")
136         col.separator()
137         col.prop(ob, "pass_index")
138
139         col = split.column()
140         col.label(text="Parent:")
141         col.prop(ob, "parent", text="")
142
143         sub = col.column()
144         sub.prop(ob, "parent_type", text="")
145         parent = ob.parent
146         if parent and ob.parent_type == 'BONE' and parent.type == 'ARMATURE':
147             sub.prop_search(ob, "parent_bone", parent.data, "bones", text="")
148         sub.active = (parent is not None)
149
150
151 class OBJECT_PT_groups(ObjectButtonsPanel, bpy.types.Panel):
152     bl_label = "Groups"
153
154     def draw(self, context):
155         layout = self.layout
156
157         ob = context.object
158
159         row = layout.row(align=True)
160         row.operator("object.group_link", text="Add to Group")
161         row.operator("object.group_add", text="", icon='ZOOMIN')
162
163         # XXX, this is bad practice, yes, I wrote it :( - campbell
164         index = 0
165         value = str(tuple(context.scene.cursor_location))
166         for group in bpy.data.groups:
167             if ob.name in group.objects:
168                 col = layout.column(align=True)
169
170                 col.context_pointer_set("group", group)
171
172                 row = col.box().row()
173                 row.prop(group, "name", text="")
174                 row.operator("object.group_remove", text="", icon='X', emboss=False)
175
176                 split = col.box().split()
177
178                 col = split.column()
179                 col.prop(group, "layers", text="Dupli")
180
181                 col = split.column()
182                 col.prop(group, "dupli_offset", text="")
183
184                 prop = col.operator("wm.context_set_value", text="From Cursor")
185                 prop.data_path = "object.users_group[%d].dupli_offset" % index
186                 prop.value = value
187                 index += 1
188
189
190 class OBJECT_PT_display(ObjectButtonsPanel, bpy.types.Panel):
191     bl_label = "Display"
192
193     def draw(self, context):
194         layout = self.layout
195
196         ob = context.object
197
198         split = layout.split()
199         col = split.column()
200         col.prop(ob, "draw_type", text="Type")
201
202         col = split.column()
203         row = col.row()
204         row.prop(ob, "show_bounds", text="Bounds")
205         sub = row.row()
206         sub.active = ob.show_bounds
207         sub.prop(ob, "draw_bounds_type", text="")
208
209         split = layout.split()
210
211         col = split.column()
212         col.prop(ob, "show_name", text="Name")
213         col.prop(ob, "show_axis", text="Axis")
214         col.prop(ob, "show_wire", text="Wire")
215         col.prop(ob, "color", text="Object Color")
216
217         col = split.column()
218         col.prop(ob, "show_texture_space", text="Texture Space")
219         col.prop(ob, "show_x_ray", text="X-Ray")
220         if ob.type == 'MESH':
221             col.prop(ob, "show_transparent", text="Transparency")
222
223
224 class OBJECT_PT_duplication(ObjectButtonsPanel, bpy.types.Panel):
225     bl_label = "Duplication"
226
227     def draw(self, context):
228         layout = self.layout
229
230         ob = context.object
231
232         layout.prop(ob, "dupli_type", expand=True)
233
234         if ob.dupli_type == 'FRAMES':
235             split = layout.split()
236
237             col = split.column(align=True)
238             col.prop(ob, "dupli_frames_start", text="Start")
239             col.prop(ob, "dupli_frames_end", text="End")
240
241             col = split.column(align=True)
242             col.prop(ob, "dupli_frames_on", text="On")
243             col.prop(ob, "dupli_frames_off", text="Off")
244
245             layout.prop(ob, "use_dupli_frames_speed", text="Speed")
246
247         elif ob.dupli_type == 'VERTS':
248             layout.prop(ob, "use_dupli_vertices_rotation", text="Rotation")
249
250         elif ob.dupli_type == 'FACES':
251             split = layout.split()
252
253             col = split.column()
254             col.prop(ob, "use_dupli_faces_scale", text="Scale")
255
256             col = split.column()
257             col.prop(ob, "dupli_faces_scale", text="Inherit Scale")
258
259         elif ob.dupli_type == 'GROUP':
260             layout.prop(ob, "dupli_group", text="Group")
261
262
263 # XXX: the following options are all quite buggy, ancient hacks that should be dropped
264
265 class OBJECT_PT_animation(ObjectButtonsPanel, bpy.types.Panel):
266     bl_label = "Animation Hacks"
267     bl_options = {'DEFAULT_CLOSED'}
268
269     def draw(self, context):
270         layout = self.layout
271
272         ob = context.object
273
274         split = layout.split()
275
276         col = split.column()
277         col.label(text="Time Offset:")
278         col.prop(ob, "use_time_offset_edit", text="Edit")
279         row = col.row()
280         row.prop(ob, "use_time_offset_parent", text="Parent")
281         row.active = (ob.parent is not None)
282         row = col.row()
283         row.prop(ob, "use_slow_parent")
284         row.active = (ob.parent is not None)
285         col.prop(ob, "time_offset", text="Offset")
286
287         # XXX: these are still used for a few curve-related tracking features
288         col = split.column()
289         col.label(text="Tracking Axes:")
290         col.prop(ob, "track_axis", text="Axis")
291         col.prop(ob, "up_axis", text="Up Axis")
292
293 from properties_animviz import MotionPathButtonsPanel, OnionSkinButtonsPanel
294
295
296 class OBJECT_PT_motion_paths(MotionPathButtonsPanel, bpy.types.Panel):
297     #bl_label = "Object Motion Paths"
298     bl_context = "object"
299
300     @classmethod
301     def poll(cls, context):
302         return (context.object)
303
304     def draw(self, context):
305         layout = self.layout
306
307         ob = context.object
308
309         self.draw_settings(context, ob.animation_visualisation)
310
311         layout.separator()
312
313         split = layout.split()
314
315         col = split.column()
316         col.operator("object.paths_calculate", text="Calculate Paths")
317
318         col = split.column()
319         col.operator("object.paths_clear", text="Clear Paths")
320
321
322 class OBJECT_PT_onion_skinning(OnionSkinButtonsPanel):  # , bpy.types.Panel): # inherit from panel when ready
323     #bl_label = "Object Onion Skinning"
324     bl_context = "object"
325
326     @classmethod
327     def poll(cls, context):
328         return (context.object)
329
330     def draw(self, context):
331         layout = self.layout
332
333         ob = context.object
334
335         self.draw_settings(context, ob.animation_visualisation)
336
337
338 class OBJECT_PT_custom_props(bpy.types.Panel, PropertyPanel, ObjectButtonsPanel):
339     COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_GAME'}
340     _context_path = "object"
341
342
343 def register():
344     pass
345
346
347 def unregister():
348     pass
349
350 if __name__ == "__main__":
351     register()