我最近一直在尝试使用C++中的Windows API创建一个窗口类。但是,每当我尝试调用ShowWindow时,该函数将最后一个错误设置为1400 (ERROR_INVALID_WINDOW_HANDLE)。在尝试了一段时间之后,我偶然发现了以下示例:http://blogs.msdn.com/b/oldnewthing/archive/2005/04/22/410773.aspx#comments
即使创建一个新项目(我使用MSVC Express2008)并复制代码(我讨厌这样做),我发现,虽然代码成功地创建了一个窗口,但ShowWindow函数仍然报告错误1400。以下是上述链接中代码的摘录:
int PASCAL
WinMain(HINSTANCE hinst, HINSTANCE, LPSTR, int nShowCmd)
{
g_hinst = hinst;
if (SUCCEEDED(CoInitialize(NULL))) {
InitCommonControls();
RootWindow *prw = RootWindow::Create();
if (prw) {
ShowWindow(prw->GetHWND(), nShowCmd);
int error = GetLastError(); //Line added by me, error gets set to 1400.
MSG msg;
while (GetMessage(&msg, NULL, 0, 0)) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
}
CoUninitialize();
}
return 0;
}(完整代码可在上面的链接中找到)
如果任何人对如何将窗口作为类的成员变量进行处理而不在ShowWindow上收到错误1400有任何想法,我将非常感谢一些帮助。
发布于 2013-03-02 08:18:07
ShowWindow(prw->GetHWND(), nShowCmd);
int error = GetLastError();这不是正确的代码。调用GetLastError()唯一有效的时候是当winapi函数执行失败的时候。如果在它们没有失败的时候使用GetLastError(),那么您将得到一个完全随机的数字。ShowWindow()有一点特别,因为它根本不会产生错误代码,所以使用GetLastError()永远不会正确。
通用模式大致如下:
if (!SomeWinapiFunction(...)) {
int error = GetLastError();
CrashAndBurn(error);
}但是一定要查看MSDN文档,看看什么返回值表示错误,以及GetLastError()是否合适。例如,它通常不在GDI函数上。请确保在代码的其他部分也纠正了这一点。在使用原始api时,正确处理错误是非常重要的。特别要注意RootWindow:: create ()方法没有好的方法来表明创建窗口失败。这一点需要解决。当然,异常是一种非常好的方法。
发布于 2018-08-06 22:14:39
我也有同样的问题。解决方案是将DefWindowProc()从默认移到WndProc()的末尾。
之前:
LRESULT CALLBACK WndProc( HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam )
{
static HBITMAP hBitMap;
static int cxSizeBitMap;
static int cySizeBitMap;
static int cxClient;
static int cyClient;
HDC hdc;
BITMAP bitMap;
PAINTSTRUCT ps;
HDC hMem;
HINSTANCE hInstance ;
switch( message )
{
case WM_CREATE:
hInstance = ((LPCREATESTRUCT) lParam)->hInstance ;
hBitMap = LoadBitmap( hInstance, MAKEINTRESOURCE( IDB_BRICK ) );
GetObject( hBitMap, sizeof(BITMAP), &bitMap );
cxSizeBitMap = bitMap.bmWidth;
cySizeBitMap = bitMap.bmHeight;
break;
case WM_SIZE:
cxClient = LOWORD (lParam) ;
cyClient = HIWORD (lParam) ;
break;
case WM_PAINT:
hdc = BeginPaint( hWnd, &ps );
hMem = CreateCompatibleDC( hdc );
SelectObject( hMem, hBitMap );
for (int y = 0 ; y < cyClient ; y += cySizeBitMap)
for (int x = 0 ; x < cxClient ; x += cxSizeBitMap)
{
BitBlt (hdc, x, y, cxSizeBitMap, cySizeBitMap, hMem, 0, 0, SRCCOPY) ;
}
DeleteDC( hMem );
EndPaint( hWnd, &ps );
break;
case WM_DESTROY:
DeleteObject( hBitMap );
PostQuitMessage( 0 );
break;
default:
// In this cast ShowWindow() will return 1400.
DefWindowProc(hWnd, message, wParam, lParam);
}
return 0;
}之后:
LRESULT CALLBACK WndProc( HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam )
{
static HBITMAP hBitMap;
static int cxSizeBitMap;
static int cySizeBitMap;
static int cxClient;
static int cyClient;
HDC hdc;
BITMAP bitMap;
PAINTSTRUCT ps;
HDC hMem;
HINSTANCE hInstance ;
switch( message )
{
case WM_CREATE:
hInstance = ((LPCREATESTRUCT) lParam)->hInstance ;
hBitMap = LoadBitmap( hInstance, MAKEINTRESOURCE( IDB_BRICK ) );
GetObject( hBitMap, sizeof(BITMAP), &bitMap );
cxSizeBitMap = bitMap.bmWidth;
cySizeBitMap = bitMap.bmHeight;
break;
case WM_SIZE:
cxClient = LOWORD (lParam) ;
cyClient = HIWORD (lParam) ;
break;
case WM_PAINT:
hdc = BeginPaint( hWnd, &ps );
hMem = CreateCompatibleDC( hdc );
// Было SelectObject( hdc, hMem );
SelectObject( hMem, hBitMap );
// Было BitBlt( hdc, 0, 0, cxSize, cySize, hMem, 0, 0, DIB_RGB_COLORS);
for (int y = 0 ; y < cyClient ; y += cySizeBitMap)
for (int x = 0 ; x < cxClient ; x += cxSizeBitMap)
{
BitBlt (hdc, x, y, cxSizeBitMap, cySizeBitMap, hMem, 0, 0, SRCCOPY) ;
}
DeleteDC( hMem );
EndPaint( hWnd, &ps );
break;
case WM_DESTROY:
DeleteObject( hBitMap );
PostQuitMessage( 0 );
break;
}
// In this case ShowWindow() will show the window.
return DefWindowProc(hWnd, message, wParam, lParam);;
}https://stackoverflow.com/questions/15168513
复制相似问题