diff options
| author | 2020-02-21 15:56:09 -0300 | |
|---|---|---|
| committer | 2020-02-21 15:56:09 -0300 | |
| commit | 4a6a1aeab489960d73a4e0f2f62865f06944a3a2 (patch) | |
| tree | f6d2bac565533c6b9d0db675d6706ed7d0b18c7f | |
| parent | Merge pull request #3434 from namkazt/patch-2 (diff) | |
| parent | fixups mistake auto commit. (diff) | |
| download | yuzu-4a6a1aeab489960d73a4e0f2f62865f06944a3a2.tar.gz yuzu-4a6a1aeab489960d73a4e0f2f62865f06944a3a2.tar.xz yuzu-4a6a1aeab489960d73a4e0f2f62865f06944a3a2.zip | |
Merge pull request #3433 from namkazt/patch-1
renderer_vulkan: Add the rest of case for TryConvertBorderColor
Diffstat (limited to '')
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_sampler_cache.cpp | 11 |
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 | ||