X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=render.h;h=aa84b231f0863b4db569a8ad88c9c1848b2ebaaa;hb=63d72af7573ba79f1c8f5cfd95cdafa5bd9a0f1f;hp=f5a77f8b605bedf812c68ef1bdd778b1a9aa5786;hpb=fae52291efa344ad98f83a13308ffa5dd583a11e;p=xonotic%2Fdarkplaces.git diff --git a/render.h b/render.h index f5a77f8b..aa84b231 100644 --- a/render.h +++ b/render.h @@ -145,6 +145,8 @@ skinframe_t *R_SkinFrame_LoadInternalQuake(const char *name, int textureflags, i skinframe_t *R_SkinFrame_LoadInternal8bit(const char *name, int textureflags, const unsigned char *skindata, int width, int height, const unsigned int *palette, const unsigned int *alphapalette); skinframe_t *R_SkinFrame_LoadMissing(void); +rtexture_t *R_GetCubemap(const char *basename); + void R_View_WorldVisibility(qboolean forcenovis); void R_DrawDecals(void); void R_DrawParticles(void); @@ -160,6 +162,17 @@ int R_CullBoxCustomPlanes(const vec3_t mins, const vec3_t maxs, int numplanes, c #include "meshqueue.h" +extern qboolean r_framedata_failed; +void R_FrameData_Reset(void); +void R_FrameData_NewFrame(void); +void *R_FrameData_Alloc(size_t size); +void *R_FrameData_Store(size_t size, void *data); + +void R_AnimCache_Free(void); +void R_AnimCache_ClearCache(void); +qboolean R_AnimCache_GetEntity(entity_render_t *ent, qboolean wantnormals, qboolean wanttangents); +void R_AnimCache_CacheVisibleEntities(void); + #include "r_lerpanim.h" extern cvar_t r_render; @@ -167,7 +180,7 @@ extern cvar_t r_renderview; extern cvar_t r_waterwarp; extern cvar_t r_textureunits; -extern cvar_t r_glsl; + extern cvar_t r_glsl_offsetmapping; extern cvar_t r_glsl_offsetmapping_reliefmapping; extern cvar_t r_glsl_offsetmapping_scale; @@ -182,6 +195,12 @@ extern cvar_t r_smoothnormals_areaweighting; extern cvar_t r_test; +extern cvar_t r_texture_convertsRGB_2d; +extern cvar_t r_texture_convertsRGB_skin; +extern cvar_t r_texture_convertsRGB_cubemap; +extern cvar_t r_texture_convertsRGB_skybox; +extern cvar_t r_texture_convertsRGB_particles; + #include "gl_backend.h" extern rtexture_t *r_texture_blanknormalmap; @@ -304,7 +323,6 @@ typedef struct rsurfacestate_s int ent_qwskin; int ent_flags; float ent_shadertime; - float ent_color[4]; int ent_alttextures; // used by q1bsp animated textures (pressed buttons) // transform matrices to render this entity and effects on this entity matrix4x4_t matrix; @@ -322,8 +340,11 @@ typedef struct rsurfacestate_s // colormapping state from entity (these are black if colormapping is off) vec3_t colormap_pantscolor; vec3_t colormap_shirtcolor; + // special coloring of ambient/diffuse textures (gloss not affected) + // colormod[3] is the alpha of the entity + float colormod[4]; // special coloring of glow textures - vec3_t glowmod; + float glowmod[3]; // view location in model space vec3_t localvieworigin; // polygon offset data for submodels @@ -344,12 +365,6 @@ typedef struct rsurfacestate_s // rtlight rendering // light currently being rendered const rtlight_t *rtlight; - // current light's cull box (copied out of an rtlight or calculated by GetLightInfo) - vec3_t rtlight_cullmins; - vec3_t rtlight_cullmaxs; - // current light's culling planes - int rtlight_numfrustumplanes; - mplane_t rtlight_frustumplanes[12+6+6]; // see R_Shadow_ComputeShadowCasterCullingPlanes // this is the location of the light in entity space vec3_t entitylightorigin; @@ -372,17 +387,18 @@ rsurfacestate_t; extern rsurfacestate_t rsurface; void RSurf_ActiveWorldEntity(void); -void RSurf_ActiveModelEntity(const entity_render_t *ent, qboolean wantnormals, qboolean wanttangents); +void RSurf_ActiveModelEntity(const entity_render_t *ent, qboolean wantnormals, qboolean wanttangents, qboolean prepass); void RSurf_ActiveCustomEntity(const matrix4x4_t *matrix, const matrix4x4_t *inversematrix, int entflags, double shadertime, float r, float g, float b, float a, int numvertices, const float *vertex3f, const float *texcoord2f, const float *normal3f, const float *svector3f, const float *tvector3f, const float *color4f, int numtriangles, const int *element3i, const unsigned short *element3s, qboolean wantnormals, qboolean wanttangents); void RSurf_SetupDepthAndCulling(void); void R_Mesh_ResizeArrays(int newvertices); texture_t *R_GetCurrentTexture(texture_t *t); -void R_DrawWorldSurfaces(qboolean skysurfaces, qboolean writedepth, qboolean depthonly, qboolean debug); -void R_DrawModelSurfaces(entity_render_t *ent, qboolean skysurfaces, qboolean writedepth, qboolean depthonly, qboolean debug); +void R_DrawWorldSurfaces(qboolean skysurfaces, qboolean writedepth, qboolean depthonly, qboolean debug, qboolean prepass); +void R_DrawModelSurfaces(entity_render_t *ent, qboolean skysurfaces, qboolean writedepth, qboolean depthonly, qboolean debug, qboolean prepass); void R_AddWaterPlanes(entity_render_t *ent); -void R_DrawCustomSurface(skinframe_t *skinframe, const matrix4x4_t *texmatrix, int materialflags, int firstvertex, int numvertices, int firsttriangle, int numtriangles, qboolean writedepth); +void R_DrawCustomSurface(skinframe_t *skinframe, const matrix4x4_t *texmatrix, int materialflags, int firstvertex, int numvertices, int firsttriangle, int numtriangles, qboolean writedepth, qboolean prepass); +void R_DrawCustomSurface_Texture(texture_t *texture, const matrix4x4_t *texmatrix, int materialflags, int firstvertex, int numvertices, int firsttriangle, int numtriangles, qboolean writedepth, qboolean prepass); void RSurf_PrepareVerticesForBatch(qboolean generatenormals, qboolean generatetangents, int texturenumsurfaces, const msurface_t **texturesurfacelist); void RSurf_DrawBatch_Simple(int texturenumsurfaces, const msurface_t **texturesurfacelist); @@ -393,7 +409,8 @@ typedef enum rsurfacepass_e { RSURFPASS_BASE, RSURFPASS_BACKGROUND, - RSURFPASS_RTLIGHT + RSURFPASS_RTLIGHT, + RSURFPASS_DEFERREDGEOMETRY, } rsurfacepass_t; @@ -416,7 +433,7 @@ typedef enum gl20_texunit_e // material properties for a colormapped material // conflicts with secondary material GL20TU_PANTS = 4, - GL20TU_SHIRT = 5, + GL20TU_SHIRT = 7, // fog fade in the distance GL20TU_FOGMASK = 8, // compiled ambient lightmap and deluxemap @@ -434,24 +451,38 @@ typedef enum gl20_texunit_e GL20TU_SHADOWMAPRECT = 11, GL20TU_SHADOWMAPCUBE = 11, GL20TU_SHADOWMAP2D = 11, - GL20TU_CUBEPROJECTION = 12 + GL20TU_CUBEPROJECTION = 12, + // orthographic-projection shadowmapping + GL20TU_SHADOWMAPORTHORECT = 15, + GL20TU_SHADOWMAPORTHO2D = 15, + // rtlight prepass data (screenspace depth and normalmap) + GL20TU_SCREENDEPTH = 13, + GL20TU_SCREENNORMALMAP = 14, + // lightmap prepass data (screenspace diffuse and specular from lights) + GL20TU_SCREENDIFFUSE = 11, + GL20TU_SCREENSPECULAR = 12, + // fake reflections + GL20TU_REFLECTMASK = 5, + GL20TU_REFLECTCUBE = 6 } gl20_texunit; -void R_SetupGenericShader(qboolean usetexture); -void R_SetupGenericTwoTextureShader(int texturemode); -void R_SetupDepthOrShadowShader(void); -void R_SetupShowDepthShader(void); -void R_SetupSurfaceShader(const vec3_t lightcolorbase, qboolean modellighting, float ambientscale, float diffusescale, float specularscale, rsurfacepass_t rsurfacepass); +void R_SetupShader_Generic(rtexture_t *first, rtexture_t *second, int texturemode, int rgbscale); +void R_SetupShader_DepthOrShadow(void); +void R_SetupShader_ShowDepth(void); +void R_SetupShader_Surface(const vec3_t lightcolorbase, qboolean modellighting, float ambientscale, float diffusescale, float specularscale, rsurfacepass_t rsurfacepass); +void R_SetupShader_DeferredLight(const rtlight_t *rtlight); typedef struct r_waterstate_waterplane_s { rtexture_t *texture_refraction; rtexture_t *texture_reflection; + rtexture_t *texture_camera; mplane_t plane; int materialflags; // combined flags of all water surfaces on this plane unsigned char pvsbits[(MAX_MAP_LEAFS+7)>>3]; // FIXME: buffer overflow on huge maps qboolean pvsvalid; + int camera_entity; } r_waterstate_waterplane_t; @@ -460,9 +491,11 @@ typedef struct r_waterstate_s qboolean enabled; qboolean renderingscene; // true while rendering a refraction or reflection texture, disables water surfaces + qboolean renderingrefraction; int waterwidth, waterheight; int texturewidth, textureheight; + int camerawidth, cameraheight; int maxwaterplanes; // same as MAX_WATERPLANES int numwaterplanes;