X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=blobdiff_plain;f=gl_backend.h;h=143b0f248b614c1f72d7df646cb91add00006f3d;hp=3e1a17c29a4de031159a38dc5ee7caa47e689753;hb=65c5c9c594e16a38c8eae6107ea2b93237a9367f;hpb=12a3c44a3e0403d4806d8803cc1469e7c822a975 diff --git a/gl_backend.h b/gl_backend.h index 3e1a17c2..143b0f24 100644 --- a/gl_backend.h +++ b/gl_backend.h @@ -7,15 +7,15 @@ #define POLYGONELEMENTS_MAXPOINTS 258 extern int polygonelements[768]; -void GL_DrawRangeElements(int firstvert, int endvert, int indexcount, int *index); - void GL_SetupView_ViewPort (int x, int y, int width, int height); void GL_SetupView_Orientation_Identity (void); void GL_SetupView_Orientation_FromEntity (vec3_t origin, vec3_t angles); -void GL_SetupView_Mode_Perspective (double aspect, double fovx, double fovy, double zNear, double zFar); +void GL_SetupView_Mode_Perspective (double fovx, double fovy, double zNear, double zFar); +void GL_SetupView_Mode_PerspectiveInfiniteFarClip (double fovx, double fovy, double zNear); void GL_SetupView_Mode_Ortho (double x1, double y1, double x2, double y2, double zNear, double zFar); -void GL_DepthFunc(int value); -void GL_ClearDepth(void); +void GL_UseColorArray(void); +void GL_Color(float cr, float cg, float cb, float ca); +void GL_TransformToScreen(const vec4_t in, vec4_t out); extern cvar_t gl_lockarrays; @@ -28,14 +28,21 @@ typedef struct int depthdisable; // disable depth read/write entirely int blendfunc1; int blendfunc2; - int wantoverbright; + //int wantoverbright; + int tex1d[MAX_TEXTUREUNITS]; int tex[MAX_TEXTUREUNITS]; + int tex3d[MAX_TEXTUREUNITS]; + int texcubemap[MAX_TEXTUREUNITS]; int texrgbscale[MAX_TEXTUREUNITS]; // used only if COMBINE is present + int texalphascale[MAX_TEXTUREUNITS]; // used only if COMBINE is present + int texcombinergb[MAX_TEXTUREUNITS]; // works with or without combine for some operations + int texcombinealpha[MAX_TEXTUREUNITS]; // does nothing without combine } rmeshstate_t; // overbright rendering scale for the current state -extern float mesh_colorscale; +extern int r_lightmapscalebit; +extern float r_colorscale; extern float *varray_vertex; extern float *varray_color; extern float *varray_texcoord[MAX_TEXTUREUNITS]; @@ -57,12 +64,18 @@ void R_Mesh_Matrix(const matrix4x4_t *matrix); // sets up the requested state void R_Mesh_State(const rmeshstate_t *m); +// sets up the requested main state +void R_Mesh_MainState(const rmeshstate_t *m); + +// sets up the requested texture state +void R_Mesh_TextureState(const rmeshstate_t *m); + // enlarges vertex arrays if they are too small #define R_Mesh_ResizeCheck(numverts) if ((numverts) > mesh_maxverts) _R_Mesh_ResizeCheck(numverts); void _R_Mesh_ResizeCheck(int numverts); // renders the mesh in the varray_* buffers -void R_Mesh_Draw(int numverts, int numtriangles, int *elements); +void R_Mesh_Draw(int numverts, int numtriangles, const int *elements); // saves a section of the rendered frame to a .tga file qboolean SCR_ScreenShot(char *filename, int x, int y, int width, int height);