From 1a5f679d439a0b09f41fcd5856983ab8b31a5980 Mon Sep 17 00:00:00 2001 From: Magnus Norddahl Date: Sun, 8 Apr 2018 13:45:23 +0200 Subject: [PATCH] - Fix depth values when screenblocks less than 11 --- src/swrenderer/drawers/r_draw.cpp | 4 ++++ src/swrenderer/plane/r_flatplane.cpp | 3 ++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/src/swrenderer/drawers/r_draw.cpp b/src/swrenderer/drawers/r_draw.cpp index d7a6ddd41..8db9d3be8 100644 --- a/src/swrenderer/drawers/r_draw.cpp +++ b/src/swrenderer/drawers/r_draw.cpp @@ -225,6 +225,7 @@ namespace swrenderer if (rendertarget->IsBgra()) { uint32_t *destorg = (uint32_t*)rendertarget->GetBuffer(); + destorg += viewwindowx + viewwindowy * rendertarget->GetPitch(); uint32_t *dest = (uint32_t*)args.Dest(); int offset = (int)(ptrdiff_t)(dest - destorg); x = offset % rendertarget->GetPitch(); @@ -233,6 +234,7 @@ namespace swrenderer else { uint8_t *destorg = rendertarget->GetBuffer(); + destorg += viewwindowx + viewwindowy * rendertarget->GetPitch(); uint8_t *dest = (uint8_t*)args.Dest(); int offset = (int)(ptrdiff_t)(dest - destorg); x = offset % rendertarget->GetPitch(); @@ -247,6 +249,7 @@ namespace swrenderer if (rendertarget->IsBgra()) { uint32_t *destorg = (uint32_t*)rendertarget->GetBuffer(); + destorg += viewwindowx + viewwindowy * rendertarget->GetPitch(); uint32_t *dest = (uint32_t*)args.Dest(); int offset = (int)(ptrdiff_t)(dest - destorg); x = offset % rendertarget->GetPitch(); @@ -255,6 +258,7 @@ namespace swrenderer else { uint8_t *destorg = rendertarget->GetBuffer(); + destorg += viewwindowx + viewwindowy * rendertarget->GetPitch(); uint8_t *dest = (uint8_t*)args.Dest(); int offset = (int)(ptrdiff_t)(dest - destorg); x = offset % rendertarget->GetPitch(); diff --git a/src/swrenderer/plane/r_flatplane.cpp b/src/swrenderer/plane/r_flatplane.cpp index d582aaf48..8d0120559 100644 --- a/src/swrenderer/plane/r_flatplane.cpp +++ b/src/swrenderer/plane/r_flatplane.cpp @@ -178,7 +178,8 @@ namespace swrenderer double curyfrac = baseyfrac + ystepscale * (x1 - minx); double distance = viewport->PlaneDepth(y, planeheight); - float zbufferdepth = 1.0f / (distance * Thread->Viewport->viewwindow.FocalTangent); + + float zbufferdepth = (float)(1.0 / fabs(planeheight / Thread->Viewport->ScreenToViewY(y, 1.0))); drawerargs.SetTextureUStep(distance * xstepscale / drawerargs.TextureWidth()); drawerargs.SetTextureUPos((distance * curxfrac + pviewx) / drawerargs.TextureWidth());