[1/2] richedit: Clip painting to formatting rectangle (try 3)

Dylan Smith dylan.ah.smith at gmail.com
Wed Jan 14 12:23:57 CST 2009


Simplified my previous patch by using IntersectClipRect.
---
 dlls/riched20/paint.c |   17 ++++++++++++++++-
 1 files changed, 16 insertions(+), 1 deletions(-)
-------------- next part --------------
diff --git a/dlls/riched20/paint.c b/dlls/riched20/paint.c
index 565d467..3b026f2 100644
--- a/dlls/riched20/paint.c
+++ b/dlls/riched20/paint.c
@@ -31,6 +31,16 @@ void ME_PaintContent(ME_TextEditor *editor, HDC hDC, BOOL bOnlyNew, const RECT *
   ME_Context c;
   int yoffset;
   int ys, ye;
+  HRGN oldRgn;
+
+  oldRgn = CreateRectRgn(0, 0, 0, 0);
+  if (!GetClipRgn(hDC, oldRgn))
+  {
+    DeleteObject(oldRgn);
+    oldRgn = NULL;
+  }
+  IntersectClipRect(hDC, rcUpdate->left, rcUpdate->top,
+                     rcUpdate->right, rcUpdate->bottom);
 
   editor->nSequence++;
   yoffset = ME_GetYScrollPos(editor);
@@ -107,6 +117,10 @@ void ME_PaintContent(ME_TextEditor *editor, HDC hDC, BOOL bOnlyNew, const RECT *
     ME_SendRequestResize(editor, FALSE);
   editor->nLastTotalLength = editor->nTotalLength;
   ME_DestroyContext(&c, NULL);
+
+  SelectClipRgn(hDC, oldRgn);
+  if (oldRgn)
+    DeleteObject(oldRgn);
 }
 
 void ME_Repaint(ME_TextEditor *editor)
@@ -1037,7 +1051,8 @@ static void ME_Scroll(ME_TextEditor *editor, int value, int type)
   if (abs(nActualScroll) > editor->sizeWindow.cy)
     InvalidateRect(editor->hWnd, NULL, TRUE);
   else
-    ScrollWindowEx(editor->hWnd, 0, nActualScroll, NULL, NULL, NULL, NULL, SW_INVALIDATE);
+    ScrollWindowEx(editor->hWnd, 0, nActualScroll, &editor->rcFormat,
+                   &editor->rcFormat, NULL, NULL, SW_INVALIDATE);
   ME_Repaint(editor);
   
   hWnd = editor->hWnd;


More information about the wine-patches mailing list