mirror of
https://github.com/libsdl-org/SDL.git
synced 2026-05-28 11:57:24 +08:00
[SDL2] Implement SDL_GL_GetAttribute for SDL_GL_FLOATBUFFERS
This commit is contained in:
committed by
Sam Lantinga
parent
b36252b120
commit
3c36718348
@@ -399,6 +399,7 @@ struct SDL_VideoDevice
|
|||||||
int no_error;
|
int no_error;
|
||||||
int retained_backing;
|
int retained_backing;
|
||||||
int driver_loaded;
|
int driver_loaded;
|
||||||
|
int HAS_GL_ARB_color_buffer_float;
|
||||||
char driver_path[256];
|
char driver_path[256];
|
||||||
void *dll_handle;
|
void *dll_handle;
|
||||||
} gl_config;
|
} gl_config;
|
||||||
|
|||||||
@@ -70,6 +70,10 @@
|
|||||||
#include <dlfcn.h>
|
#include <dlfcn.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef GL_RGBA_FLOAT_MODE_ARB
|
||||||
|
#define GL_RGBA_FLOAT_MODE_ARB 0x8820
|
||||||
|
#endif /* GL_RGBA_FLOAT_MODE_ARB */
|
||||||
|
|
||||||
/* Available video drivers */
|
/* Available video drivers */
|
||||||
static VideoBootStrap *bootstrap[] = {
|
static VideoBootStrap *bootstrap[] = {
|
||||||
#ifdef SDL_VIDEO_DRIVER_COCOA
|
#ifdef SDL_VIDEO_DRIVER_COCOA
|
||||||
@@ -4036,6 +4040,15 @@ int SDL_GL_GetAttribute(SDL_GLattr attr, int *value)
|
|||||||
*value = _this->gl_config.no_error;
|
*value = _this->gl_config.no_error;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
case SDL_GL_FLOATBUFFERS:
|
||||||
|
{
|
||||||
|
if (_this->gl_config.HAS_GL_ARB_color_buffer_float) {
|
||||||
|
attrib = GL_RGBA_FLOAT_MODE_ARB;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
return SDL_SetError("Unknown OpenGL attribute");
|
return SDL_SetError("Unknown OpenGL attribute");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -511,6 +511,10 @@ void WIN_GL_InitExtensions(_THIS)
|
|||||||
_this->gl_data->HAS_WGL_ARB_create_context_no_error = SDL_TRUE;
|
_this->gl_data->HAS_WGL_ARB_create_context_no_error = SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check for WGL_ARB_pixel_format_float */
|
||||||
|
_this->gl_data->HAS_WGL_ARB_pixel_format_float =
|
||||||
|
HasExtension("WGL_ARB_pixel_format_float", extensions);
|
||||||
|
|
||||||
_this->gl_data->wglMakeCurrent(hdc, NULL);
|
_this->gl_data->wglMakeCurrent(hdc, NULL);
|
||||||
_this->gl_data->wglDeleteContext(hglrc);
|
_this->gl_data->wglDeleteContext(hglrc);
|
||||||
ReleaseDC(hwnd, hdc);
|
ReleaseDC(hwnd, hdc);
|
||||||
@@ -641,7 +645,7 @@ static int WIN_GL_SetupWindowInternal(_THIS, SDL_Window *window)
|
|||||||
*iAttr++ = _this->gl_config.multisamplesamples;
|
*iAttr++ = _this->gl_config.multisamplesamples;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_this->gl_config.floatbuffers) {
|
if (_this->gl_data->HAS_WGL_ARB_pixel_format_float && _this->gl_config.floatbuffers) {
|
||||||
*iAttr++ = WGL_PIXEL_TYPE_ARB;
|
*iAttr++ = WGL_PIXEL_TYPE_ARB;
|
||||||
*iAttr++ = WGL_TYPE_RGBA_FLOAT_ARB;
|
*iAttr++ = WGL_TYPE_RGBA_FLOAT_ARB;
|
||||||
}
|
}
|
||||||
@@ -825,6 +829,9 @@ SDL_GLContext WIN_GL_CreateContext(_THIS, SDL_Window *window)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_this->gl_config.HAS_GL_ARB_color_buffer_float =
|
||||||
|
SDL_GL_ExtensionSupported("GL_ARB_color_buffer_float");
|
||||||
|
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -64,6 +64,7 @@ struct SDL_GLDriverData
|
|||||||
SDL_bool HAS_WGL_ARB_context_flush_control;
|
SDL_bool HAS_WGL_ARB_context_flush_control;
|
||||||
SDL_bool HAS_WGL_ARB_create_context_robustness;
|
SDL_bool HAS_WGL_ARB_create_context_robustness;
|
||||||
SDL_bool HAS_WGL_ARB_create_context_no_error;
|
SDL_bool HAS_WGL_ARB_create_context_no_error;
|
||||||
|
SDL_bool HAS_WGL_ARB_pixel_format_float;
|
||||||
|
|
||||||
/* Max version of OpenGL ES context that can be created if the
|
/* Max version of OpenGL ES context that can be created if the
|
||||||
implementation supports WGL_EXT_create_context_es2_profile.
|
implementation supports WGL_EXT_create_context_es2_profile.
|
||||||
|
|||||||
Reference in New Issue
Block a user