diff options
| author | 2015-05-07 18:37:59 -0400 | |
|---|---|---|
| committer | 2015-05-09 22:26:17 -0400 | |
| commit | 23e8be573ef047d8a0bee191f4065dbcd60a7f65 (patch) | |
| tree | e4274244ccd93c0b4e15e84f551c99382e8169d9 /src/video_core/rasterizer.cpp | |
| parent | rasterizer: Implemented AddSigned combiner op. (diff) | |
| download | yuzu-23e8be573ef047d8a0bee191f4065dbcd60a7f65.tar.gz yuzu-23e8be573ef047d8a0bee191f4065dbcd60a7f65.tar.xz yuzu-23e8be573ef047d8a0bee191f4065dbcd60a7f65.zip | |
rasterizer: Implemented combiner output scaling.
Diffstat (limited to 'src/video_core/rasterizer.cpp')
| -rw-r--r-- | src/video_core/rasterizer.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/video_core/rasterizer.cpp b/src/video_core/rasterizer.cpp index f74721d4b..46a326bb4 100644 --- a/src/video_core/rasterizer.cpp +++ b/src/video_core/rasterizer.cpp | |||
| @@ -597,7 +597,10 @@ static void ProcessTriangleInternal(const VertexShader::OutputVertex& v0, | |||
| 597 | }; | 597 | }; |
| 598 | auto alpha_output = AlphaCombine(tev_stage.alpha_op, alpha_result); | 598 | auto alpha_output = AlphaCombine(tev_stage.alpha_op, alpha_result); |
| 599 | 599 | ||
| 600 | combiner_output = Math::MakeVec(color_output, alpha_output); | 600 | combiner_output[0] = std::min((unsigned)255, color_output.r() * tev_stage.GetColorMultiplier()); |
| 601 | combiner_output[1] = std::min((unsigned)255, color_output.g() * tev_stage.GetColorMultiplier()); | ||
| 602 | combiner_output[2] = std::min((unsigned)255, color_output.b() * tev_stage.GetColorMultiplier()); | ||
| 603 | combiner_output[3] = std::min((unsigned)255, alpha_output * tev_stage.GetAlphaMultiplier()); | ||
| 601 | 604 | ||
| 602 | if (registers.tev_combiner_buffer_input.TevStageUpdatesCombinerBufferColor(tev_stage_index)) { | 605 | if (registers.tev_combiner_buffer_input.TevStageUpdatesCombinerBufferColor(tev_stage_index)) { |
| 603 | combiner_buffer.r() = combiner_output.r(); | 606 | combiner_buffer.r() = combiner_output.r(); |