fix scrolling; resize board, enabling scrolling, when SIP is revealed.

And make it possible for user to reveal it.
This commit is contained in:
ehouse 2005-06-13 14:29:49 +00:00
parent 3eb04b4161
commit 5f0648c840

View file

@ -257,29 +257,43 @@ ceInitUtilFuncs( CEAppGlobals* globals )
} /* ceInitUtilFuncs */ } /* ceInitUtilFuncs */
#ifdef CEFEATURE_CANSCROLL #ifdef CEFEATURE_CANSCROLL
# define SCROLL_SHRINK 1
static void static void
installScroller( CEAppGlobals* globals, XP_U16 nHidden, XP_U16 x, XP_U16 y, showScroller( CEAppGlobals* globals, XP_U16 nHidden, XP_U16 x, XP_U16 y,
XP_U16 width, XP_U16 height ) XP_U16 width, XP_U16 height )
{ {
if ( !globals->scrollHandle ) { if ( !globals->scrollHandle ) {
HWND hwndSB; HWND hwndSB;
SCROLLINFO sinfo;
int ret;
hwndSB = CreateWindow( TEXT("SCROLLBAR"), // Class name hwndSB = CreateWindow( TEXT("SCROLLBAR"), // Class name
NULL, // Window text NULL, // Window text
// Window style // Window style
SBS_VERT|WS_VISIBLE|WS_CHILD, SBS_VERT|WS_VISIBLE|WS_CHILD,
x, y, width, height, x + SCROLL_SHRINK, y,
width - SCROLL_SHRINK, height + 1,
globals->hWnd, globals->hWnd,
(HMENU)SCROLLBARID,// The control identifier (HMENU)SCROLLBARID,// The control identifier
globals->hInst, // The instance handle globals->hInst, // The instance handle
NULL ); // s'pposed to be NULL NULL ); // s'pposed to be NULL
(void)SetScrollRange( hwndSB, SB_CTL, 0, nHidden - 1, XP_MEMSET( &sinfo, 0, sizeof(sinfo) );
FALSE /* redraw */ ); sinfo.cbSize = sizeof(sinfo);
EnableWindow( hwndSB, FALSE ); /* tray hidden */ sinfo.fMask = SIF_RANGE | SIF_POS | SIF_PAGE;
sinfo.nPos = 0;
sinfo.nMin = 0;
sinfo.nMax = nHidden;
sinfo.nPage = 1;
ret = SetScrollInfo( hwndSB, SB_CTL, &sinfo, TRUE );
EnableWindow( hwndSB, TRUE ); /* tray hidden */
globals->scrollHandle = hwndSB; globals->scrollHandle = hwndSB;
} }
} /* installScroller */
ShowWindow( globals->scrollHandle, SW_SHOW );
} /* showScroller */
static void static void
hideScroller( CEAppGlobals* globals ) hideScroller( CEAppGlobals* globals )
@ -313,7 +327,7 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nCols, CEBoardParms* bparms )
{ {
RECT rc; RECT rc;
XP_U16 width, height; XP_U16 width, height;
XP_U16 trayVScale, leftEdge, scoreWidth, scoreHeight, maxScoreHeight; XP_U16 trayVScale, leftEdge, scoreWidth;
XP_U16 boardHt, boardWidth, visBoardHt, hScale, vScale, nHiddenRows; XP_U16 boardHt, boardWidth, visBoardHt, hScale, vScale, nHiddenRows;
XP_U16 boardHtLimit, trayTop; XP_U16 boardHtLimit, trayTop;
XP_Bool needsScroller; XP_Bool needsScroller;
@ -322,13 +336,7 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nCols, CEBoardParms* bparms )
width = rc.right - rc.left; width = rc.right - rc.left;
height = rc.bottom - rc.top; height = rc.bottom - rc.top;
scoreHeight = CE_SCORE_HEIGHT; boardHt = height - CE_SCORE_HEIGHT - MIN_TRAY_HEIGHT;
maxScoreHeight = height - (nCols * MIN_CELL_HEIGHT);
if ( scoreHeight > maxScoreHeight ) {
scoreHeight = maxScoreHeight;
}
boardHt = height - scoreHeight - MIN_TRAY_HEIGHT;
/* Try to make it fit without scrolling. But if necessary, reduce the /* Try to make it fit without scrolling. But if necessary, reduce the
width for a scrollbar. */ width for a scrollbar. */
@ -349,12 +357,12 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nCols, CEBoardParms* bparms )
visible board height is determined. */ visible board height is determined. */
visBoardHt = vScale * nCols; visBoardHt = vScale * nCols;
nHiddenRows = 0; nHiddenRows = 0;
boardHtLimit = height - scoreHeight - MIN_TRAY_HEIGHT; boardHtLimit = height - CE_SCORE_HEIGHT - MIN_TRAY_HEIGHT;
while ( visBoardHt > boardHtLimit ) { while ( visBoardHt > boardHtLimit ) {
visBoardHt -= vScale; visBoardHt -= vScale;
++nHiddenRows; ++nHiddenRows;
} }
trayTop = scoreHeight + visBoardHt + TRAY_PADDING; trayTop = CE_SCORE_HEIGHT + visBoardHt + TRAY_PADDING;
trayVScale = height - trayTop; trayVScale = height - trayTop;
/* Center the board */ /* Center the board */
@ -376,16 +384,16 @@ figureBoardParms( CEAppGlobals* globals, XP_U16 nCols, CEBoardParms* bparms )
bparms->trayHScale = CE_TRAY_SCALEH; /* unchanged so far... */ bparms->trayHScale = CE_TRAY_SCALEH; /* unchanged so far... */
bparms->leftEdge = leftEdge; bparms->leftEdge = leftEdge;
bparms->scoreWidth = scoreWidth; bparms->scoreWidth = scoreWidth;
bparms->scoreHeight = scoreHeight; bparms->scoreHeight = CE_SCORE_HEIGHT;
#ifdef CEFEATURE_CANSCROLL #ifdef CEFEATURE_CANSCROLL
bparms->needsScroller = needsScroller; bparms->needsScroller = needsScroller;
if ( needsScroller ) { if ( needsScroller ) {
XP_U16 boardRight = leftEdge + (nCols * hScale); XP_U16 boardRight = leftEdge + (nCols * hScale);
installScroller( globals, nHiddenRows, showScroller( globals, nHiddenRows,
boardRight, boardRight,
scoreHeight, CE_SCORE_HEIGHT,
rc.right - boardRight, visBoardHt ); rc.right - boardRight, visBoardHt );
XP_LOGF( "NEEDING SCROLLBAR!!!!" ); XP_LOGF( "NEEDING SCROLLBAR!!!!" );
XP_LOGF( "%d rows hidden", nHiddenRows ); XP_LOGF( "%d rows hidden", nHiddenRows );
@ -412,7 +420,6 @@ cePositionBoard( CEAppGlobals* globals )
board_setTimerLoc( globals->game.board, CE_TIMER_LEFT, board_setTimerLoc( globals->game.board, CE_TIMER_LEFT,
CE_TIMER_TOP, CE_TIMER_WIDTH, CE_TIMER_HEIGHT ); CE_TIMER_TOP, CE_TIMER_WIDTH, CE_TIMER_HEIGHT );
board_setPos( globals->game.board, bparms.leftEdge, board_setPos( globals->game.board, bparms.leftEdge,
bparms.scoreHeight, XP_FALSE ); bparms.scoreHeight, XP_FALSE );
board_setScale( globals->game.board, bparms.boardHScale, bparms.boardVScale ); board_setScale( globals->game.board, bparms.boardHScale, bparms.boardVScale );
@ -513,7 +520,7 @@ ceInitAndStartBoard( CEAppGlobals* globals, XP_Bool newGame, CeGamePrefs* gp )
if ( newGame ) { if ( newGame ) {
XP_U16 newGameID = 0; XP_U16 newGameID = 0;
game_reset( MEMPOOL &globals->game, &globals->gameInfo, game_reset( MEMPOOL &globals->game, &globals->gameInfo, &globals->util,
newGameID, &globals->appPrefs.cp, (TransportSend)NULL, newGameID, &globals->appPrefs.cp, (TransportSend)NULL,
globals ); globals );
@ -601,9 +608,8 @@ ceSavePrefs( CEAppGlobals* globals )
XP_DEBUGF( "ceSavePrefs: prefs file written" ); XP_DEBUGF( "ceSavePrefs: prefs file written" );
} else { } else {
XP_LOGF( "failed to create prefs file" ); logLastError( "failed to create prefs file" );
} }
} /* ceSavePrefs */ } /* ceSavePrefs */
static XP_Bool static XP_Bool
@ -1360,9 +1366,7 @@ makeCommandBar( HWND hwnd, HINSTANCE hInst )
mbi.hwndParent = hwnd; mbi.hwndParent = hwnd;
mbi.nToolBarId = IDM_MENU; mbi.nToolBarId = IDM_MENU;
mbi.hInstRes = hInst; mbi.hInstRes = hInst;
mbi.nBmpId = 0; //mbi.dwFlags = SHCMBF_HIDESIPBUTTON; /* eeh added. Why??? */
mbi.cBmpImages = 0;
mbi.dwFlags = SHCMBF_HIDESIPBUTTON; /* eeh added */
if (!SHCreateMenuBar(&mbi)) { if (!SHCreateMenuBar(&mbi)) {
XP_LOGF( "SHCreateMenuBar failed" ); XP_LOGF( "SHCreateMenuBar failed" );
@ -1444,9 +1448,10 @@ WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
if ( message == WM_CREATE ) { if ( message == WM_CREATE ) {
globals = ((CREATESTRUCT*)lParam)->lpCreateParams; globals = ((CREATESTRUCT*)lParam)->lpCreateParams;
SetWindowLong( hWnd, GWL_USERDATA, (long)globals ); SetWindowLong( hWnd, GWL_USERDATA, (long)globals );
globals->hwndCB = makeCommandBar( hWnd, globals->hInst ); globals->hwndCB = makeCommandBar( hWnd, globals->hInst );
addButtonsToCmdBar( globals ); addButtonsToCmdBar( globals );
globals->sai.cbSize = sizeof(globals->sai);
} else { } else {
globals = (CEAppGlobals*)GetWindowLong( hWnd, GWL_USERDATA ); globals = (CEAppGlobals*)GetWindowLong( hWnd, GWL_USERDATA );
@ -1459,6 +1464,9 @@ WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
case WM_SETTINGCHANGE: case WM_SETTINGCHANGE:
SHHandleWMSettingChange( hWnd, wParam, lParam, &globals->sai ); SHHandleWMSettingChange( hWnd, wParam, lParam, &globals->sai );
cePositionBoard( globals );
board_invalAll( globals->game.board );
draw = XP_TRUE;
break; break;
#ifdef CEFEATURE_CANSCROLL #ifdef CEFEATURE_CANSCROLL