1c6b8399422673b92e2d4f6e1074c0e88ead4a7a
[blender-staging.git] / source / blender / gpu / GPU_draw.h
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This shader 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. The Blender
10  * Foundation also sells licenses for use in proprietary software under
11  * the Blender License.  See http://www.blender.org/BL/ for information
12  * about this.
13  *
14  * This shader is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this shader; if not, write to the Free Software Foundation,
21  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  *
23  * The Original Code is Copyright (C) 2005 Blender Foundation.
24  * All rights reserved.
25  *
26  * The Original Code is: all of this file.
27  *
28  * Contributor(s): Brecht Van Lommel.
29  *
30  * ***** END GPL LICENSE BLOCK *****
31  */
32
33 #ifndef GPU_GAME_H
34 #define GPU_GAME_H
35
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39
40 struct Image;
41 struct MTFace;
42 struct Object;
43 struct Scene;
44 struct View3D;
45 struct RegionView3D;
46
47 /* OpenGL drawing functions related to shading. These are also
48  * shared with the game engine, where there were previously
49  * duplicates of some of these functions. */
50
51 /* Initialize
52  * - sets the default Blender opengl state, if in doubt, check
53  *   the contents of this function
54  * - this is called when starting Blender, for opengl rendering,
55  *   and for switching back from the game engine for example. */
56
57 void GPU_state_init(void);
58
59 /* Material drawing
60  * - first the state is initialized by a particular object and
61  *   it's materials
62  * - after this, materials can be quickly enabled by their number,
63  *   GPU_enable_material returns 0 if drawing should be skipped
64  * - after drawing, the material must be disabled again */
65
66 void GPU_begin_object_materials(struct View3D *v3d, struct RegionView3D *rv3d, 
67         struct Scene *scene, struct Object *ob, int glsl, int *do_alpha_pass);
68 void GPU_end_object_materials(void);
69
70 int GPU_enable_material(int nr, void *attribs);
71 void GPU_disable_material(void);
72
73 void GPU_set_material_blend_mode(int blendmode);
74 int GPU_get_material_blend_mode(void);
75
76 /* TexFace drawing
77  * - this is mutually exclusive with material drawing, a mesh should
78  *   be drawn using one or the other
79  * - passing NULL clears the state again */
80
81 int GPU_set_tpage(struct MTFace *tface, int mipmap);
82
83 /* Lights
84  * - returns how many lights were enabled
85  * - this affects fixed functions materials and texface, not glsl */
86
87 int GPU_default_lights(void);
88 int GPU_scene_object_lights(struct Scene *scene, struct Object *ob,
89         int lay, float viewmat[][4], int ortho);
90
91 /* Text render
92  * - based on moving uv coordinates */
93
94 void GPU_render_text(struct MTFace *tface, int mode,
95         const char *textstr, int textlen, unsigned int *col,
96         float *v1, float *v2, float *v3, float *v4, int glattrib);
97
98 /* Mipmap settings
99  * - these will free textures on changes */
100
101 void GPU_set_mipmap(int mipmap);
102 void GPU_set_linear_mipmap(int linear);
103 void GPU_paint_set_mipmap(int mipmap);
104
105 /* Image updates and free
106  * - these deal with images bound as opengl textures */
107
108 void GPU_paint_update_image(struct Image *ima, int x, int y, int w, int h, int mipmap);
109 void GPU_update_images_framechange(void);
110 int GPU_update_image_time(struct Image *ima, double time);
111 int GPU_verify_image(struct Image *ima, int tftile, int tfmode, int compare, int mipmap);
112 void GPU_free_image(struct Image *ima);
113 void GPU_free_images(void);
114
115 /* smoke drawing functions */
116 void GPU_free_smoke(struct SmokeModifierData *smd);
117 void GPU_create_smoke(struct SmokeModifierData *smd);
118
119 #ifdef __cplusplus
120 }
121 #endif
122
123 #endif
124