diff options
author | bunnei <bunneidev@gmail.com> | 2018-06-05 00:11:36 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-05 00:11:36 +0200 |
commit | 38d25a4cb2d2430fe7cceaa3104a61c2339c1d03 (patch) | |
tree | b00d32c1f02204de623755b1e1b5348b831ec7f7 /src/video_core/engines | |
parent | Merge pull request #490 from BreadFish64/extension-check (diff) | |
parent | GPU: Calculate the correct viewport dimensions based on the scale and translate registers. (diff) | |
download | yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar.gz yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar.bz2 yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar.lz yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar.xz yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.tar.zst yuzu-38d25a4cb2d2430fe7cceaa3104a61c2339c1d03.zip |
Diffstat (limited to 'src/video_core/engines')
-rw-r--r-- | src/video_core/engines/maxwell_3d.h | 40 |
1 files changed, 28 insertions, 12 deletions
diff --git a/src/video_core/engines/maxwell_3d.h b/src/video_core/engines/maxwell_3d.h index 5cf62fb01..245410c95 100644 --- a/src/video_core/engines/maxwell_3d.h +++ b/src/video_core/engines/maxwell_3d.h @@ -354,10 +354,35 @@ public: f32 scale_x; f32 scale_y; f32 scale_z; - u32 translate_x; - u32 translate_y; - u32 translate_z; + f32 translate_x; + f32 translate_y; + f32 translate_z; INSERT_PADDING_WORDS(2); + + MathUtil::Rectangle<s32> GetRect() const { + return { + GetX(), // left + GetY() + GetHeight(), // top + GetX() + GetWidth(), // right + GetY() // bottom + }; + }; + + s32 GetX() const { + return static_cast<s32>(std::max(0.0f, translate_x - std::fabs(scale_x))); + } + + s32 GetY() const { + return static_cast<s32>(std::max(0.0f, translate_y - std::fabs(scale_y))); + } + + s32 GetWidth() const { + return static_cast<s32>(translate_x + std::fabs(scale_x)) - GetX(); + } + + s32 GetHeight() const { + return static_cast<s32>(translate_y + std::fabs(scale_y)) - GetY(); + } } viewport_transform[NumViewports]; struct { @@ -371,15 +396,6 @@ public: }; float depth_range_near; float depth_range_far; - - MathUtil::Rectangle<s32> GetRect() const { - return { - static_cast<s32>(x), // left - static_cast<s32>(y + height), // top - static_cast<s32>(x + width), // right - static_cast<s32>(y) // bottom - }; - }; } viewport[NumViewports]; INSERT_PADDING_WORDS(0x1D); |