300 lines
6.9 KiB
C++
300 lines
6.9 KiB
C++
|
/****************************************************************************
|
||
|
|
||
|
Copyright (c) Microsoft Corporation 1997
|
||
|
All rights reserved
|
||
|
|
||
|
***************************************************************************/
|
||
|
|
||
|
#include "pch.h"
|
||
|
#include "utils.h"
|
||
|
|
||
|
DEFINE_MODULE("RIPREP")
|
||
|
|
||
|
#define SMALL_BUFFER_SIZE 1024
|
||
|
|
||
|
//
|
||
|
// Centers a dialog.
|
||
|
//
|
||
|
void
|
||
|
CenterDialog(
|
||
|
HWND hwndDlg )
|
||
|
{
|
||
|
RECT rc;
|
||
|
RECT rcScreen;
|
||
|
int x, y;
|
||
|
int cxDlg, cyDlg;
|
||
|
int cxScreen;
|
||
|
int cyScreen;
|
||
|
|
||
|
SystemParametersInfo( SPI_GETWORKAREA, 0, &rcScreen, 0 );
|
||
|
|
||
|
cxScreen = rcScreen.right - rcScreen.left;
|
||
|
cyScreen = rcScreen.bottom - rcScreen.top;
|
||
|
|
||
|
GetWindowRect( hwndDlg, &rc );
|
||
|
|
||
|
cxDlg = rc.right - rc.left;
|
||
|
cyDlg = rc.bottom - rc.top;
|
||
|
|
||
|
y = rcScreen.top + ( ( cyScreen - cyDlg ) / 2 );
|
||
|
x = rcScreen.left + ( ( cxScreen - cxDlg ) / 2 );
|
||
|
|
||
|
SetWindowPos( hwndDlg, NULL, x, y, 0, 0, SWP_NOSIZE | SWP_NOACTIVATE );
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Eats all mouse and keyboard messages.
|
||
|
//
|
||
|
void
|
||
|
ClearMessageQueue( void )
|
||
|
{
|
||
|
MSG msg;
|
||
|
|
||
|
while ( PeekMessage( (LPMSG)&msg, NULL, WM_KEYFIRST, WM_MOUSELAST,
|
||
|
PM_NOYIELD | PM_REMOVE ) );
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Create a message box from resource strings.
|
||
|
//
|
||
|
INT
|
||
|
MessageBoxFromStrings(
|
||
|
HWND hParent,
|
||
|
UINT idsCaption,
|
||
|
UINT idsText,
|
||
|
UINT uType )
|
||
|
{
|
||
|
TCHAR szText[ SMALL_BUFFER_SIZE ];
|
||
|
TCHAR szCaption[ SMALL_BUFFER_SIZE ];
|
||
|
DWORD dw;
|
||
|
|
||
|
dw = LoadString( g_hinstance, idsCaption, szCaption, ARRAYSIZE( szCaption ));
|
||
|
Assert( dw );
|
||
|
dw = LoadString( g_hinstance, idsText, szText, ARRAYSIZE( szText ));
|
||
|
Assert( dw );
|
||
|
|
||
|
return MessageBox( hParent, szText, szCaption, uType );
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Creates a error message box
|
||
|
//
|
||
|
INT
|
||
|
MessageBoxFromError(
|
||
|
HWND hParent,
|
||
|
LPTSTR pszTitle,
|
||
|
DWORD dwErr,
|
||
|
LPTSTR pszAdditionalText,
|
||
|
UINT uType )
|
||
|
{
|
||
|
WCHAR szText[ SMALL_BUFFER_SIZE ];
|
||
|
LPTSTR lpMsgBuf;
|
||
|
LPTSTR lpMsgBuf2;
|
||
|
int retval;
|
||
|
|
||
|
if ( dwErr == ERROR_SUCCESS ) {
|
||
|
AssertMsg( dwErr, "Why was MessageBoxFromError() called when the dwErr == ERROR_SUCCES?" );
|
||
|
return IDOK;
|
||
|
}
|
||
|
|
||
|
if ( !pszTitle ) {
|
||
|
DWORD dw;
|
||
|
dw = LoadString( g_hinstance, IDS_ERROR, szText, ARRAYSIZE( szText ));
|
||
|
Assert( dw );
|
||
|
pszTitle = szText;
|
||
|
}
|
||
|
|
||
|
if (FormatMessage(
|
||
|
FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
|
||
|
NULL,
|
||
|
dwErr,
|
||
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
|
||
|
(LPTSTR) &lpMsgBuf2,
|
||
|
0,
|
||
|
NULL )) {
|
||
|
|
||
|
|
||
|
//
|
||
|
// If additional text was given, allocate a buffer large enough for both
|
||
|
// strings. If the allocation fails, just show the error text.
|
||
|
//
|
||
|
|
||
|
if ( pszAdditionalText != NULL ) {
|
||
|
DWORD len = (wcslen(lpMsgBuf2) + wcslen(pszAdditionalText) + 1) * sizeof(WCHAR);
|
||
|
lpMsgBuf = (LPTSTR)LocalAlloc( LPTR, len );
|
||
|
if ( lpMsgBuf != NULL ) {
|
||
|
wcscpy( lpMsgBuf, lpMsgBuf2 );
|
||
|
wcscat( lpMsgBuf, pszAdditionalText );
|
||
|
} else {
|
||
|
lpMsgBuf = lpMsgBuf2;
|
||
|
}
|
||
|
} else {
|
||
|
lpMsgBuf = lpMsgBuf2;
|
||
|
}
|
||
|
|
||
|
retval = MessageBox( hParent, lpMsgBuf, pszTitle, uType | MB_TASKMODAL | MB_ICONERROR );
|
||
|
|
||
|
SetFocus( hParent );
|
||
|
|
||
|
if (lpMsgBuf != NULL) {
|
||
|
LocalFree( lpMsgBuf );
|
||
|
}
|
||
|
|
||
|
if ( lpMsgBuf2 != lpMsgBuf ) {
|
||
|
LocalFree( lpMsgBuf2 );
|
||
|
}
|
||
|
|
||
|
return retval;
|
||
|
|
||
|
} else {
|
||
|
Assert(FALSE);
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
VOID
|
||
|
SetDialogFont(
|
||
|
IN HWND hdlg,
|
||
|
IN UINT ControlId,
|
||
|
IN MyDlgFont WhichFont
|
||
|
)
|
||
|
{
|
||
|
static HFONT BigBoldFont = NULL;
|
||
|
static HFONT BoldFont = NULL;
|
||
|
static HFONT NormalFont = NULL;
|
||
|
HFONT Font;
|
||
|
LOGFONT LogFont;
|
||
|
WCHAR FontSizeString[24];
|
||
|
int FontSize;
|
||
|
HDC hdc;
|
||
|
|
||
|
switch(WhichFont) {
|
||
|
|
||
|
case DlgFontTitle:
|
||
|
|
||
|
if(!BigBoldFont) {
|
||
|
|
||
|
if ( Font =
|
||
|
(HFONT) SendDlgItemMessage( hdlg, ControlId, WM_GETFONT, 0, 0) )
|
||
|
{
|
||
|
if ( GetObject( Font, sizeof(LOGFONT), &LogFont) )
|
||
|
{
|
||
|
DWORD dw = LoadString( g_hinstance,
|
||
|
IDS_LARGEFONTNAME,
|
||
|
LogFont.lfFaceName,
|
||
|
LF_FACESIZE);
|
||
|
Assert( dw );
|
||
|
|
||
|
// LogFont.lfWeight = 700;
|
||
|
FontSize = 14;
|
||
|
|
||
|
if ( hdc = GetDC(hdlg) )
|
||
|
{
|
||
|
LogFont.lfHeight =
|
||
|
0 - (GetDeviceCaps(hdc,LOGPIXELSY) * FontSize / 72);
|
||
|
|
||
|
BigBoldFont = CreateFontIndirect(&LogFont);
|
||
|
|
||
|
ReleaseDC(hdlg,hdc);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
Font = BigBoldFont;
|
||
|
break;
|
||
|
|
||
|
case DlgFontBold:
|
||
|
|
||
|
if ( !BoldFont )
|
||
|
{
|
||
|
if ( Font =
|
||
|
(HFONT) SendDlgItemMessage( hdlg, ControlId, WM_GETFONT, 0, 0 ))
|
||
|
{
|
||
|
if ( GetObject( Font, sizeof(LOGFONT), &LogFont ) )
|
||
|
{
|
||
|
|
||
|
LogFont.lfWeight = FW_BOLD;
|
||
|
|
||
|
if ( hdc = GetDC( hdlg ) )
|
||
|
{
|
||
|
BoldFont = CreateFontIndirect( &LogFont );
|
||
|
ReleaseDC( hdlg, hdc );
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
Font = BoldFont;
|
||
|
break;
|
||
|
|
||
|
default:
|
||
|
//
|
||
|
// Nothing to do here.
|
||
|
//
|
||
|
Font = NULL;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
if( Font )
|
||
|
{
|
||
|
SendDlgItemMessage( hdlg, ControlId, WM_SETFONT, (WPARAM) Font, 0 );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
//
|
||
|
// Adjusts and draws a bitmap transparently in the RECT prc.
|
||
|
//
|
||
|
void
|
||
|
DrawBitmap(
|
||
|
HANDLE hBitmap,
|
||
|
LPDRAWITEMSTRUCT lpdis,
|
||
|
LPRECT prc )
|
||
|
{
|
||
|
TraceFunc( "DrawBitmap( ... )\n" );
|
||
|
|
||
|
BITMAP bm;
|
||
|
HDC hDCBitmap;
|
||
|
int dy;
|
||
|
|
||
|
if (GetObject( hBitmap, sizeof(bm), &bm ) &&
|
||
|
(hDCBitmap = CreateCompatibleDC( NULL ))) {
|
||
|
|
||
|
SelectObject( hDCBitmap, hBitmap );
|
||
|
|
||
|
// center the image
|
||
|
dy = 4 + prc->bottom - bm.bmHeight;
|
||
|
|
||
|
StretchBlt( lpdis->hDC, prc->left, prc->top + dy, prc->right, prc->bottom,
|
||
|
hDCBitmap, 0, 0, bm.bmWidth, bm.bmHeight, SRCAND );
|
||
|
|
||
|
DeleteDC( hDCBitmap );
|
||
|
|
||
|
}
|
||
|
|
||
|
TraceFuncExit( );
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Verifies that the user wanted to cancel setup.
|
||
|
//
|
||
|
BOOL
|
||
|
VerifyCancel( HWND hParent )
|
||
|
{
|
||
|
TraceFunc( "VerifyCancel( ... )\n" );
|
||
|
|
||
|
INT iReturn;
|
||
|
BOOL fAbort = FALSE;
|
||
|
|
||
|
iReturn = MessageBoxFromStrings( hParent,
|
||
|
IDS_CANCELCAPTION,
|
||
|
IDS_CANCELTEXT,
|
||
|
MB_YESNO | MB_ICONQUESTION );
|
||
|
if ( iReturn == IDYES ) {
|
||
|
fAbort = TRUE;
|
||
|
}
|
||
|
|
||
|
SetWindowLongPtr( hParent, DWLP_MSGRESULT, ( fAbort ? 0 : -1 ));
|
||
|
|
||
|
RETURN(!fAbort);
|
||
|
}
|