// on each level change for the used skinframes, if some are not used they
// are freed
int loadsequence;
- // on 32bit systems this makes the struct 128 bytes long
- int padding;
+ // indicates whether this texture has transparent pixels
+ qboolean hasalpha;
// average texture color, if applicable
float avgcolor[4];
+ // for mdl skins, we actually only upload on first use (many are never used, and they are almost never used in both base+pants+shirt and merged modes)
+ unsigned char *qpixels;
+ int qwidth;
+ int qheight;
+ qboolean qhascolormapping;
+ qboolean qgeneratebase;
+ qboolean qgeneratemerged;
+ qboolean qgeneratenmap;
+ qboolean qgenerateglow;
}
skinframe_t;
}
texturelayertype_t;
-typedef enum texturelayerflag_e
-{
- // indicates that the pass should apply fog darkening; used on
- // transparent surfaces where simply blending an alpha fog as a final
- // pass would not behave properly, so all the surfaces must be darkened,
- // and the fog color added as a separate pass
- TEXTURELAYERFLAG_FOGDARKEN = 1,
-}
-texturelayerflag_t;
-
typedef struct texturelayer_s
{
texturelayertype_t type;
rtexture_t *texture;
matrix4x4_t texmatrix;
vec4_t color;
- int flags;
}
texturelayer_t;
q3shaderinfo_deform_t deforms[Q3MAXDEFORMS];
qboolean colormapping;
- rtexture_t *basetexture;
- rtexture_t *glosstexture;
- rtexture_t *backgroundbasetexture;
- rtexture_t *backgroundglosstexture;
+ rtexture_t *basetexture; // original texture without pants/shirt/glow
+ rtexture_t *pantstexture; // pants only (in greyscale)
+ rtexture_t *shirttexture; // shirt only (in greyscale)
+ rtexture_t *nmaptexture; // normalmap (bumpmap for dot3)
+ rtexture_t *glosstexture; // glossmap (for dot3)
+ rtexture_t *glowtexture; // glow only (fullbrights)
+ rtexture_t *fogtexture; // alpha of the base texture (if not opaque)
+ rtexture_t *backgroundbasetexture; // original texture without pants/shirt/glow
+ rtexture_t *backgroundnmaptexture; // normalmap (bumpmap for dot3)
+ rtexture_t *backgroundglosstexture; // glossmap (for dot3)
+ rtexture_t *backgroundglowtexture; // glow only (fullbrights)
float specularscale;
float specularpower;
// color tint (colormod * currentalpha) used for rtlighting this material
void(*DrawDepth)(struct entity_render_s *ent);
// draw any enabled debugging effects on this model (such as showing triangles, normals, collision brushes...)
void(*DrawDebug)(struct entity_render_s *ent);
+ // draw geometry textures for deferred rendering
+ void(*DrawPrepass)(struct entity_render_s *ent);
// compile an optimized shadowmap mesh for the model based on light source
void(*CompileShadowMap)(struct entity_render_s *ent, vec3_t relativelightorigin, vec3_t relativelightdirection, float lightradius, int numsurfaces, const int *surfacelist);
// draw depth into a shadowmap
void(*DrawShadowMap)(int side, struct entity_render_s *ent, const vec3_t relativelightorigin, const vec3_t relativelightdirection, float lightradius, int numsurfaces, const int *surfacelist, const unsigned char *surfacesides, const vec3_t lightmins, const vec3_t lightmaxs);
// gathers info on which clusters and surfaces are lit by light, as well as calculating a bounding box
- void(*GetLightInfo)(struct entity_render_s *ent, vec3_t relativelightorigin, float lightradius, vec3_t outmins, vec3_t outmaxs, int *outleaflist, unsigned char *outleafpvs, int *outnumleafspointer, int *outsurfacelist, unsigned char *outsurfacepvs, int *outnumsurfacespointer, unsigned char *outshadowtrispvs, unsigned char *outlighttrispvs, unsigned char *visitingleafpvs);
+ void(*GetLightInfo)(struct entity_render_s *ent, vec3_t relativelightorigin, float lightradius, vec3_t outmins, vec3_t outmaxs, int *outleaflist, unsigned char *outleafpvs, int *outnumleafspointer, int *outsurfacelist, unsigned char *outsurfacepvs, int *outnumsurfacespointer, unsigned char *outshadowtrispvs, unsigned char *outlighttrispvs, unsigned char *visitingleafpvs, int numfrustumplanes, const mplane_t *frustumplanes);
// compile a shadow volume for the model based on light source
void(*CompileShadowVolume)(struct entity_render_s *ent, vec3_t relativelightorigin, vec3_t relativelightdirection, float lightradius, int numsurfaces, const int *surfacelist);
// draw a shadow volume for the model based on light source
void R_Q1BSP_Draw(struct entity_render_s *ent);
void R_Q1BSP_DrawDepth(struct entity_render_s *ent);
void R_Q1BSP_DrawDebug(struct entity_render_s *ent);
-void R_Q1BSP_GetLightInfo(struct entity_render_s *ent, vec3_t relativelightorigin, float lightradius, vec3_t outmins, vec3_t outmaxs, int *outleaflist, unsigned char *outleafpvs, int *outnumleafspointer, int *outsurfacelist, unsigned char *outsurfacepvs, int *outnumsurfacespointer, unsigned char *outshadowtrispvs, unsigned char *outlighttrispvs, unsigned char *visitingleafpvs);
+void R_Q1BSP_DrawPrepass(struct entity_render_s *ent);
+void R_Q1BSP_GetLightInfo(struct entity_render_s *ent, vec3_t relativelightorigin, float lightradius, vec3_t outmins, vec3_t outmaxs, int *outleaflist, unsigned char *outleafpvs, int *outnumleafspointer, int *outsurfacelist, unsigned char *outsurfacepvs, int *outnumsurfacespointer, unsigned char *outshadowtrispvs, unsigned char *outlighttrispvs, unsigned char *visitingleafpvs, int numfrustumplanes, const mplane_t *frustumplanes);
void R_Q1BSP_CompileShadowMap(struct entity_render_s *ent, vec3_t relativelightorigin, vec3_t relativelightdirection, float lightradius, int numsurfaces, const int *surfacelist);
void R_Q1BSP_DrawShadowMap(int side, struct entity_render_s *ent, const vec3_t relativelightorigin, const vec3_t relativelightdirection, float lightradius, int modelnumsurfaces, const int *modelsurfacelist, const unsigned char *surfacesides, const vec3_t lightmins, const vec3_t lightmaxs);
void R_Q1BSP_CompileShadowVolume(struct entity_render_s *ent, vec3_t relativelightorigin, vec3_t relativelightdirection, float lightradius, int numsurfaces, const int *surfacelist);