e3db1e6af4167d6e9fea15bd26014e6da4e21dc1
[blender.git] / release / scripts / ui / properties_data_camera.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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
16 #
17 # ##### END GPL LICENSE BLOCK #####
18
19 # <pep8 compliant>
20 import bpy
21
22 narrowui = 180
23
24
25 class DataButtonsPanel(bpy.types.Panel):
26     bl_space_type = 'PROPERTIES'
27     bl_region_type = 'WINDOW'
28     bl_context = "data"
29
30     def poll(self, context):
31         return context.camera
32
33
34 class DATA_PT_context_camera(DataButtonsPanel):
35     bl_label = ""
36     bl_show_header = False
37
38     def draw(self, context):
39         layout = self.layout
40
41         ob = context.object
42         cam = context.camera
43         space = context.space_data
44         col2 = context.region.width > narrowui
45
46         if col2:
47             split = layout.split(percentage=0.65)
48
49             if ob:
50                 split.template_ID(ob, "data")
51                 split.itemS()
52             elif cam:
53                 split.template_ID(space, "pin_id")
54                 split.itemS()
55         else:
56             layout.template_ID(ob, "data")
57
58
59 class DATA_PT_camera(DataButtonsPanel):
60     bl_label = "Lens"
61
62     def draw(self, context):
63         layout = self.layout
64
65         cam = context.camera
66         col2 = context.region.width > narrowui
67
68         if col2:
69             layout.itemR(cam, "type", expand=True)
70         else:
71             layout.itemR(cam, "type", text="")
72
73         split = layout.split()
74
75         col = split.column()
76         if cam.type == 'PERSP':
77             if cam.lens_unit == 'MILLIMETERS':
78                 col.itemR(cam, "lens", text="Angle")
79             elif cam.lens_unit == 'DEGREES':
80                 col.itemR(cam, "angle")
81             if col2:
82                 col = split.column()
83             col.itemR(cam, "lens_unit", text="")
84
85         elif cam.type == 'ORTHO':
86             col.itemR(cam, "ortho_scale")
87
88         layout.itemR(cam, "panorama")
89
90         split = layout.split()
91
92         col = split.column(align=True)
93         col.itemL(text="Shift:")
94         col.itemR(cam, "shift_x", text="X")
95         col.itemR(cam, "shift_y", text="Y")
96
97         if col2:
98             col = split.column(align=True)
99         col.itemL(text="Clipping:")
100         col.itemR(cam, "clip_start", text="Start")
101         col.itemR(cam, "clip_end", text="End")
102
103         layout.itemL(text="Depth of Field:")
104
105         split = layout.split()
106
107         col = split.column()
108         col.itemR(cam, "dof_object", text="")
109
110         if col2:
111             col = split.column()
112         col.itemR(cam, "dof_distance", text="Distance")
113
114
115 class DATA_PT_camera_display(DataButtonsPanel):
116     bl_label = "Display"
117
118     def draw(self, context):
119         layout = self.layout
120
121         cam = context.camera
122         col2 = context.region.width > narrowui
123
124         split = layout.split()
125
126         col = split.column()
127         col.itemR(cam, "show_limits", text="Limits")
128         col.itemR(cam, "show_mist", text="Mist")
129         col.itemR(cam, "show_title_safe", text="Title Safe")
130         col.itemR(cam, "show_name", text="Name")
131
132         if col2:
133             col = split.column()
134         col.itemR(cam, "draw_size", text="Size")
135         col.itemS()
136         col.itemR(cam, "show_passepartout", text="Passepartout")
137         sub = col.column()
138         sub.active = cam.show_passepartout
139         sub.itemR(cam, "passepartout_alpha", text="Alpha", slider=True)
140
141 bpy.types.register(DATA_PT_context_camera)
142 bpy.types.register(DATA_PT_camera)
143 bpy.types.register(DATA_PT_camera_display)