1aa853201f02aa58f3138753ca28030cc8d4f1bb
[xonotic/darkplaces.git] / r_shadow.h
1
2 #ifndef R_SHADOW_H
3 #define R_SHADOW_H
4
5 extern cvar_t r_shadow_lightattenuationscale;
6 extern cvar_t r_shadow_lightintensityscale;
7 extern cvar_t r_shadow_realtime;
8 extern cvar_t r_shadow_texture3d;
9 extern cvar_t r_shadow_gloss;
10 extern cvar_t r_shadow_debuglight;
11
12 void R_Shadow_Init(void);
13 void R_Shadow_Volume(int numverts, int numtris, int *elements, int *neighbors, vec3_t relativelightorigin, float lightradius, float projectdistance);
14 void R_Shadow_DiffuseLighting(int numverts, int numtriangles, const int *elements, const float *svectors, const float *tvectors, const float *normals, const float *texcoords, const float *relativelightorigin, float lightradius, const float *lightcolor, rtexture_t *basetexture, rtexture_t *bumptexture, rtexture_t *lightcubemap);
15 void R_Shadow_SpecularLighting(int numverts, int numtriangles, const int *elements, const float *svectors, const float *tvectors, const float *normals, const float *texcoords, const float *relativelightorigin, const float *relativeeyeorigin, float lightradius, const float *lightcolor, rtexture_t *glosstexture, rtexture_t *bumptexture, rtexture_t *lightcubemap);
16 void R_Shadow_ClearStencil(void);
17
18 void R_Shadow_RenderVolume(int numverts, int numtris, int *elements);
19 void R_Shadow_RenderShadowMeshVolume(shadowmesh_t *mesh);
20 void R_Shadow_Stage_Begin(void);
21 void R_Shadow_Stage_ShadowVolumes(void);
22 void R_Shadow_Stage_Light(void);
23 // returns true if shadow volumes should be drawn again to erase,
24 // otherwise clears stencil
25 int R_Shadow_Stage_EraseShadowVolumes(void);
26 void R_Shadow_Stage_End(void);
27
28 typedef struct worldlight_s
29 {
30         vec3_t origin;
31         vec3_t light;
32         vec3_t mins;
33         vec3_t maxs;
34         vec_t lightradius;
35         vec_t cullradius;
36         struct worldlight_s *next;
37         msurface_t **surfaces;
38         int numsurfaces;
39         mleaf_t **leafs;
40         int numleafs;
41         rtexture_t *cubemap;
42         char *cubemapname;
43         int style;
44         shadowmesh_t *shadowvolume;
45         int selected;
46 }
47 worldlight_t;
48
49 extern worldlight_t *r_shadow_worldlightchain;
50
51 // 0 = normal, 1 = dynamic light shadows, 2 = world and dynamic light shadows
52 extern int r_shadow_lightingmode;
53 void R_Shadow_UpdateLightingMode(void);
54
55 void R_Shadow_UpdateWorldLightSelection(void);
56
57 #endif