WIN CE 实现透明控件
2009-01-07 16:24
246 查看
1、导入一张背景图:IDB_BKGND
2、资源里添加一按钮和一静态文本框
3、声明如下:
HBRUSH GetBkBrush( HWND hWnd, UINT nID, HBITMAP hBmBk );
HBITMAP m_hBmBkgnd; // 对话框背景图片
HBRUSH m_hBrCtl[2]; // 控件背景画刷
4、添加WM_CTCOLOR WM_PAINT WM_DESTROY 消息;
5、OnInitDialog中加入如下代码:
m_hBmBkgnd = ::LoadBitmap( AfxGetInstanceHandle(), MAKEINTRESOURCE(IDB_BKGND) );
if( m_hBmBkgnd )
{
m_hBrCtl[0] = GetBkBrush( GetSafeHwnd(), IDC_BUTTON1, m_hBmBkgnd );
m_hBrCtl[1] = GetBkBrush( GetSafeHwnd(), IDC_STATIC1, m_hBmBkgnd );
}
6、
HBRUSH CTransButtonDlg::GetBkBrush( HWND hWnd, UINT nID, HBITMAP hBmBk )
{
#define _X(x) (x.left)
#define _Y(x) (x.top)
#define _W(x) (x.right - x.left)
#define _H(x) (x.bottom - x.top)
HWND hWndCtrl;
hWndCtrl = ::GetDlgItem( hWnd, nID );
HBRUSH hBrushCtrl = NULL;
if( NULL != hWndCtrl )
{
RECT rcCtrl;
::GetWindowRect( hWndCtrl, &rcCtrl );
::ScreenToClient(hWnd, (LPPOINT)&rcCtrl);
::ScreenToClient(hWnd, ((LPPOINT)&rcCtrl)+1);
HDC hDC = ::GetDC(hWnd);
HDC hMemDCBk = CreateCompatibleDC( hDC );
HDC hMemDCCtrl = CreateCompatibleDC( hDC );
HBITMAP hBmCtrl = CreateCompatibleBitmap( hDC, _W(rcCtrl), _H(rcCtrl) );
HBITMAP hBmOldBk;
HBITMAP hBmOldCtrl;
hBmOldBk = (HBITMAP) ::SelectObject( hMemDCBk, hBmBk );
hBmOldCtrl = (HBITMAP) ::SelectObject( hMemDCCtrl, hBmCtrl );
::BitBlt( hMemDCCtrl, 0, 0, _W(rcCtrl), _H(rcCtrl), hMemDCBk, _X(rcCtrl), _Y(rcCtrl), SRCCOPY );
::SelectObject(hMemDCCtrl, hBmOldCtrl );
::SelectObject(hMemDCBk, hBmOldBk );
hBrushCtrl = ::CreatePatternBrush( hBmCtrl );
DeleteObject( hBmCtrl );
::DeleteDC( hMemDCBk );
::DeleteDC( hMemDCCtrl );
::ReleaseDC( hWnd, hDC );
}
return hBrushCtrl;
}
void CTransButtonDlg::OnPaint()
{
CPaintDC dc(this); // device context for painting
CDC memDC;
CBitmap bmBkgnd;
bmBkgnd.Attach( m_hBmBkgnd );
memDC.CreateCompatibleDC(&dc);
CBitmap *pOldBm = memDC.SelectObject( &bmBkgnd );
BITMAP bm;
bmBkgnd.GetObject(sizeof(bm), &bm);
dc.BitBlt(0, 0, bm.bmWidth, bm.bmHeight, &memDC, 0, 0, SRCCOPY );
memDC.SelectObject( pOldBm );
bmBkgnd.Detach();
}
HBRUSH CTransButtonDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if(pWnd->GetDlgCtrlID() == IDC_BUTTON1 )
{
pDC->SetTextColor(RGB(0, 0, 0));
pDC->SetBkMode( TRANSPARENT ) ;
return m_hBrCtl[0];
}
else if(pWnd->GetDlgCtrlID() == IDC_STATIC1)
{
pDC->SetTextColor(RGB(0, 0, 0));
pDC->SetBkMode( TRANSPARENT ) ;
return m_hBrCtl[1];
}
return hbr;
}
void CTransButtonDlg::OnDestroy()
{
CDialog::OnDestroy();
::DeleteObject( m_hBmBkgnd );
::DeleteObject( m_hBrCtl[0] );
::DeleteObject( m_hBrCtl[1] );
}
2、资源里添加一按钮和一静态文本框
3、声明如下:
HBRUSH GetBkBrush( HWND hWnd, UINT nID, HBITMAP hBmBk );
HBITMAP m_hBmBkgnd; // 对话框背景图片
HBRUSH m_hBrCtl[2]; // 控件背景画刷
4、添加WM_CTCOLOR WM_PAINT WM_DESTROY 消息;
5、OnInitDialog中加入如下代码:
m_hBmBkgnd = ::LoadBitmap( AfxGetInstanceHandle(), MAKEINTRESOURCE(IDB_BKGND) );
if( m_hBmBkgnd )
{
m_hBrCtl[0] = GetBkBrush( GetSafeHwnd(), IDC_BUTTON1, m_hBmBkgnd );
m_hBrCtl[1] = GetBkBrush( GetSafeHwnd(), IDC_STATIC1, m_hBmBkgnd );
}
6、
HBRUSH CTransButtonDlg::GetBkBrush( HWND hWnd, UINT nID, HBITMAP hBmBk )
{
#define _X(x) (x.left)
#define _Y(x) (x.top)
#define _W(x) (x.right - x.left)
#define _H(x) (x.bottom - x.top)
HWND hWndCtrl;
hWndCtrl = ::GetDlgItem( hWnd, nID );
HBRUSH hBrushCtrl = NULL;
if( NULL != hWndCtrl )
{
RECT rcCtrl;
::GetWindowRect( hWndCtrl, &rcCtrl );
::ScreenToClient(hWnd, (LPPOINT)&rcCtrl);
::ScreenToClient(hWnd, ((LPPOINT)&rcCtrl)+1);
HDC hDC = ::GetDC(hWnd);
HDC hMemDCBk = CreateCompatibleDC( hDC );
HDC hMemDCCtrl = CreateCompatibleDC( hDC );
HBITMAP hBmCtrl = CreateCompatibleBitmap( hDC, _W(rcCtrl), _H(rcCtrl) );
HBITMAP hBmOldBk;
HBITMAP hBmOldCtrl;
hBmOldBk = (HBITMAP) ::SelectObject( hMemDCBk, hBmBk );
hBmOldCtrl = (HBITMAP) ::SelectObject( hMemDCCtrl, hBmCtrl );
::BitBlt( hMemDCCtrl, 0, 0, _W(rcCtrl), _H(rcCtrl), hMemDCBk, _X(rcCtrl), _Y(rcCtrl), SRCCOPY );
::SelectObject(hMemDCCtrl, hBmOldCtrl );
::SelectObject(hMemDCBk, hBmOldBk );
hBrushCtrl = ::CreatePatternBrush( hBmCtrl );
DeleteObject( hBmCtrl );
::DeleteDC( hMemDCBk );
::DeleteDC( hMemDCCtrl );
::ReleaseDC( hWnd, hDC );
}
return hBrushCtrl;
}
void CTransButtonDlg::OnPaint()
{
CPaintDC dc(this); // device context for painting
CDC memDC;
CBitmap bmBkgnd;
bmBkgnd.Attach( m_hBmBkgnd );
memDC.CreateCompatibleDC(&dc);
CBitmap *pOldBm = memDC.SelectObject( &bmBkgnd );
BITMAP bm;
bmBkgnd.GetObject(sizeof(bm), &bm);
dc.BitBlt(0, 0, bm.bmWidth, bm.bmHeight, &memDC, 0, 0, SRCCOPY );
memDC.SelectObject( pOldBm );
bmBkgnd.Detach();
}
HBRUSH CTransButtonDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if(pWnd->GetDlgCtrlID() == IDC_BUTTON1 )
{
pDC->SetTextColor(RGB(0, 0, 0));
pDC->SetBkMode( TRANSPARENT ) ;
return m_hBrCtl[0];
}
else if(pWnd->GetDlgCtrlID() == IDC_STATIC1)
{
pDC->SetTextColor(RGB(0, 0, 0));
pDC->SetBkMode( TRANSPARENT ) ;
return m_hBrCtl[1];
}
return hbr;
}
void CTransButtonDlg::OnDestroy()
{
CDialog::OnDestroy();
::DeleteObject( m_hBmBkgnd );
::DeleteObject( m_hBrCtl[0] );
::DeleteObject( m_hBrCtl[1] );
}
相关文章推荐
- 【转】自行实现透明的控件如Panel GroupBox
- 循序渐进实现仿QQ界面(五):半透明窗体与不透明控件
- QT窗口控件透明效果的实现
- 循序渐进实现仿QQ界面(五):半透明窗体与不透明控件
- 实现控件的透明背景
- EVC中透明控件的实现
- C# 实现真正的透明控件(Windows桌面程序)
- 自绘控件里实现控件无效区域透明效果
- 循序渐进实现仿QQ界面(五):半透明窗体与不透明控件
- vc循序渐进实现仿QQ界面(五):半透明窗体与不透明控件
- EVC中透明控件的实现
- Windows Mobile实现透明控件
- 半透明窗口中显示标准控件(控件与文字不透明)的实现方案(附源码)
- 自定义View控件值ScrollView,监听实现标题透明到显示
- C#怎样实现窗体透明而控件不透明,或者就是怎样无窗体显示图片,就像圣诞那样的程序,不吝赐教!
- 在EVC中实现透明控件
- 实现控件透明背景的几种方案
- MFC一一添加背景图片并让控件实现透明的
- MFC中实现Static控件背景透明
- mfc中如何实现窗体半透明 但是控件不透明