X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=r_light.h;h=a3c7066e26fbe81c9177f3b8d948109f2fc57ca8;hb=093c41bf532834207d8a23df44f5b39fa707815d;hp=9a264c9428fba804966c0eb7b5ac1e226531ed12;hpb=12d41dc109d083ea965d53d2c35aec6ecd246691;p=xonotic%2Fdarkplaces.git diff --git a/r_light.h b/r_light.h index 9a264c94..a3c7066e 100644 --- a/r_light.h +++ b/r_light.h @@ -1,12 +1,26 @@ +#ifndef R_LIGHT_H +#define R_LIGHT_H + typedef struct { vec3_t origin; vec_t cullradius2; // only for culling comparisons, squared version vec3_t light; // the brightness of the light vec_t cullradius; // only for culling comparisons - vec_t lightsubtract; // to avoid sudden brightness change at cullradius, subtract this + vec_t subtract; // to avoid sudden brightness change at cullradius, subtract this entity_render_t *ent; // owner of this light + + matrix4x4_t matrix_lighttoworld; + matrix4x4_t matrix_worldtolight; + matrix4x4_t matrix_worldtoattenuationxyz; + matrix4x4_t matrix_worldtoattenuationz; + + vec3_t color; + vec_t radius; + int cubemapnum; + int shadow; + vec_t corona; } rdlight_t; @@ -15,7 +29,12 @@ extern rdlight_t r_dlight[MAX_DLIGHTS]; void R_BuildLightList(void); void R_AnimateLight(void); -void R_MarkLights(void); +void R_MarkLights(entity_render_t *ent); void R_DrawCoronas(void); -void R_CompleteLightPoint(vec3_t color, vec3_t p, int dynamic, mleaf_t *leaf); -void R_LightModel(int numverts); +void R_CompleteLightPoint(vec3_t ambientcolor, vec3_t diffusecolor, vec3_t diffusenormal, const vec3_t p, int dynamic, const mleaf_t *leaf); +int R_LightModel(float *ambient4f, float *diffusecolor, float *diffusenormal, const entity_render_t *ent, float colorr, float colorg, float colorb, float colora, int worldcoords); +void R_LightModel_CalcVertexColors(const float *ambientcolor4f, const float *diffusecolor, const float *diffusenormal, int numverts, const float *vertex3f, const float *normal3f, float *color4f); +void R_UpdateEntLights(entity_render_t *ent); + +#endif +