summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/video_core/renderer_vulkan/vk_sampler_cache.cpp11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/video_core/renderer_vulkan/vk_sampler_cache.cpp b/src/video_core/renderer_vulkan/vk_sampler_cache.cpp
index 0a8ec8398..204b7c39c 100644
--- a/src/video_core/renderer_vulkan/vk_sampler_cache.cpp
+++ b/src/video_core/renderer_vulkan/vk_sampler_cache.cpp
@@ -23,7 +23,14 @@ static std::optional<vk::BorderColor> TryConvertBorderColor(std::array<float, 4>
23 } else if (color == std::array<float, 4>{1, 1, 1, 1}) { 23 } else if (color == std::array<float, 4>{1, 1, 1, 1}) {
24 return vk::BorderColor::eFloatOpaqueWhite; 24 return vk::BorderColor::eFloatOpaqueWhite;
25 } else { 25 } else {
26 return {}; 26 if (color[0] + color[1] + color[2] > 1.35f) {
27 // If color elements are brighter than roughly 0.5 average, use white border
28 return vk::BorderColor::eFloatOpaqueWhite;
29 }
30 if (color[3] > 0.5f) {
31 return vk::BorderColor::eFloatOpaqueBlack;
32 }
33 return vk::BorderColor::eFloatTransparentBlack;
27 } 34 }
28} 35}
29 36
@@ -37,8 +44,6 @@ UniqueSampler VKSamplerCache::CreateSampler(const Tegra::Texture::TSCEntry& tsc)
37 44
38 const auto border_color{tsc.GetBorderColor()}; 45 const auto border_color{tsc.GetBorderColor()};
39 const auto vk_border_color{TryConvertBorderColor(border_color)}; 46 const auto vk_border_color{TryConvertBorderColor(border_color)};
40 UNIMPLEMENTED_IF_MSG(!vk_border_color, "Unimplemented border color {} {} {} {}",
41 border_color[0], border_color[1], border_color[2], border_color[3]);
42 47
43 constexpr bool unnormalized_coords{false}; 48 constexpr bool unnormalized_coords{false};
44 49