mirror of
https://github.com/ZDoom/gzdoom-gles.git
synced 2025-01-19 07:00:52 +00:00
- add vid_hdr cvar that enables higher than 8bpc output for monitors that support it
# Conflicts: # src/v_video.cpp # src/win32/win32glvideo.cpp # Conflicts: # src/gl/renderer/gl_postprocess.cpp
This commit is contained in:
parent
73ed375b6f
commit
4cd535b3b6
3 changed files with 89 additions and 44 deletions
|
@ -68,6 +68,8 @@
|
|||
#include "gl/stereo3d/gl_stereo3d.h"
|
||||
#include "r_videoscale.h"
|
||||
|
||||
extern bool vid_hdr_active;
|
||||
|
||||
//==========================================================================
|
||||
//
|
||||
// CVARs
|
||||
|
@ -855,6 +857,8 @@ void FGLRenderer::CopyToBackbuffer(const GL_IRECT *bounds, bool applyGamma)
|
|||
|
||||
void FGLRenderer::DrawPresentTexture(const GL_IRECT &box, bool applyGamma)
|
||||
{
|
||||
float invgamma;
|
||||
|
||||
glViewport(box.left, box.top, box.width, box.height);
|
||||
|
||||
GLRenderer->mBuffers->BindDitherTexture(1);
|
||||
|
@ -875,19 +879,28 @@ void FGLRenderer::DrawPresentTexture(const GL_IRECT &box, bool applyGamma)
|
|||
mPresentShader->InputTexture.Set(0);
|
||||
if (!applyGamma || framebuffer->IsHWGammaActive())
|
||||
{
|
||||
mPresentShader->InvGamma.Set(1.0f);
|
||||
invgamma = 1.0f;
|
||||
mPresentShader->InvGamma.Set(invgamma);
|
||||
mPresentShader->Contrast.Set(1.0f);
|
||||
mPresentShader->Brightness.Set(0.0f);
|
||||
mPresentShader->Saturation.Set(1.0f);
|
||||
}
|
||||
else
|
||||
{
|
||||
mPresentShader->InvGamma.Set(1.0f / clamp<float>(Gamma, 0.1f, 4.f));
|
||||
invgamma = 1.0f / clamp<float>(Gamma, 0.1f, 4.f);
|
||||
mPresentShader->InvGamma.Set(invgamma);
|
||||
mPresentShader->Contrast.Set(clamp<float>(vid_contrast, 0.1f, 3.f));
|
||||
mPresentShader->Brightness.Set(clamp<float>(vid_brightness, -0.8f, 0.8f));
|
||||
mPresentShader->Saturation.Set(clamp<float>(vid_saturation, -15.0f, 15.f));
|
||||
mPresentShader->GrayFormula.Set(static_cast<int>(gl_satformula));
|
||||
}
|
||||
if (vid_hdr_active && framebuffer->IsFullscreen())
|
||||
{
|
||||
// Full screen exclusive mode treats a rgba16f frame buffer as linear.
|
||||
// It probably will eventually in desktop mode too, but the DWM doesn't seem to support that.
|
||||
invgamma *= 2.2f;
|
||||
mPresentShader->InvGamma.Set(invgamma);
|
||||
}
|
||||
mPresentShader->Scale.Set(mScreenViewport.width / (float)mBuffers->GetWidth(), mScreenViewport.height / (float)mBuffers->GetHeight());
|
||||
RenderScreenQuad();
|
||||
}
|
||||
|
|
|
@ -85,6 +85,7 @@
|
|||
#include "vm.h"
|
||||
#include "r_videoscale.h"
|
||||
#include "i_time.h"
|
||||
#include "version.h"
|
||||
#include "atterm.h"
|
||||
|
||||
EXTERN_CVAR(Bool, r_blendmethod)
|
||||
|
@ -1695,12 +1696,19 @@ void IVideo::DumpAdapters ()
|
|||
Printf("Multi-monitor support unavailable.\n");
|
||||
}
|
||||
|
||||
CUSTOM_CVAR(Bool, vid_hdr, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
||||
{
|
||||
Printf("This won't take effect until " GAMENAME " is restarted.\n");
|
||||
}
|
||||
|
||||
CCMD(vid_listadapters)
|
||||
{
|
||||
if (Video != NULL)
|
||||
Video->DumpAdapters();
|
||||
}
|
||||
|
||||
bool vid_hdr_active = false;
|
||||
|
||||
DEFINE_GLOBAL(SmallFont)
|
||||
DEFINE_GLOBAL(SmallFont2)
|
||||
DEFINE_GLOBAL(BigFont)
|
||||
|
|
|
@ -62,6 +62,7 @@
|
|||
#include "gl/system/gl_swframebuffer.h"
|
||||
|
||||
extern HWND Window;
|
||||
EXTERN_CVAR(Bool, vid_hdr)
|
||||
|
||||
extern "C" {
|
||||
__declspec(dllexport) DWORD NvOptimusEnablement = 0x00000001;
|
||||
|
@ -70,6 +71,7 @@ extern "C" {
|
|||
|
||||
void gl_CalculateCPUSpeed();
|
||||
extern int NewWidth, NewHeight, NewBits, DisplayBits;
|
||||
extern bool vid_hdr_active;
|
||||
|
||||
// these get used before GLEW is initialized so we have to use separate pointers with different names
|
||||
PFNWGLCHOOSEPIXELFORMATARBPROC myWglChoosePixelFormatARB; // = (PFNWGLCHOOSEPIXELFORMATARBPROC)wglGetProcAddress("wglChoosePixelFormatARB");
|
||||
|
@ -734,12 +736,16 @@ bool Win32GLVideo::SetPixelFormat()
|
|||
//
|
||||
//==========================================================================
|
||||
|
||||
static void append(std::vector<int> &list1, std::initializer_list<int> list2)
|
||||
{
|
||||
list1.insert(list1.end(), list2);
|
||||
}
|
||||
|
||||
bool Win32GLVideo::SetupPixelFormat(int multisample)
|
||||
{
|
||||
int i;
|
||||
int colorDepth;
|
||||
HDC deskDC;
|
||||
int attributes[28];
|
||||
std::vector<int> attributes;
|
||||
int pixelFormat;
|
||||
unsigned int numFormats;
|
||||
float attribsFloat[] = {0.0f, 0.0f};
|
||||
|
@ -751,59 +757,77 @@ bool Win32GLVideo::SetupPixelFormat(int multisample)
|
|||
if (myWglChoosePixelFormatARB)
|
||||
{
|
||||
again:
|
||||
attributes[0] = WGL_RED_BITS_ARB; //bits
|
||||
attributes[1] = 8;
|
||||
attributes[2] = WGL_GREEN_BITS_ARB; //bits
|
||||
attributes[3] = 8;
|
||||
attributes[4] = WGL_BLUE_BITS_ARB; //bits
|
||||
attributes[5] = 8;
|
||||
attributes[6] = WGL_ALPHA_BITS_ARB;
|
||||
attributes[7] = 8;
|
||||
attributes[8] = WGL_DEPTH_BITS_ARB;
|
||||
attributes[9] = 24;
|
||||
attributes[10] = WGL_STENCIL_BITS_ARB;
|
||||
attributes[11] = 8;
|
||||
|
||||
attributes[12] = WGL_DRAW_TO_WINDOW_ARB; //required to be true
|
||||
attributes[13] = true;
|
||||
attributes[14] = WGL_SUPPORT_OPENGL_ARB;
|
||||
attributes[15] = true;
|
||||
attributes[16] = WGL_DOUBLE_BUFFER_ARB;
|
||||
attributes[17] = true;
|
||||
|
||||
append(attributes, { WGL_DEPTH_BITS_ARB, 24 });
|
||||
append(attributes, { WGL_STENCIL_BITS_ARB, 8 });
|
||||
|
||||
//required to be true
|
||||
append(attributes, { WGL_DRAW_TO_WINDOW_ARB, GL_TRUE });
|
||||
append(attributes, { WGL_SUPPORT_OPENGL_ARB, GL_TRUE });
|
||||
append(attributes, { WGL_DOUBLE_BUFFER_ARB, GL_TRUE });
|
||||
|
||||
if (multisample > 0)
|
||||
{
|
||||
attributes[18] = WGL_SAMPLE_BUFFERS_ARB;
|
||||
attributes[19] = true;
|
||||
attributes[20] = WGL_SAMPLES_ARB;
|
||||
attributes[21] = multisample;
|
||||
i = 22;
|
||||
append(attributes, { WGL_SAMPLE_BUFFERS_ARB, GL_TRUE });
|
||||
append(attributes, { WGL_SAMPLES_ARB, multisample });
|
||||
}
|
||||
else
|
||||
{
|
||||
i = 18;
|
||||
}
|
||||
|
||||
attributes[i++] = WGL_ACCELERATION_ARB; //required to be FULL_ACCELERATION_ARB
|
||||
attributes[i++] = WGL_FULL_ACCELERATION_ARB;
|
||||
|
||||
|
||||
append(attributes, { WGL_ACCELERATION_ARB, WGL_FULL_ACCELERATION_ARB }); //required to be FULL_ACCELERATION_ARB
|
||||
|
||||
if (vr_enable_quadbuffered)
|
||||
{
|
||||
// [BB] Starting with driver version 314.07, NVIDIA GeForce cards support OpenGL quad buffered
|
||||
// stereo rendering with 3D Vision hardware. Select the corresponding attribute here.
|
||||
attributes[i++] = WGL_STEREO_ARB;
|
||||
attributes[i++] = true;
|
||||
append(attributes, { WGL_STEREO_ARB, GL_TRUE });
|
||||
}
|
||||
|
||||
attributes[i++] = 0;
|
||||
attributes[i++] = 0;
|
||||
|
||||
if (!myWglChoosePixelFormatARB(m_hDC, attributes, attribsFloat, 1, &pixelFormat, &numFormats))
|
||||
|
||||
size_t bitsPos = attributes.size();
|
||||
|
||||
if (vid_hdr)
|
||||
{
|
||||
append(attributes, { WGL_RED_BITS_ARB, 16 });
|
||||
append(attributes, { WGL_GREEN_BITS_ARB, 16 });
|
||||
append(attributes, { WGL_BLUE_BITS_ARB, 16 });
|
||||
append(attributes, { WGL_ALPHA_BITS_ARB, 16 });
|
||||
append(attributes, { WGL_PIXEL_TYPE_ARB, WGL_TYPE_RGBA_FLOAT_ARB });
|
||||
}
|
||||
else
|
||||
{
|
||||
append(attributes, { WGL_RED_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_GREEN_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_BLUE_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_ALPHA_BITS_ARB, 8 });
|
||||
}
|
||||
|
||||
append(attributes, { 0, 0 });
|
||||
|
||||
if (!myWglChoosePixelFormatARB(m_hDC, attributes.data(), attribsFloat, 1, &pixelFormat, &numFormats))
|
||||
{
|
||||
Printf("R_OPENGL: Couldn't choose pixel format. Retrying in compatibility mode\n");
|
||||
goto oldmethod;
|
||||
}
|
||||
|
||||
if (vid_hdr && numFormats == 0) // This card/driver doesn't support the rgb16f pixel format. Fall back to 8bpc
|
||||
{
|
||||
Printf("R_OPENGL: This card/driver does not support RGBA16F. HDR will not work.\n");
|
||||
|
||||
attributes.erase(attributes.begin() + bitsPos, attributes.end());
|
||||
append(attributes, { WGL_RED_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_GREEN_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_BLUE_BITS_ARB, 8 });
|
||||
append(attributes, { WGL_ALPHA_BITS_ARB, 8 });
|
||||
append(attributes, { 0, 0 });
|
||||
|
||||
if (!myWglChoosePixelFormatARB(m_hDC, attributes.data(), attribsFloat, 1, &pixelFormat, &numFormats))
|
||||
{
|
||||
Printf("R_OPENGL: Couldn't choose pixel format. Retrying in compatibility mode\n");
|
||||
goto oldmethod;
|
||||
}
|
||||
}
|
||||
else if (vid_hdr)
|
||||
{
|
||||
vid_hdr_active = true;
|
||||
}
|
||||
|
||||
if (numFormats == 0)
|
||||
{
|
||||
if (vr_enable_quadbuffered)
|
||||
|
|
Loading…
Reference in a new issue