#include "r_local.h" #include "../ref_gl/gl_export.h" /* ======================== DebugCallback For ARB_debug_output ======================== */ static void APIENTRY GL_DebugOutput( GLuint source, GLuint type, GLuint id, GLuint severity, GLint length, const GLcharARB *message, GLvoid *userParam ) { switch( type ) { case GL_DEBUG_TYPE_ERROR_ARB: gEngfuncs.Con_Printf( S_OPENGL_ERROR "%s\n", message ); break; case GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR_ARB: gEngfuncs.Con_Printf( S_OPENGL_WARN "%s\n", message ); break; case GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR_ARB: gEngfuncs.Con_Printf( S_OPENGL_WARN "%s\n", message ); break; case GL_DEBUG_TYPE_PORTABILITY_ARB: gEngfuncs.Con_Reportf( S_OPENGL_WARN "%s\n", message ); break; case GL_DEBUG_TYPE_PERFORMANCE_ARB: gEngfuncs.Con_Printf( S_OPENGL_NOTE "%s\n", message ); break; case GL_DEBUG_TYPE_OTHER_ARB: default: gEngfuncs.Con_Printf( S_OPENGL_NOTE "%s\n", message ); break; } } int tex; unsigned short *buffer; #define LOAD(x) p##x = gEngfuncs.GL_GetProcAddress(#x) void R_InitBlit() { int i; LOAD(glBegin); LOAD(glEnd); LOAD(glTexCoord2f); LOAD(glVertex2f); LOAD(glEnable); LOAD(glDisable); LOAD(glTexImage2D); LOAD(glOrtho); LOAD(glMatrixMode); LOAD(glLoadIdentity); LOAD(glViewport); LOAD(glBindTexture); LOAD(glDebugMessageCallbackARB); LOAD(glDebugMessageControlARB); LOAD(glGetError); LOAD(glGenTextures); LOAD(glTexParameteri); if( gpGlobals->developer ) { gEngfuncs.Con_Reportf( "Installing GL_DebugOutput...\n"); pglDebugMessageCallbackARB( GL_DebugOutput, NULL ); // force everything to happen in the main thread instead of in a separate driver thread pglEnable( GL_DEBUG_OUTPUT_SYNCHRONOUS_ARB ); } // enable all the low priority messages pglDebugMessageControlARB( GL_DONT_CARE, GL_DONT_CARE, GL_DEBUG_SEVERITY_LOW_ARB, 0, NULL, true ); pglGenTextures( 1, &tex ); buffer = Mem_Malloc( r_temppool, 1920*1080*2 ); for( i = 0; i < 256; i++ ) { unsigned int r,g,b; // 332 to 565 r = ((i >> (8 - 3) )<< 2 ) & MASK(5); g = ((i >> (8 - 3 - 3)) << 3) & MASK(6); b = ((i >> (8 - 3 - 3 - 2)) << 3) & MASK(5); vid.screen_major[i] = r << (6 + 5) | (g << 5) | b; // restore minor GBRGBRGB r = MOVE_BIT(i, 5, 1) | MOVE_BIT(i, 2, 0); g = MOVE_BIT(i, 7, 2) | MOVE_BIT(i, 4, 1) | MOVE_BIT(i, 1, 0); b = MOVE_BIT(i, 6, 2) | MOVE_BIT(i, 3, 1) | MOVE_BIT(i, 0, 0); vid.screen_minor[i] = r << (6 + 5) | (g << 5) | b; } } void R_BlitScreen() { //memset( vid.buffer, 10, vid.width * vid.height ); int i; byte *buf = vid.buffer; for( i = 0; i < vid.width * vid.height;i++) { byte major = buf[(i<<1)+1]; byte minor = buf[(i<<1)]; buffer[i] = vid.screen_major[major]|vid.screen_minor[minor]; } pglBindTexture(GL_TEXTURE_2D, tex); pglViewport( 0, 0, gpGlobals->width, gpGlobals->height ); pglMatrixMode( GL_PROJECTION ); pglLoadIdentity(); pglOrtho( 0, gpGlobals->width, gpGlobals->height, 0, -99999, 99999 ); pglMatrixMode( GL_MODELVIEW ); pglLoadIdentity(); pglEnable( GL_TEXTURE_2D ); pglBindTexture(GL_TEXTURE_2D, tex); pglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); pglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); pglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); pglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); //gEngfuncs.Con_Printf("%d\n",pglGetError()); pglTexImage2D( GL_TEXTURE_2D, 0, GL_RGB, vid.width, vid.height, 0, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, buffer ); //gEngfuncs.Con_Printf("%d\n",pglGetError()); pglBegin( GL_QUADS ); pglTexCoord2f( 0, 0 ); pglVertex2f( 0, 0 ); pglTexCoord2f( 1, 0 ); pglVertex2f( vid.width, 0 ); pglTexCoord2f( 1, 1 ); pglVertex2f( vid.width, vid.height ); pglTexCoord2f( 0, 1 ); pglVertex2f( 0, vid.height ); pglEnd(); pglDisable( GL_TEXTURE_2D ); gEngfuncs.GL_SwapBuffers(); }