2012-08-05 114 views
1

当我在下面的代码使用SetBkMode(hdc, TRANSPARENT);,我当我调整主窗口下面的效果(因此当孩子收到WM_PAINT消息):SetBkMode(HDC,透明)不起作用

enter image description here

问题是:当我调整主窗口的大小时,“Find:”的旧区域会被擦除,我猜。但它仍然存在。

如果我不使用SetBkMode(hdc, TRANSPARENT);,我没有这个问题。它看起来像:

enter image description here

,即它具有白色背景。此外,如果我使用SetBkMode(hdc, TRANSPARENT);,它看起来像上面一样,然后再调整主窗口的大小。所以我不认为SetBkMode(hdc, TRANSPARENT);在这里工作。

hwnd是一个风格为SS_BITMAP风格的静态小孩。

你知道为什么会出现这个问题吗?

switch (message) { 
    case WM_PAINT: 
     PAINTSTRUCT ps; 
     HDC hdc = BeginPaint(hwnd, &ps); 

     SelectObject(hdc, gDefaultGuiFont); 
     SetBkMode(hdc, TRANSPARENT); 

     RECT rc; 
     GetClientRect(hwnd, &rc); 
     DrawText(hdc, _TR("Find:"), -1, &rc, DT_SINGLELINE | DT_CENTER | DT_VCENTER); 

     EndPaint(hwnd, &ps); 

     return 0; 

    ............. 
} 
+0

问题是什么?你画“查找”并得到象形文字? – Maximus 2012-08-05 08:14:18

+0

不,我上传了一张新图片,使问题变得清晰。 – user565739 2012-08-05 08:16:27

+0

看起来像这是工具栏部分。以为,它不需要调整大小? – Maximus 2012-08-05 08:26:10

回答

0

尝试使用“固定”矩形。例如

RECT rc; 
    GetClientRect(hwnd, &rc); 
    rc.left += ...; rc.top += ...; // shift up-left point 
    DrawText(hdc, _TR("Find:"), -1, &rc, DT_SINGLELINE | DT_LEFT | DT_TOP); 

的想法是你在错误的位置(一次),并在合适的位置(两次)绘制文本而backgound更新一次。不能说部分代码更多。

0

问题是,Windows并未更新静态控件背后的控件(时间),因此您现在负责它的内容。所以你想使用父母提供的背景。好只问父画为您在子窗口:

RECT rc; 
GetClientRectRelative(m_hWnd, GetParent(m_hWnd), &rc); 
SetWindowOrgEx(m_mdc, rc.left, rc.top, NULL); 
SendMessage(GetParent(m_hWnd), WM_PAINT, (WPARAM)(HDC)m_mdc); 
SetWindowOrgEx(m_mdc, 0, 0, NULL); 

在这

bool GetClientRectRelative(HWND hWnd, HWND hWndRelativeTo, RECT *pRect) 
{ 
    RECT rcWnd, rcRelativeTo; 
    if (!GetClientRect(hWnd, &rcWnd) || 
      !ClientToScreen(hWnd, (POINT*)&rcWnd) || 
      !ClientToScreen(hWnd, (POINT*)&rcWnd + 1) || 
      !GetClientRect(hWndRelativeTo, &rcRelativeTo) || 
      !ClientToScreen(hWndRelativeTo, (POINT*)&rcRelativeTo) || 
      !ClientToScreen(hWndRelativeTo, (POINT*)&rcRelativeTo + 1)) 
     return false; 

    pRect->top = rcWnd.top - rcRelativeTo.top; 
    pRect->left = rcWnd.left - rcRelativeTo.left; 
    pRect->right = rcWnd.right - rcRelativeTo.left; 
    pRect->bottom = rcWnd.bottom - rcRelativeTo.top; 

    return true; 
} 

现在画你喜欢的东西,我建议你使用TRANSPARENT背景模式。

请创建您的所有子窗口,样式为WS_CLIPCHILDRENWS_CLIPSIBLINGS,那么这些问题将会立即显现,并且避免闪烁。