Commit 6b3fd786 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

riched20: Use row ptrs in the cursor to co-ordinates function.

parent f45408b2
...@@ -218,31 +218,29 @@ int set_selection_cursors(ME_TextEditor *editor, int from, int to) ...@@ -218,31 +218,29 @@ int set_selection_cursors(ME_TextEditor *editor, int from, int to)
} }
void ME_GetCursorCoordinates(ME_TextEditor *editor, ME_Cursor *pCursor, void cursor_coords( ME_TextEditor *editor, ME_Cursor *cursor,
int *x, int *y, int *height) int *x, int *y, int *height )
{ {
ME_DisplayItem *row; ME_Row *row;
ME_Run *run = &pCursor->pRun->member.run; ME_Run *run = &cursor->pRun->member.run;
ME_Paragraph *para = &pCursor->pPara->member.para; ME_Paragraph *para = &cursor->pPara->member.para;
ME_Run *size_run = run, *prev; ME_Run *size_run = run, *prev;
ME_Context c; ME_Context c;
int run_x; int run_x;
assert(height && x && y);
assert(~para->nFlags & MEPF_REWRAP); assert(~para->nFlags & MEPF_REWRAP);
row = ME_FindItemBack( run_get_di( run ), diStartRowOrParagraph ); row = row_from_cursor( cursor );
assert(row && row->type == diStartRow);
ME_InitContext(&c, editor, ITextHost_TxGetDC(editor->texthost)); ME_InitContext(&c, editor, ITextHost_TxGetDC(editor->texthost));
if (!pCursor->nOffset && (prev = run_prev( run ))) size_run = prev; if (!cursor->nOffset && (prev = run_prev( run ))) size_run = prev;
run_x = ME_PointFromCharContext( &c, run, pCursor->nOffset, TRUE ); run_x = ME_PointFromCharContext( &c, run, cursor->nOffset, TRUE );
*height = size_run->nAscent + size_run->nDescent; *height = size_run->nAscent + size_run->nDescent;
*x = c.rcView.left + run->pt.x + run_x - editor->horz_si.nPos; *x = c.rcView.left + run->pt.x + run_x - editor->horz_si.nPos;
*y = c.rcView.top + para->pt.y + row->member.row.nBaseline *y = c.rcView.top + para->pt.y + row->nBaseline
+ run->pt.y - size_run->nAscent - editor->vert_si.nPos; + run->pt.y - size_run->nAscent - editor->vert_si.nPos;
ME_DestroyContext(&c); ME_DestroyContext(&c);
return; return;
...@@ -252,7 +250,7 @@ void create_caret(ME_TextEditor *editor) ...@@ -252,7 +250,7 @@ void create_caret(ME_TextEditor *editor)
{ {
int x, y, height; int x, y, height;
ME_GetCursorCoordinates(editor, &editor->pCursors[0], &x, &y, &height); cursor_coords( editor, &editor->pCursors[0], &x, &y, &height );
ITextHost_TxCreateCaret(editor->texthost, NULL, 0, height); ITextHost_TxCreateCaret(editor->texthost, NULL, 0, height);
editor->caret_height = height; editor->caret_height = height;
editor->caret_hidden = TRUE; editor->caret_hidden = TRUE;
...@@ -281,7 +279,7 @@ void update_caret(ME_TextEditor *editor) ...@@ -281,7 +279,7 @@ void update_caret(ME_TextEditor *editor)
if (!editor->bHaveFocus) return; if (!editor->bHaveFocus) return;
if (!ME_IsSelection(editor)) if (!ME_IsSelection(editor))
{ {
ME_GetCursorCoordinates(editor, &editor->pCursors[0], &x, &y, &height); cursor_coords( editor, &editor->pCursors[0], &x, &y, &height );
if (height != editor->caret_height) create_caret(editor); if (height != editor->caret_height) create_caret(editor);
x = min(x, editor->rcFormat.right-1); x = min(x, editor->rcFormat.right-1);
ITextHost_TxSetCaretPos(editor->texthost, x, y); ITextHost_TxSetCaretPos(editor->texthost, x, y);
......
...@@ -164,6 +164,7 @@ static inline ME_DisplayItem *run_get_di( ME_Run *run ) ...@@ -164,6 +164,7 @@ static inline ME_DisplayItem *run_get_di( ME_Run *run )
} }
/* caret.c */ /* caret.c */
void cursor_coords( ME_TextEditor *editor, ME_Cursor *cursor, int *x, int *y, int *height ) DECLSPEC_HIDDEN;
void ME_SetCursorToStart(ME_TextEditor *editor, ME_Cursor *cursor) DECLSPEC_HIDDEN; void ME_SetCursorToStart(ME_TextEditor *editor, ME_Cursor *cursor) DECLSPEC_HIDDEN;
int set_selection_cursors(ME_TextEditor *editor, int from, int to) DECLSPEC_HIDDEN; int set_selection_cursors(ME_TextEditor *editor, int from, int to) DECLSPEC_HIDDEN;
BOOL ME_MoveCursorWords(ME_TextEditor *editor, ME_Cursor *cursor, int nRelOfs) DECLSPEC_HIDDEN; BOOL ME_MoveCursorWords(ME_TextEditor *editor, ME_Cursor *cursor, int nRelOfs) DECLSPEC_HIDDEN;
...@@ -192,7 +193,6 @@ BOOL ME_InternalDeleteText(ME_TextEditor *editor, ME_Cursor *start, int nChars, ...@@ -192,7 +193,6 @@ BOOL ME_InternalDeleteText(ME_TextEditor *editor, ME_Cursor *start, int nChars,
int ME_GetTextLength(ME_TextEditor *editor) DECLSPEC_HIDDEN; int ME_GetTextLength(ME_TextEditor *editor) DECLSPEC_HIDDEN;
int ME_GetTextLengthEx(ME_TextEditor *editor, const GETTEXTLENGTHEX *how) DECLSPEC_HIDDEN; int ME_GetTextLengthEx(ME_TextEditor *editor, const GETTEXTLENGTHEX *how) DECLSPEC_HIDDEN;
ME_Style *ME_GetSelectionInsertStyle(ME_TextEditor *editor) DECLSPEC_HIDDEN; ME_Style *ME_GetSelectionInsertStyle(ME_TextEditor *editor) DECLSPEC_HIDDEN;
void ME_GetCursorCoordinates(ME_TextEditor *editor, ME_Cursor *pCursor, int *x, int *y, int *height) DECLSPEC_HIDDEN;
/* context.c */ /* context.c */
void ME_InitContext(ME_Context *c, ME_TextEditor *editor, HDC hDC) DECLSPEC_HIDDEN; void ME_InitContext(ME_Context *c, ME_TextEditor *editor, HDC hDC) DECLSPEC_HIDDEN;
......
...@@ -2734,11 +2734,11 @@ static HRESULT WINAPI ITextRange_fnScrollIntoView(ITextRange *me, LONG value) ...@@ -2734,11 +2734,11 @@ static HRESULT WINAPI ITextRange_fnScrollIntoView(ITextRange *me, LONG value)
{ {
case tomStart: case tomStart:
cursor_from_char_ofs( editor, This->start, &cursor ); cursor_from_char_ofs( editor, This->start, &cursor );
ME_GetCursorCoordinates(editor, &cursor, &x, &y, &height); cursor_coords( editor, &cursor, &x, &y, &height );
break; break;
case tomEnd: case tomEnd:
cursor_from_char_ofs( editor, This->end, &cursor ); cursor_from_char_ofs( editor, This->end, &cursor );
ME_GetCursorCoordinates(editor, &cursor, &x, &y, &height); cursor_coords( editor, &cursor, &x, &y, &height );
break; break;
default: default:
FIXME("bStart value %d not handled\n", value); FIXME("bStart value %d not handled\n", value);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment