Module: wine Branch: master Commit: 86de76b9e177af98ea93721e8775dc533f80bf97 URL: http://source.winehq.org/git/wine.git/?a=commit;h=86de76b9e177af98ea93721e87...
Author: Alexander Kochetkov al.kochet@gmail.com Date: Fri Feb 25 15:19:55 2011 +0300
gdi32: Fix text baseline calculation in compatible mode.
---
dlls/gdi32/font.c | 19 ++++++++++++++++++- 1 files changed, 18 insertions(+), 1 deletions(-)
diff --git a/dlls/gdi32/font.c b/dlls/gdi32/font.c index e17dd44..1dc87b1 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;