I/O reg viewer: improve scrollbar handling, and fix a small bug with

names/descriptions that have ampersands and/or underscores inside them.
This commit is contained in:
luigi__ 2009-09-13 10:17:25 +00:00
parent 75b285b45c
commit ce48f43c89
1 changed files with 31 additions and 9 deletions

View File

@ -195,14 +195,26 @@ void CIORegView::ChangeReg(int reg)
if (maxlines < numlines) if (maxlines < numlines)
{ {
RECT rc;
BOOL oldenable = IsWindowEnabled(hScrollbar); BOOL oldenable = IsWindowEnabled(hScrollbar);
int range;
GetClientRect(hWnd, &rc);
range = (numlines * lineheight) - (rc.bottom - rebarHeight);
if (!oldenable) if (!oldenable)
{ {
RECT rc; GetClientRect(hWnd, &rc);
EnableWindow(hScrollbar, TRUE); EnableWindow(hScrollbar, TRUE);
SendMessage(hScrollbar, SBM_SETRANGE, 0, (numlines * lineheight) - (rc.bottom - rebarHeight)); SendMessage(hScrollbar, SBM_SETRANGE, 0, range);
SendMessage(hScrollbar, SBM_SETPOS, 0, 0); SendMessage(hScrollbar, SBM_SETPOS, 0, TRUE);
yoff = 0;
}
else
{
int pos = min(range, (int)SendMessage(hScrollbar, SBM_GETPOS, 0, 0));
SendMessage(hScrollbar, SBM_SETRANGE, 0, range);
SendMessage(hScrollbar, SBM_SETPOS, pos, TRUE);
yoff = -pos;
} }
} }
else else
@ -298,7 +310,7 @@ void IORegView_Paint(CIORegView* wnd, HWND hWnd, WPARAM wParam, LPARAM lParam)
DrawText(hMemDC, txt, curx, cury, fontsize.cx*8, fontsize.cy, DT_LEFT); DrawText(hMemDC, txt, curx, cury, fontsize.cx*8, fontsize.cy, DT_LEFT);
curx += (fontsize.cx*8) + kXMargin + 1 + kXMargin; curx += (fontsize.cx*8) + kXMargin + 1 + kXMargin;
DrawText(hMemDC, curReg.name, curx, cury, nameColWidth, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS); DrawText(hMemDC, curReg.name, curx, cury, nameColWidth, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS | DT_NOPREFIX);
curx += nameColWidth + kXMargin + 1 + kXMargin; curx += nameColWidth + kXMargin + 1 + kXMargin;
switch (curReg.size) switch (curReg.size)
@ -332,7 +344,7 @@ void IORegView_Paint(CIORegView* wnd, HWND hWnd, WPARAM wParam, LPARAM lParam)
nameColWidth = w - (kXMargin + (fontsize.cx*8) + kXMargin + 1 + kXMargin + kXMargin + 1 + kXMargin + (fontsize.cx*8) + kXMargin); nameColWidth = w - (kXMargin + (fontsize.cx*8) + kXMargin + 1 + kXMargin + kXMargin + 1 + kXMargin + (fontsize.cx*8) + kXMargin);
sprintf(txt, "%08X - %s", reg.address, reg.name); sprintf(txt, "%08X - %s", reg.address, reg.name);
DrawText(hMemDC, txt, curx, cury, w, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS); DrawText(hMemDC, txt, curx, cury, w, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS | DT_NOPREFIX);
cury += fontsize.cy + kYMargin; cury += fontsize.cy + kYMargin;
MoveToEx(hMemDC, 0, cury, NULL); MoveToEx(hMemDC, 0, cury, NULL);
LineTo(hMemDC, w, cury); LineTo(hMemDC, w, cury);
@ -389,7 +401,7 @@ void IORegView_Paint(CIORegView* wnd, HWND hWnd, WPARAM wParam, LPARAM lParam)
DrawText(hMemDC, txt, curx, cury, fontsize.cx*8, fontsize.cy, DT_LEFT); DrawText(hMemDC, txt, curx, cury, fontsize.cx*8, fontsize.cy, DT_LEFT);
curx += (fontsize.cx*8) + kXMargin + 1 + kXMargin; curx += (fontsize.cx*8) + kXMargin + 1 + kXMargin;
DrawText(hMemDC, bitfield.name, curx, cury, nameColWidth, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS); DrawText(hMemDC, bitfield.name, curx, cury, nameColWidth, fontsize.cy, DT_LEFT | DT_END_ELLIPSIS | DT_NOPREFIX);
curx += nameColWidth + kXMargin + 1 + kXMargin; curx += nameColWidth + kXMargin + 1 + kXMargin;
char bfpattern[8]; char bfpattern[8];
@ -523,12 +535,22 @@ LRESULT CALLBACK IORegView_Proc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lPar
if (wnd->maxlines < wnd->numlines) if (wnd->maxlines < wnd->numlines)
{ {
BOOL oldenable = IsWindowEnabled(wnd->hScrollbar); BOOL oldenable = IsWindowEnabled(wnd->hScrollbar);
int range = (wnd->numlines * wnd->lineheight) - wndHeight;
if (!oldenable) if (!oldenable)
{ {
EnableWindow(wnd->hScrollbar, TRUE); EnableWindow(wnd->hScrollbar, TRUE);
SendMessage(wnd->hScrollbar, SBM_SETPOS, 0, 0); SendMessage(wnd->hScrollbar, SBM_SETRANGE, 0, range);
SendMessage(wnd->hScrollbar, SBM_SETPOS, 0, TRUE);
wnd->yoff = 0;
}
else
{
int pos = min(range, (int)SendMessage(wnd->hScrollbar, SBM_GETPOS, 0, 0));
SendMessage(wnd->hScrollbar, SBM_SETRANGE, 0, range);
SendMessage(wnd->hScrollbar, SBM_SETPOS, pos, TRUE);
wnd->yoff = -pos;
} }
SendMessage(wnd->hScrollbar, SBM_SETRANGE, 0, (wnd->numlines * wnd->lineheight) - wndHeight);
} }
else else
EnableWindow(wnd->hScrollbar, FALSE); EnableWindow(wnd->hScrollbar, FALSE);