一个简单的显示问题,关于显示图标的。

yiruirui0507 2011-01-16 10:22:44
#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 ("BitBlt") ;
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_INFORMATION) ;
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, TEXT ("BitBlt Demo"),
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, CW_USEDEFAULT,
CW_USEDEFAULT, CW_USEDEFAULT,
NULL, NULL, hInstance, NULL) ;

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)
{
static int cxClient, cyClient, cxSource, cySource ;
HDC hdcClient, hdcWindow ;
int x, y ;
PAINTSTRUCT ps ;
static int cx,cy;
switch (message)
{
case WM_CREATE:
cxSource = GetSystemMetrics (SM_CXSIZEFRAME) +
GetSystemMetrics (SM_CXSIZE) ;//得到一个标题栏上图标的宽度(象素)+边框

cySource = GetSystemMetrics (SM_CYSIZEFRAME) +
GetSystemMetrics (SM_CYCAPTION) ;//得到标题栏的高度+边框
cx=GetSystemMetrics(SM_CXSCREEN)-29;//这里减去29就刚好使开始位置变成了右上角那个差号的位置
cy=0;
return 0 ;

case WM_SIZE:
cxClient = LOWORD (lParam) ;
cyClient = HIWORD (lParam) ;
return 0 ;

case WM_PAINT:
hdcClient = BeginPaint (hwnd, &ps) ;
hdcWindow = GetWindowDC (hwnd) ;

for (y = 0 ; y < cyClient ; y += cySource)
for (x = 0 ; x < cxClient ; x += cxSource)
{
BitBlt (hdcClient, x, y, cxSource, cySource,
hdcWindow, cx, 0, SRCCOPY) ;
}

ReleaseDC (hwnd, hdcWindow) ;
EndPaint (hwnd, &ps) ;
return 0 ;

case WM_DESTROY:
PostQuitMessage (0) ;
return 0 ;
}
return DefWindowProc (hwnd, message, wParam, lParam) ;
}

目的是利用bitblt函数来复制右上角的那个红色差号图标放置到客户区,不知道什么原因,必须点最大化的时候才能显示出来,而刚开始运行的时候客户区空白。没看出哪里有问题,3Q!
...全文
93 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
yiruirui0507 2011-01-16
  • 打赏
  • 举报
回复
刚洗澡的时候找到问题了,
cx=GetSystemMetrics(SM_CXSCREEN)-29;//这里减去29就刚好使开始位置变成了右上角那个差号的位置
cy=0;
这里的SM_CXSCREEN是整个屏幕的象素宽度,比如我的分辨率为1280*800,则我的这个cx=1251,cy=0
也就是说复制这个矩形区域的像素到客户区
但是当程序运行的时候,并不是最大化显示的,所以1251这个象素区还没任何东西,而最大化的时候,窗体充满了整个屏幕,因此会显示出来差号。
更改:应该获得的是当前窗体的大小(象素)-29才可以,但是当前窗体的像素宽度不知道咋么获取,各位有办法没,我在WM_SIZE中测试如下:
case WM_SIZE:
cxClient = LOWORD (lParam) ;
cyClient = HIWORD (lParam) ;
cx=cxClient-29;
cy=0;
return 0 ;
这样就能显示出来了,但是cxClient人家毕竟是客户区的大小,要想得到真正的窗体宽度,需要客户区大小+左扩展边框+右扩展边框=cwindowx=cxClient+2*GetSystemMetrics (SM_CXSIZEFRAME)这个就是了
然后cx=cwindowx-29;cy=0;如此方能得到正解。
nicklisir 2011-01-16
  • 打赏
  • 举报
回复
invalidateRect/updatewindow更新试试
wltg2001 2011-01-16
  • 打赏
  • 举报
回复
for (y = 0 ; y < cyClient ; y += cySource)
for (x = 0 ; x < cxClient ; x += cxSource)
{
BitBlt (hdcClient, x, y, cxSource, cySource,
hdcWindow, cx, 0, SRCCOPY) ;
}
==========
循环里调用BitBlt啊?一次性调用不好吗?

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧