VKSwapChain: Always use surface formats with a normal sRGB color space if not RGBA16F
Co-authored-by: TellowKrinkle <tellowkrinkle@gmail.com>
This commit is contained in:
parent
cf29214c03
commit
e6f335bfcf
|
@ -176,18 +176,20 @@ bool SwapChain::SelectSurfaceFormat()
|
||||||
// because we already apply gamma ourselves, and we might not use sRGB gamma.
|
// because we already apply gamma ourselves, and we might not use sRGB gamma.
|
||||||
// Force using a linear format instead, if this is the case.
|
// Force using a linear format instead, if this is the case.
|
||||||
VkFormat format = VKTexture::GetLinearFormat(surface_format.format);
|
VkFormat format = VKTexture::GetLinearFormat(surface_format.format);
|
||||||
|
if (surface_format.colorSpace == VK_COLOR_SPACE_SRGB_NONLINEAR_KHR)
|
||||||
|
{
|
||||||
if (format == VK_FORMAT_R8G8B8A8_UNORM)
|
if (format == VK_FORMAT_R8G8B8A8_UNORM)
|
||||||
surface_format_RGBA8 = &surface_format;
|
surface_format_RGBA8 = &surface_format;
|
||||||
else if (format == VK_FORMAT_B8G8R8A8_UNORM)
|
else if (format == VK_FORMAT_B8G8R8A8_UNORM)
|
||||||
surface_format_BGRA8 = &surface_format;
|
surface_format_BGRA8 = &surface_format;
|
||||||
else if (format == VK_FORMAT_A2B10G10R10_UNORM_PACK32 &&
|
else if (format == VK_FORMAT_A2B10G10R10_UNORM_PACK32)
|
||||||
surface_format.colorSpace == VK_COLOR_SPACE_SRGB_NONLINEAR_KHR)
|
|
||||||
surface_format_RGB10_A2 = &surface_format;
|
surface_format_RGB10_A2 = &surface_format;
|
||||||
|
}
|
||||||
else if (format == VK_FORMAT_R16G16B16A16_SFLOAT &&
|
else if (format == VK_FORMAT_R16G16B16A16_SFLOAT &&
|
||||||
surface_format.colorSpace == VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT)
|
surface_format.colorSpace == VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT)
|
||||||
|
{
|
||||||
surface_format_RGBA16F_scRGB = &surface_format;
|
surface_format_RGBA16F_scRGB = &surface_format;
|
||||||
else
|
}
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const VkSurfaceFormatKHR* surface_format = nullptr;
|
const VkSurfaceFormatKHR* surface_format = nullptr;
|
||||||
|
|
Loading…
Reference in New Issue