rna function:
[blender.git] / source / blender / makesrna / intern / rna_camera_api.c
1 /*
2  * $Id:
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  * Contributor(s): Campbell Barton
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24
25 /** \file blender/makesrna/intern/rna_camera_api.c
26  *  \ingroup RNA
27  */
28
29
30 #include <stdlib.h>
31 #include <stdio.h>
32 #include <string.h>
33
34
35 #include "RNA_define.h"
36 #include "BKE_utildefines.h"
37
38 #ifdef RNA_RUNTIME
39
40 #include "DNA_scene_types.h"
41 #include "BKE_context.h"
42 #include "BKE_object.h"
43
44 void rna_camera_view_frame(struct Camera *camera, struct Scene *scene,
45                            float vec1_r[3], float vec2_r[3], float vec3_r[3], float vec4_r[3])
46 {
47         float vec[4][3];
48
49         camera_view_frame(scene, camera, vec);
50
51         copy_v3_v3(vec1_r, vec[0]);
52         copy_v3_v3(vec2_r, vec[1]);
53         copy_v3_v3(vec3_r, vec[2]);
54         copy_v3_v3(vec4_r, vec[3]);
55 }
56
57 #else
58
59 void RNA_api_camera(StructRNA *srna)
60 {
61         FunctionRNA *func;
62         PropertyRNA *parm;
63
64         func= RNA_def_function(srna, "view_frame", "rna_camera_view_frame");
65         RNA_def_function_ui_description(func, "Return 4 points for the cameras frame (before object transformation)");
66
67         RNA_def_pointer(func, "scene", "Scene", "", "Scene to use for aspect calculation, when omitted 1:1 aspect is used");
68
69         /* return location and normal */
70         parm= RNA_def_float_vector(func, "result_1", 3, NULL, -FLT_MAX, FLT_MAX, "Result", NULL, -1e4, 1e4);
71         RNA_def_property_flag(parm, PROP_THICK_WRAP);
72         RNA_def_function_output(func, parm);
73
74         parm= RNA_def_float_vector(func, "result_2", 3, NULL, -FLT_MAX, FLT_MAX, "Result", NULL, -1e4, 1e4);
75         RNA_def_property_flag(parm, PROP_THICK_WRAP);
76         RNA_def_function_output(func, parm);
77
78         parm= RNA_def_float_vector(func, "result_3", 3, NULL, -FLT_MAX, FLT_MAX, "Result", NULL, -1e4, 1e4);
79         RNA_def_property_flag(parm, PROP_THICK_WRAP);
80         RNA_def_function_output(func, parm);
81
82         parm= RNA_def_float_vector(func, "result_4", 3, NULL, -FLT_MAX, FLT_MAX, "Result", NULL, -1e4, 1e4);
83         RNA_def_property_flag(parm, PROP_THICK_WRAP);
84         RNA_def_function_output(func, parm);
85 }
86
87 #endif
88