X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=blobdiff_plain;f=gl_backend.h;h=b36225229fa60536b730c846980de4e085cd3a51;hp=fa7961a90963be31edd94d12a950eaaa796920b0;hb=5c77268d0a473dfcf784d69343a3ddabcbd5ab33;hpb=66ba61eab96c3f91e48a2768238c4096efbdb063 diff --git a/gl_backend.h b/gl_backend.h index fa7961a9..b3622522 100644 --- a/gl_backend.h +++ b/gl_backend.h @@ -2,28 +2,32 @@ #ifndef GL_BACKEND_H #define GL_BACKEND_H -#define MAX_TEXTUREUNITS 16 +// how many texture units to track state on (backendunits/backendimageunits/backendarrayunits are limited to this value) +#define MAX_TEXTUREUNITS 64 #define POLYGONELEMENTS_MAXPOINTS 258 -extern int polygonelements[768]; +extern int polygonelements[(POLYGONELEMENTS_MAXPOINTS-2)*3]; +#define QUADELEMENTS_MAXQUADS 128 +extern int quadelements[QUADELEMENTS_MAXQUADS*6]; void GL_SetupView_Orientation_Identity(void); -void GL_SetupView_Orientation_FromEntity(matrix4x4_t *matrix); +void GL_SetupView_Orientation_FromEntity(const matrix4x4_t *matrix); void GL_SetupView_Mode_Perspective(double frustumx, double frustumy, double zNear, double zFar); void GL_SetupView_Mode_PerspectiveInfiniteFarClip(double frustumx, double frustumy, double zNear); void GL_SetupView_Mode_Ortho(double x1, double y1, double x2, double y2, double zNear, double zFar); void GL_BlendFunc(int blendfunc1, int blendfunc2); void GL_DepthMask(int state); void GL_DepthTest(int state); +void GL_CullFace(int state); +void GL_AlphaTest(int state); void GL_ColorMask(int r, int g, int b, int a); void GL_Color(float cr, float cg, float cb, float ca); -void GL_ShowTrisColor(float cr, float cg, float cb, float ca); void GL_TransformToScreen(const vec4_t in, vec4_t out); void GL_LockArrays(int first, int count); void GL_ActiveTexture(unsigned int num); void GL_ClientActiveTexture(unsigned int num); -void GL_Scissor(int x, int y, int width, int height); // AK for DRAWQUEUE_SETCLIP -void GL_ScissorTest(int state); // AK for DRAWQUEUE_(RE)SETCLIP +void GL_Scissor(int x, int y, int width, int height); +void GL_ScissorTest(int state); void GL_Clear(int mask); unsigned int GL_Backend_CompileProgram(int vertexstrings_count, const char **vertexstrings_list, int fragmentstrings_count, const char **fragmentstrings_list); @@ -34,7 +38,7 @@ extern cvar_t gl_mesh_copyarrays; extern cvar_t gl_paranoid; extern cvar_t gl_printcheckerror; -//input to R_Mesh_State +//input to R_Mesh_TextureState typedef struct rmeshstate_s { // textures @@ -52,10 +56,6 @@ typedef struct rmeshstate_s // pointers const float *pointer_texcoord[MAX_TEXTUREUNITS]; // 2D const float *pointer_texcoord3f[MAX_TEXTUREUNITS]; // 3D - - // other state set by this - const float *pointer_vertex; - const float *pointer_color; } rmeshstate_t; @@ -89,8 +89,10 @@ void R_Mesh_TexBindCubeMap(unsigned int unitnum, int texnum); void R_Mesh_TexMatrix(unsigned int unitnum, const matrix4x4_t *matrix); // sets the combine state for a texenv unit void R_Mesh_TexCombine(unsigned int unitnum, int combinergb, int combinealpha, int rgbscale, int alphascale); -// set up the requested entire rendering state -void R_Mesh_State(const rmeshstate_t *m); +// set up the requested texture state +void R_Mesh_TextureState(const rmeshstate_t *m); +// set up a blank texture state (faster/easier specialized version of R_Mesh_TextureState) +void R_Mesh_ResetTextureState(void); // renders a mesh void R_Mesh_Draw(int firstvertex, int numvertices, int numtriangles, const int *elements); @@ -104,38 +106,7 @@ void R_ClearScreen(void); // invoke refresh of frame void SCR_UpdateScreen(void); // invoke refresh of loading plaque (nothing else seen) -void SCR_UpdateLoadingScreen(void); - -// public structure -typedef struct rcachearrayrequest_s -{ - // for use by the code that is requesting the array, these are not - // directly used but merely compared to determine if cache items are - // identical - const void *id_pointer1; - const void *id_pointer2; - const void *id_pointer3; - int id_number1; - int id_number2; - int id_number3; - // size of array data - int data_size; - // array data pointer - void *data; -} -rcachearrayrequest_t; - -int R_Mesh_CacheArray(rcachearrayrequest_t *r); - -extern float varray_vertex3f[65536*3]; -extern float varray_svector3f[65536*3]; -extern float varray_tvector3f[65536*3]; -extern float varray_normal3f[65536*3]; -extern float varray_color4f[65536*4]; -extern float varray_texcoord2f[4][65536*2]; -extern float varray_texcoord3f[4][65536*3]; -extern int earray_element3i[65536]; -extern float varray_vertex3f2[65536*3]; +void SCR_UpdateLoadingScreen(qboolean clear); #endif