gpt4 book ai didi

c++ - 如何将位图设置为CHILD窗口的背景(WIN32)

转载 作者:搜寻专家 更新时间:2023-10-31 01:51:44 25 4
gpt4 key购买 nike

首先这不是MFC。这是我一直在处理的 GUI 的裁剪版本:

enter image description here

如您所见,选项卡控件上方有一个位图图像(它使用默认窗口的句柄),我将其称为“蓝色位图”我没有遇到任何问题,它运行良好。我遇到的问题是设置另一个位图(从磁盘上的位图文件)到子窗口(更具体地说是选项卡控件子窗口)的背景,替换灰色。以下是我为尝试所做的一些事情,并将位图设置为子窗口(选项卡)的背景。

1) 我使用了与将蓝色位图分配给窗口相同的方法,首先使用 LoadImage 导入位图,如下所示:

index->hbmBitmapBanner = (HBITMAP)LoadImage(index->hInstance,L"Images\\horizontal.bmp",IMAGE_BITMAP,0,0,LR_LOADFROMFILE);

然后在 WM_PAINT 消息中:

    case WM_PAINT:
{
PAINTSTRUCT ps1;
if (BeginPaint(WINDOWHANDLE,&ps1))
{
HDC hdcBanner = CreateCompatibleDC(ps1.hdc);
HBITMAP hbmOldHorizontal = (HBITMAP)SelectObject(hdcBanner,index->hbmBitmapBanner); // banner
BitBlt(ps1.hdc,0,0,516,101,hdcBanner,5,0,SRCCOPY);
SelectObject(hdcBanner,hbmOldHorizontal);
DeleteDC(hdcBanner);
EndPaint(WINDOWHANDLE,&ps1);
}
break;
}

该代码成功地将蓝色位图设置到窗口,但没有成功地将另一个位图设置到窗口中(蓝色位图的变量被替换,大小和方向当然也发生了变化)。它根本不在屏幕上显示位图,窗口保持不变,但没有功能失败。 另外,当我交换文件位置时,它将位图加载到蓝色位图所在的位置,因此加载功能绝对没有失败。

2) 使用上面的代码,我尝试将BeginPaint的第一个参数更改为选项卡控件框的窗口句柄,这再次证明没有用,窗口保持不变。我还尝试将 BeginPaint 的第一个参数更改为显示在信息选项卡上的子窗口,这导致子窗口(这是一个组框)消失,但窗口上仍然没有出现位图。

3) 作为最后的手段,我愚蠢地尝试在子窗口上使用这个函数

SetClassLongPtr(tab->hTabIndex[0],GCLP_HBRBACKGROUND,(DWORD)GetStockObject(BLACK_BRUSH));

当然,它没有用


如果有用的话,下面是我在窗口中创建制表符的方式:

TCITEM tie = {0};     
tab->hTab = CreateWindowEx(0,WC_TABCONTROL,L"",WS_CHILD | WS_VISIBLE,0,101,600,400,
WINDOWHANDLE,NULL,(HINSTANCE)GetWindowLong(WINDOWHANDLE,GWLP_HINSTANCE),NULL
);

是主要的选项卡控件,然后插入各个选项卡(即信息选项卡)

    TCHAR pszTab1 [] = L"Information";  // tab1's text 
tie.pszText = pszTab1; // the tab's text/caption
TabCtrl_InsertItem(tab->hTab, 0, &tie); // insert the tab

附加信息:除此之外,选项卡控件和窗口正在完美工作/交互。我只针对一个选项卡测试/尝试这样做,因为我知道如果它在一个选项卡上有效,那么它会在所有选项卡上有效,从而节省时间。

我有 Charles Petzold 在我旁边编写的 Programming For Windows Fifth Edition 作为引用,其中有一个相当大的部分是关于位图的,但他没有讨论将位图加载到子窗口,他最接近的在菜单中使用位图,这与窗口完全不同。

最佳答案

我认为这里的问题是 Windows 公共(public)控件不通过主线程的窗口过程而是通过它们自己的(系统定义的)窗口过程与您的应用程序交互。

因此,例如,当您的选项卡窗口重绘自身时,它不会响应 WM_PAINT 消息到达您的代码中定义的窗口过程。您应该能够通过检查传递给窗口过程的消息的窗口句柄(例如 WM_PAINT)来自行验证情况是否如此。

如果您希望“利用”公共(public)控件的默认行为,您必须对其进行“子类化”(参见 here),但根据我的经验,尝试更改重绘行为通常是有问题的。

在选项卡控件的情况下,最好的做法是创建一个大小与选项卡控件的客户区大小相符的子窗口数组,并安排在任何时候显示的子窗口对应于选定的选项卡。

如果您使用的是 C++,您可以考虑创建一个基类来包装处理背景(位图)绘制的这些窗口。然后您可以派生一系列包装器来处理每个单独的选项卡。我过去就使用过这种方法,而且效果很好。

记住选项卡控件的选项卡不会扩展到整个控件的工作区,而只是选项卡本身可能会有所帮助。我不记得细节,但我认为它们是由控件在内部处理的,以任何方式操纵它们都是相当棘手的,即使当控件被子类化时也是如此——这可能是错误的。

希望对您有所帮助。

干杯,伊恩。

关于c++ - 如何将位图设置为CHILD窗口的背景(WIN32),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13560854/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com