diff --git a/src/v_video.cpp b/src/v_video.cpp index afab505a7..8f49f9b39 100644 --- a/src/v_video.cpp +++ b/src/v_video.cpp @@ -886,12 +886,10 @@ void V_DrawStretchyFixedPatch(fixed_t x, fixed_t y, fixed_t pscale, fixed_t vsca else pwidth = patch->width * dupx; - float fdupy = FIXED_TO_FLOAT(vdup); - float fx = x; float fy = y; float fx2 = fx + pwidth; - float fy2 = fy + static_cast(patch->height) * fdupy; + float fy2 = fy + ((patch->height * vdup) / FRACUNIT); float falpha = 1.f; float umin = 0.f; float umax = 1.f; @@ -2497,6 +2495,7 @@ fixed_t V_StringScaledWidth( boolean uppercase; fixed_t cx, cy; + fixed_t right; fixed_t cw; @@ -2699,6 +2698,7 @@ fixed_t V_StringScaledWidth( } cx = cy = 0; + right = 0; for (; ( c = *s ); ++s) { @@ -2716,6 +2716,12 @@ fixed_t V_StringScaledWidth( if (c >= 0 && c < font->size && font->font[c]) { cw = SHORT (font->font[c]->width) * dupx; + + // How bunched dims work is by incrementing cx slightly less than a full character width. + // This causes the next character to be drawn overlapping the previous. + // We need to count the full width to get the rightmost edge of the string though. + right = cx + (cw * scale); + (*dim_fn)(scale, chw, hchw, dupx, &cw); cx += cw; } @@ -2723,7 +2729,7 @@ fixed_t V_StringScaledWidth( cx += spacew; } - fullwidth = std::max(cx, fullwidth); + fullwidth = std::max(right, std::max(cx, fullwidth)); } return fullwidth;