关于背景透明,透明贴图后,Invalidate(FALSE)刷新后贴图被上次的痕迹遮盖。
Invalidate(TRUE)可以去除遮盖的痕迹,但这样的的闪烁谁也无法接受
这个问题产生的原因可能是SetBkMode(TRANSPARENT)透明的区域,当Invalidate(FALSE)后不会再进行刷新,
导致以前痕迹还在,造成了遮盖的效果。
解决:
方法1,得到这篇区域InvalidateRect()来刷新,只有这片小的区域会闪烁。 这个方法后还是让人不满意。
方法2,偷梁换柱,截取这个文字应有的背景,直接进行不透明贴图。 这个方法实现的效果很满意。
方法2示例代码:
void CXXXStatic::OnPaint()
{
CPaintDC dc(this);
CString strText;
this->GetWindowText(strText);
CBitmap memBmp;
CDC memDC;
memDC.CreateCompatibleDC(pDC);
CBitmap *pOldBmp = memBmp.LoadBitmap(IDB_XXX_XXX); //load你的背景
pOldBmp = memDC.SelectObject(&memBmp);
memDC.TextOut(0, 0, strText, wcslen(strText));
dc.BitBlt(posX, posY, bmpW, bmpH, &memDC, 0, 0, SRCCOPY);
memDC.SelectObject(pOldBmp);
memDC.DeleteObject();
}
方法3,同方法二,只不过背景还设置为透明,利用CImage进行贴图。
方法3示例代码
void CXXXStatic::OnPaint()
{
CPaintDC dc(this);
CString strText;
this->GetWindowText(strText);
dc.SetBkMode(TRANSPARENT);
CImage img;
if(m_imgPath != _T("")) //(m_imgPath 是一个成员变量,通过对它进行set,可以设置此控件的图片背景。
{
img.Load(m_imgPath);
img.Draw(dc.m_hDC, 0, 0);
}
dc.TextOut(0, 0, strText, wcslen(strText));
}
void CXXXStatic::SetTextBkImg(LPCTSTR filePath)
{
m_imgPath = CString(filePath);
}
效果后