2010-07-18 6 views
16

Как отключить изменение размера, перетащив края окон?Disable Window Resizing Win32

Вот мое окно код создания

bool CreateGLWindow(char* title, int width, int height) 
{ 
GLuint  PixelFormat;   // Holds The Results After Searching For A Match 
WNDCLASS wc;      // Windows Class Structure 
DWORD  dwExStyle;    // Window Extended Style 
DWORD  dwStyle;    // Window Style 
RECT  WindowRect;    // Grabs Rectangle Upper Left/Lower Right Values 
WindowRect.left=(long)0;   // Set Left Value To 0 
WindowRect.right=(long)width;  // Set Right Value To Requested Width 
WindowRect.top=(long)0;    // Set Top Value To 0 
WindowRect.bottom=(long)height;  // Set Bottom Value To Requested Height 

hInstance   = GetModuleHandle(NULL);    // Grab An Instance For Our Window 
wc.style   = CS_HREDRAW | CS_VREDRAW | CS_OWNDC; // Redraw On Size, And Own DC For Window. 
wc.lpfnWndProc  = (WNDPROC) WndProc;     // WndProc Handles Messages 
wc.cbClsExtra  = 0;         // No Extra Window Data 
wc.cbWndExtra  = 0;         // No Extra Window Data 
wc.hInstance  = hInstance;       // Set The Instance 
wc.hIcon   = LoadIcon(NULL, IDI_WINLOGO);   // Load The Default Icon 
wc.hCursor   = LoadCursor(NULL, IDC_ARROW);   // Load The Arrow Pointer 
wc.hbrBackground = NULL;         // No Background Required For GL 
wc.lpszMenuName  = NULL;         // We Don't Want A Menu 
wc.lpszClassName = "OpenGL";        // Set The Class Name 

if (!RegisterClass(&wc))         // Attempt To Register The Window Class 
{ 
    MessageBox(NULL,"Failed To Register The Window Class.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;           // Return FALSE 
} 

dwExStyle=WS_EX_APPWINDOW | WS_EX_WINDOWEDGE;   // Window Extended Style 
dwStyle=WS_OVERLAPPEDWINDOW;       // Windows Style 

AdjustWindowRectEx(&WindowRect, dwStyle, FALSE, dwExStyle);  // Adjust Window To True Requested Size 

// Create The Window 
if (!(hWnd=CreateWindowEx( dwExStyle,       // Extended Style For The Window 
          "OpenGL",       // Class Name 
          title,        // Window Title 
          dwStyle |       // Defined Window Style 
          WS_CLIPSIBLINGS |     // Required Window Style 
          WS_CLIPCHILDREN,     // Required Window Style 
          0, 0,        // Window Position 
          WindowRect.right-WindowRect.left, // Calculate Window Width 
          WindowRect.bottom-WindowRect.top, // Calculate Window Height 
          NULL,        // No Parent Window 
          NULL,        // No Menu 
          hInstance,       // Instance 
          NULL)))        // Dont Pass Anything To WM_CREATE 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Window Creation Error.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

static PIXELFORMATDESCRIPTOR pfd=    // pfd Tells Windows How We Want Things To Be 
{ 
    sizeof(PIXELFORMATDESCRIPTOR),    // Size Of This Pixel Format Descriptor 
    1,           // Version Number 
    PFD_DRAW_TO_WINDOW |      // Format Must Support Window 
    PFD_SUPPORT_OPENGL |      // Format Must Support OpenGL 
    PFD_DOUBLEBUFFER,       // Must Support Double Buffering 
    PFD_TYPE_RGBA,        // Request An RGBA Format 
    24,          // Select Our Color Depth 
    0, 0, 0, 0, 0, 0,       // Color Bits Ignored 
    0,           // No Alpha Buffer 
    0,           // Shift Bit Ignored 
    0,           // No Accumulation Buffer 
    0, 0, 0, 0,         // Accumulation Bits Ignored 
    24,           // 24Bit Z-Buffer (Depth Buffer) 
    0,           // No Stencil Buffer 
    0,           // No Auxiliary Buffer 
    PFD_MAIN_PLANE,        // Main Drawing Layer 
    0,           // Reserved 
    0, 0, 0          // Layer Masks Ignored 
}; 

if (!(hDC=GetDC(hWnd)))       // Did We Get A Device Context? 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Can't Create A GL Device Context.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

if (!(PixelFormat=ChoosePixelFormat(hDC,&pfd))) // Did Windows Find A Matching Pixel Format? 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Can't Find A Suitable PixelFormat.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

if(!SetPixelFormat(hDC,PixelFormat,&pfd))  // Are We Able To Set The Pixel Format? 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Can't Set The PixelFormat.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

if (!(hRC=wglCreateContext(hDC)))    // Are We Able To Get A Rendering Context? 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Can't Create A GL Rendering Context.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

if(!wglMakeCurrent(hDC,hRC))     // Try To Activate The Rendering Context 
{ 
    KillGLWindow();        // Reset The Display 
    MessageBox(NULL,"Can't Activate The GL Rendering Context.","ERROR",MB_OK|MB_ICONEXCLAMATION); 
    return false;        // Return FALSE 
} 

ShowWindow(hWnd,SW_SHOW);      // Show The Window 
SetForegroundWindow(hWnd);      // Slightly Higher Priority 
SetFocus(hWnd);         // Sets Keyboard Focus To The Window 
reshape(width, height);     // Set Up Our Perspective GL Screen 

init(); 

return true;         // Success 
} 

ответ

46

WS_OVERLAPPEDWINDOW стиля включает в себя WS_THICKFRAME стиля, который, я думаю, это responslible для создания вашего окна изменяемого размера.

Рассмотрим что-то вроде

dwStyle=(WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX); 
+0

Однако, 'AdjustWindowRectEx', кажется, не правильно работать, если' WS_THICKFRAME' не является частью стиля. –

+1

Не знаете, почему этот знак отмечен как ответ, поскольку он не работает для меня (Windows 10). Другой ответ работал как прелесть, но со следующей строкой кода: ':: SetWindowLong (hWnd, GWL_STYLE, GetWindowLong (hWnd, GWL_STYLE) & ~ WS_SIZEBOX);' – YePhIcK

+1

@YePhIcK хорошо, я дал этот ответ почти 7 лет назад, пробовал его на NT 5.1 - 6.1, где он работал хорошо под вопросом, как вопрос был задан ОП. Никогда не пробовал это на более новых версиях, и с тех пор я не работаю в Windows, поэтому есть шанс, что некоторые биты изменились между тем. – thatsdisgusting

4

изменить стиль окна от WS_OVERLAPPEDWINDOW, скажем, WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX. Другими словами, он перекрывает окно за вычетом толщины (изменчивая граница) и maxbox.

0

Обработайте сообщение WM_SIZING и отмените все попытки изменить прямоугольник окна.

-2

Это работает для меня, но вместо того, чтобы использовать

WS_OVERLAPPEDWINDOW & ~WS_THICKFRAME 

использовать только

WS_OVERLAPPEDWINDOW 
+0

Это не отключает изменение размера. Чтобы отключить изменение размера, следуйте ответам @thatsdisgusting. Используйте 'WS_OPERLAPPEDWINDOW^WS_THICKFRAME'. –

17

Вы можете использовать WS_OVERLAPPEDWINDOW^WS_THICKFRAME

XOR будет держать все в WS_OVERLAPPEDWINDOW для WS_THICKFRAME

кроме
+0

Это не мешает максимизации. –

3

Если вы используете WS_OVERLAPPED | WS_MINIMIZEBOX | WS_SYSMENU, это di sable и максимизация и изменение размера.

11

Вы можете попробовать что-то вроде этого:

::SetWindowLong(hWnd, GWL_STYLE, GetWindowLong(hWnd, GWL_STYLE)&~WS_SIZEBOX); 

Это только отключить изменение размера путем перетаскивания края окна. Кстати, WS_SIZEBOX такая же, как WS_THICKFRAME из

#define WS_SIZEBOX WS_THICKFRAME