|
|
@ -439,6 +439,11 @@ OGLTexture MakeImage(const VideoCommon::ImageInfo& info, GLenum gl_internal_form
|
|
|
|
return GL_R32UI;
|
|
|
|
return GL_R32UI;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[[nodiscard]] bool IsAstcRecompressionEnabled() {
|
|
|
|
|
|
|
|
return Settings::values.astc_recompression.GetValue() !=
|
|
|
|
|
|
|
|
Settings::AstcRecompression::Uncompressed;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[[nodiscard]] GLenum SelectAstcFormat(PixelFormat format, bool is_srgb) {
|
|
|
|
[[nodiscard]] GLenum SelectAstcFormat(PixelFormat format, bool is_srgb) {
|
|
|
|
switch (Settings::values.astc_recompression.GetValue()) {
|
|
|
|
switch (Settings::values.astc_recompression.GetValue()) {
|
|
|
|
case Settings::AstcRecompression::Bc1:
|
|
|
|
case Settings::AstcRecompression::Bc1:
|
|
|
@ -760,7 +765,7 @@ Image::Image(TextureCacheRuntime& runtime_, const VideoCommon::ImageInfo& info_,
|
|
|
|
gl_format = GL_RGBA;
|
|
|
|
gl_format = GL_RGBA;
|
|
|
|
gl_type = GL_UNSIGNED_INT_8_8_8_8_REV;
|
|
|
|
gl_type = GL_UNSIGNED_INT_8_8_8_8_REV;
|
|
|
|
|
|
|
|
|
|
|
|
if (IsPixelFormatASTC(info.format)) {
|
|
|
|
if (IsPixelFormatASTC(info.format) && IsAstcRecompressionEnabled()) {
|
|
|
|
gl_internal_format = SelectAstcFormat(info.format, is_srgb);
|
|
|
|
gl_internal_format = SelectAstcFormat(info.format, is_srgb);
|
|
|
|
gl_format = GL_NONE;
|
|
|
|
gl_format = GL_NONE;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1155,7 +1160,7 @@ ImageView::ImageView(TextureCacheRuntime& runtime, const VideoCommon::ImageViewI
|
|
|
|
const bool is_srgb = IsPixelFormatSRGB(info.format);
|
|
|
|
const bool is_srgb = IsPixelFormatSRGB(info.format);
|
|
|
|
internal_format = is_srgb ? GL_SRGB8_ALPHA8 : GL_RGBA8;
|
|
|
|
internal_format = is_srgb ? GL_SRGB8_ALPHA8 : GL_RGBA8;
|
|
|
|
|
|
|
|
|
|
|
|
if (IsPixelFormatASTC(info.format)) {
|
|
|
|
if (IsPixelFormatASTC(info.format) && IsAstcRecompressionEnabled()) {
|
|
|
|
internal_format = SelectAstcFormat(info.format, is_srgb);
|
|
|
|
internal_format = SelectAstcFormat(info.format, is_srgb);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|