--- np2/win9x/dialog/d_about.cpp 2003/10/16 17:58:58 1.1.1.1 +++ np2/win9x/dialog/d_about.cpp 2007/10/26 14:38:34 1.14 @@ -1,86 +1,112 @@ #include "compiler.h" #include "resource.h" #include "np2.h" +#include "oemtext.h" +#include "np2class.h" #include "dialog.h" #include "dialogs.h" -#include "np2info.h" +#include "np2ver.h" #include "pccore.h" +#include "np2info.h" -static RECT aboutrct; -static const char np2infostr[] = \ - "CPU: !CPU !CLOCK\r\n" \ - "MEM: !MEM1\r\n" \ - "GDC: !GDC\r\n" \ - "TEXT: !TEXT\r\n" \ - "GRPH: !GRPH\r\n" \ - "SOUND: !EXSND\r\n" \ - "\r\n" \ - "BIOS: !BIOS\r\n" \ - "RHYTHM: !RHYTHM\r\n" \ - "\r\n" \ - "SCREEN: !DISP"; - - -// ---- - -static void about_init(HWND hWnd) { - - char work[128]; - - strcpy(work, "Neko Project II "); - strcat(work, np2version); -#ifdef NEW286 - strcat(work, "+"); +static SIZE s_szAbout; + +static const OEMCHAR str_np2title[] = OEMTEXT(PROJECTNAME) \ + OEMTEXT(PROJECTSUBNAME) \ + OEMTEXT(" "); +static const OEMCHAR np2infostr[] = OEMTEXT("CPU: %CPU% %CLOCK%\nMEM: %MEM1%\nGDC: %GDC%\n %GDC2%\nTEXT: %TEXT%\nGRPH: %GRPH%\nSOUND: %EXSND%\n\nBIOS: %BIOS%\nRHYTHM: %RHYTHM%\n\nSCREEN: %DISP%"); + + +static void onInitDialog(HWND hWnd) +{ + OEMCHAR szWork[128]; + RECT rect; + RECT rectMore; + RECT rectInfo; + int nHeight; + POINT pt; +#if defined(OSLANG_UTF8) + TCHAR szWork2[128]; +#endif // defined(OSLANG_UTF8) + + milstr_ncpy(szWork, str_np2title, NELEMENTS(szWork)); + milstr_ncat(szWork, np2version, NELEMENTS(szWork)); +#if defined(NP2VER_WIN9X) + milstr_ncat(szWork, NP2VER_WIN9X, NELEMENTS(szWork)); +#endif +#if defined(OSLANG_UTF8) + oemtotchar(szWork2, NELEMENTS(szWork2), szWork, -1); + SetDlgItemText(hWnd, IDC_NP2VER, szWork2); +#else + SetDlgItemText(hWnd, IDC_NP2VER, szWork); #endif - SetDlgItemText(hWnd, IDC_NP2VER, work); - GetWindowRect(hWnd, &aboutrct); - MoveWindow(hWnd, aboutrct.left, aboutrct.top, - aboutrct.right - aboutrct.left, 84, TRUE); - SetFocus(GetDlgItem(hWnd, IDOK)); -} -static void about_more(HWND hWnd) { + GetWindowRect(hWnd, &rect); + s_szAbout.cx = rect.right - rect.left; + s_szAbout.cy = rect.bottom - rect.top; + + if ((dlgs_getitemrect(hWnd, IDC_MORE, &rectMore)) && + (dlgs_getitemrect(hWnd, IDC_NP2INFO, &rectInfo))) + { + nHeight = s_szAbout.cy - (rectInfo.bottom - rectMore.bottom); + GetClientRect(GetParent(hWnd), &rect); + pt.x = (rect.right - rect.left - s_szAbout.cx) / 2; + pt.y = (rect.bottom - rect.top - s_szAbout.cy) / 2; + ClientToScreen(GetParent(hWnd), &pt); + np2class_move(hWnd, pt.x, pt.y, s_szAbout.cx, nHeight); + } - char infostr[1024]; + SetFocus(GetDlgItem(hWnd, IDOK)); +} - np2info(infostr, np2infostr, sizeof(infostr)); - SetDlgItemText(hWnd, IDC_NP2INFO, infostr); +static void onMore(HWND hWnd) +{ + OEMCHAR szInfo[1024]; + RECT rect; +#if defined(OSLANG_UTF8) + TCHAR szInfo2[1024]; +#endif // defined(OSLANG_UTF8) + + np2info(szInfo, np2infostr, NELEMENTS(szInfo), NULL); +#if defined(OSLANG_UTF8) + oemtotchar(szInfo2, NELEMENTS(szInfo2), szInfo, -1); + SetDlgItemText(hWnd, IDC_NP2INFO, szInfo2); +#else + SetDlgItemText(hWnd, IDC_NP2INFO, szInfo); +#endif EnableWindow(GetDlgItem(hWnd, IDC_MORE), FALSE); - MoveWindow(hWnd, aboutrct.left, aboutrct.top, - aboutrct.right - aboutrct.left, - aboutrct.bottom - aboutrct.top, TRUE); + GetWindowRect(hWnd, &rect); + np2class_move(hWnd, rect.left, rect.top, s_szAbout.cx, s_szAbout.cy); SetFocus(GetDlgItem(hWnd, IDOK)); } -LRESULT CALLBACK AboutDialogProc(HWND hWnd, UINT msg, WPARAM wp, LPARAM lp) { - - switch (msg) { +LRESULT CALLBACK AboutDialogProc(HWND hWnd, UINT uMsg, + WPARAM wParam, LPARAM lParam) +{ + switch(uMsg) + { case WM_INITDIALOG: - ShowWindow(GetDlgItem(hWnd, IDC_EXTICON), SW_HIDE); - about_init(hWnd); - return(FALSE); + onInitDialog(hWnd); + break; case WM_COMMAND: - switch (LOWORD(wp)) { + switch (LOWORD(wParam)) + { case IDOK: EndDialog(hWnd, IDOK); - break; + return TRUE; + case IDC_MORE: - about_more(hWnd); + onMore(hWnd); break; - default: - return(FALSE); } break; case WM_CLOSE: PostMessage(hWnd, WM_COMMAND, IDOK, 0); break; - - default: - return(FALSE); } - return(TRUE); + return FALSE; }