X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=gl_backend.h;h=3bdc2e60b9f3c4434db058eb2aaf598a3a2f23cc;hb=69a9f6bb4ea7d2a62b22238da58fe99d0ebd41d8;hp=d5940a3722657d9204165d0ad71cfc8873395b0d;hpb=73624ef15d754ca65acb6f2037989fb582cd7b92;p=xonotic%2Fdarkplaces.git diff --git a/gl_backend.h b/gl_backend.h index d5940a37..3bdc2e60 100644 --- a/gl_backend.h +++ b/gl_backend.h @@ -2,15 +2,17 @@ #ifndef GL_BACKEND_H #define GL_BACKEND_H -#define MAX_TEXTUREUNITS 8 +#define MAX_TEXTUREUNITS 16 #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_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_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); @@ -20,21 +22,22 @@ 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(int num); -void GL_ClientActiveTexture(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_ActiveTexture(unsigned int num); +void GL_ClientActiveTexture(unsigned int num); +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); +void GL_Backend_FreeProgram(unsigned int prog); + extern cvar_t gl_lockarrays; extern cvar_t gl_mesh_copyarrays; extern cvar_t gl_paranoid; extern cvar_t gl_printcheckerror; -extern int c_meshelements, c_meshs; - //input to R_Mesh_State -typedef struct +typedef struct rmeshstate_s { // textures int tex1d[MAX_TEXTUREUNITS]; @@ -46,8 +49,11 @@ typedef struct 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 + // matrices + matrix4x4_t texmatrix[MAX_TEXTUREUNITS]; // pointers - const float *pointer_texcoord[MAX_TEXTUREUNITS]; + const float *pointer_texcoord[MAX_TEXTUREUNITS]; // 2D + const float *pointer_texcoord3f[MAX_TEXTUREUNITS]; // 3D // other state set by this const float *pointer_vertex; @@ -65,54 +71,42 @@ void R_Mesh_Start(void); // (only valid after R_Mesh_Start) void R_Mesh_Finish(void); -// sets up the requested transform matrix +// sets up the requested vertex transform matrix void R_Mesh_Matrix(const matrix4x4_t *matrix); - -// sets up the requested transform matrix -void R_Mesh_TextureMatrix(int unitnumber, const matrix4x4_t *matrix); - -// set up the requested state +// sets the vertex array pointer +void R_Mesh_VertexPointer(const float *vertex3f); +// sets the color array pointer (GL_Color only works when this is NULL) +void R_Mesh_ColorPointer(const float *color4f); +// sets the texcoord array pointer for an array unit +void R_Mesh_TexCoordPointer(unsigned int unitnum, unsigned int numcomponents, const float *texcoord); +// sets all textures bound to an image unit (multiple can be non-zero at once, according to OpenGL rules the highest one overrides the others) +void R_Mesh_TexBindAll(unsigned int unitnum, int tex1d, int tex2d, int tex3d, int texcubemap); +// sets these are like TexBindAll with only one of the texture indices non-zero +// (binds one texture type and unbinds all other types) +void R_Mesh_TexBind1D(unsigned int unitnum, int texnum); +void R_Mesh_TexBind(unsigned int unitnum, int texnum); +void R_Mesh_TexBind3D(unsigned int unitnum, int texnum); +void R_Mesh_TexBindCubeMap(unsigned int unitnum, int texnum); +// sets the texcoord matrix for a texenv unit +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); // renders a mesh -void R_Mesh_Draw(int numverts, int numtriangles, const int *elements); +void R_Mesh_Draw(int firstvertex, int numvertices, int numtriangles, const int *elements); // renders a mesh as lines -void R_Mesh_Draw_ShowTris(int numverts, int numtriangles, const int *elements); +void R_Mesh_Draw_ShowTris(int firstvertex, int numvertices, int numtriangles, const int *elements); // saves a section of the rendered frame to a .tga or .jpg file -qboolean SCR_ScreenShot(char *filename, int x, int y, int width, int height, qboolean jpeg); +qboolean SCR_ScreenShot(char *filename, unsigned char *buffer1, unsigned char *buffer2, unsigned char *buffer3, int x, int y, int width, int height, qboolean flipx, qboolean flipy, qboolean flipdiagonal, qboolean jpeg, qboolean gammacorrect); // used by R_Envmap_f and internally in backend, clears the frame void R_ClearScreen(void); // invoke refresh of frame void SCR_UpdateScreen(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_color4f[65536*4]; -extern float varray_texcoord2f[4][65536*2]; -extern float varray_texcoord3f[4][65536*3]; -extern float varray_normal3f[65536*3]; -extern int earray_element3i[65536]; +// invoke refresh of loading plaque (nothing else seen) +void SCR_UpdateLoadingScreen(void); #endif