From 86de76b9e177af98ea93721e8775dc533f80bf97 Mon Sep 17 00:00:00 2001 From: Alexander Kochetkov Date: Fri, 25 Feb 2011 15:19:55 +0300 Subject: [PATCH] gdi32: Fix text baseline calculation in compatible mode. --- dlls/gdi32/font.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/dlls/gdi32/font.c b/dlls/gdi32/font.c index e17dd44483d..1dc87b1166b 100644 --- a/dlls/gdi32/font.c +++ b/dlls/gdi32/font.c @@ -2155,6 +2155,12 @@ BOOL WINAPI ExtTextOutW( HDC hdc, INT x, INT y, UINT flags, if(!(tm.tmPitchAndFamily & TMPF_VECTOR)) /* Non-scalable fonts shouldn't be rotated */ lf.lfEscapement = 0; + if ((dc->GraphicsMode == GM_COMPATIBLE) && + (dc->vport2WorldValid && dc->xformWorld2Vport.eM11 * dc->xformWorld2Vport.eM22 < 0)) + { + lf.lfEscapement = -lf.lfEscapement; + } + if(lf.lfEscapement != 0) { cosEsc = cos(lf.lfEscapement * M_PI / 1800); @@ -2262,7 +2268,18 @@ BOOL WINAPI ExtTextOutW( HDC hdc, INT x, INT y, UINT flags, LPtoDP(hdc, desired, 2); desired[1].x -= desired[0].x; desired[1].y -= desired[0].y; - if (layout & LAYOUT_RTL) desired[1].x = -desired[1].x; + + if (dc->GraphicsMode == GM_COMPATIBLE) + { + if (dc->vport2WorldValid && dc->xformWorld2Vport.eM11 < 0) + desired[1].x = -desired[1].x; + if (dc->vport2WorldValid && dc->xformWorld2Vport.eM22 < 0) + desired[1].y = -desired[1].y; + } + else + { + if (layout & LAYOUT_RTL) desired[1].x = -desired[1].x; + } deltas[i].x = desired[1].x - width.x; deltas[i].y = desired[1].y - width.y;