永发信息网

怎样用window api实现程序全屏显示

答案:4  悬赏:70  手机版
解决时间 2021-03-12 09:33
  • 提问者网友:不爱我么
  • 2021-03-12 03:42
在vs2005平台下,编写一个win32项目,实现一个窗口,让程序运行后就最大化显示,该怎样写代码?(不用mfc)
stone_dongdong, 我想要的效果是程序全屏显示, 指窗口标题栏和系统任务栏都隐藏的那种效果, 不知前辈能否再指点一二?
整个程序只有一个主窗口,并没有对话框资源,是一个类似于HelloWin的程序,所以不能使用对话框编辑器

以下几位的方法我都试过,但都不奏效,或许是我没能理解到位,不知几位前辈能否给一个只用windows api(不用mfc)写的一个可全屏显示的程序
最佳答案
  • 五星知识达人网友:患得患失的劫
  • 2021-03-12 04:04
给你完整的代码吧。这应该是你想要的。

//请用alt+f4关闭该窗口,以下代码可运行于vc6至vc9(vs2008)版本
#include <windows.h>

LRESULT CALLBACK WndProc (HWND, UINT, WPARAM, LPARAM) ;

int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance,
PSTR szCmdLine, int iCmdShow)
{
static TCHAR szAppName[] = TEXT ("HelloWin") ;
HWND hwnd ;
MSG msg ;
WNDCLASS wndclass ;

wndclass.style = CS_HREDRAW | CS_VREDRAW ;
wndclass.lpfnWndProc = WndProc ;
wndclass.cbClsExtra = 0 ;
wndclass.cbWndExtra = 0 ;
wndclass.hInstance = hInstance ;
wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ;
wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ;
wndclass.hbrBackground= (HBRUSH) GetStockObject (WHITE_BRUSH) ;
wndclass.lpszMenuName = NULL ;
wndclass.lpszClassName= szAppName ;

if (!RegisterClass (&wndclass))
{
MessageBox ( NULL, TEXT ("This program requires Windows NT!"),
szAppName, MB_ICONERROR) ;
return 0 ;
}

hwnd = CreateWindow( szAppName, // window class name
TEXT ("Full Screen Display"), // window caption
// WS_OVERLAPPEDWINDOW, // window style
WS_POPUP,
// CW_USEDEFAULT,// initial x position
// CW_USEDEFAULT,// initial y position
// CW_USEDEFAULT,// initial x size
// CW_USEDEFAULT,// initial y size
0,
0,
::GetSystemMetrics(SM_CXSCREEN),
::GetSystemMetrics(SM_CYSCREEN),
NULL, // parent window handle
NULL, // window menu handle
hInstance, // program instance handle
NULL) ; // creation parameters

ShowWindow (hwnd, iCmdShow) ;
UpdateWindow (hwnd) ;

while (GetMessage (&msg, NULL, 0, 0))
{
TranslateMessage (&msg) ;
DispatchMessage (&msg) ;
}
return msg.wParam ;
}

LRESULT CALLBACK WndProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
HDC hdc ;
PAINTSTRUCT ps ;
RECT rect ;

switch (message)
{
case WM_CREATE:
// PlaySound (TEXT ("hellowin.wav"), NULL, SND_FILENAME | SND_ASYNC) ;
return 0 ;
case WM_PAINT:
hdc = BeginPaint (hwnd, &ps) ;
GetClientRect (hwnd, &rect) ;
DrawText (hdc, TEXT ("This window can cover the task item!"), -1, &rect,
DT_SINGLELINE | DT_CENTER | DT_VCENTER) ;
EndPaint (hwnd, &ps) ;
return 0 ;
case WM_DESTROY:
PostQuitMessage (0) ;
return 0 ;
}
return DefWindowProc (hwnd, message, wParam, lParam) ;
}
全部回答
  • 1楼网友:毛毛
  • 2021-03-12 06:24
这种效果实际上应该是窗口处于非最大化状态 即 ShowWindow(hWnd, SW_SHOWNORMAL); 由 GetSystemMetrics(SM_CXSCREEN); GetSystemMetrics(SM_CYSCREEN); 获取屏幕大小 然后调整窗口大小和位置 使GetClientRect(hWnd, lpRect); 客户区左上角位于屏幕(0,0)的位置 客户区宽度为GetSystemMetrics(SM_CXSCREEN) 客户区高度为GetSystemMetrics(SM_CYSCREEN) 通过 ClientToScreen(hWnd,lpPoint); 计算调整窗口大小和位置 就可实现楼主要求的效果 API代码: int x = GetSystemMetrics(SM_CXSCREEN); int y = GetSystemMetrics(SM_CYSCREEN); int dx, dy; ShowWindow(hwnd, SW_SHOWNORMAL); RECT rect; RECT wrect; POINT point; ::GetClientRect(hwnd, &rect); ::GetWindowRect(hwnd, &wrect); point.x = 0; point.y = 0; ::ClientToScreen(hwnd, &point); wrect.right += x - rect.right; wrect.bottom += y - rect.bottom; ::MoveWindow(hwnd, wrect.left - point.x, wrect.top - point.y, wrect.right, wrect.bottom, true); 这样垂直方向已到最大值无法再大 只有再处理 WM_GETMINMAXINFO 消息了
  • 2楼网友:爱难随人意
  • 2021-03-12 05:22
int cx = GetSystemMetrics( SM_CXSCREEN); int cy = GetSystemMetrics( SM_CYSCREEN); MoveWindow( 0,0,cx,cy); 不用MFC的话,CreateWindow的时候,相应修改窗口的属性。看看MSDN说明。 如果是对话框,SetWindowLong一样可以修改。
  • 3楼网友:woshuo
  • 2021-03-12 04:29
你好! int cx = GetSystemMetrics( SM_CXSCREEN); int cy = GetSystemMetrics( SM_CYSCREEN); MoveWindow( 0,0,cx,cy); 不用MFC的话,CreateWindow的时候,相应修改窗口的属性。看看MSDN说明。 如果是对话框,SetWindowLong一样可以修改。 如有疑问,请追问。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯