现在的位置: 首页 > 综合 > 正文

窗体透明、窗体上控件和DC绘图不透明

2014年01月21日 ⁄ 综合 ⁄ 共 1754字 ⁄ 字号 评论关闭

特点:
    1.Dialog窗体完全透明。
    2.窗体上的控件不透明、DC绘制的图形不透明。
    3.拖动窗体上用DC绘制的图形可以移动窗体。
   缺点:
    1.窗体设置透明使用是掩码颜色,所以在窗体上用DC绘图的过程当中如果采用了和透明掩码颜色相同的颜色将不会显示出来。
    2.如果将Border属性设置成了NONE,那么想通过响应WM_NCHITEST消息来实现窗体拖动就无法完成了。只能通过在窗体中增加DC绘图的方式来完成。
    3.DC绘图时虽然支持半透明绘图,但是透明绘图区域不透明。

效果图如下:

主要代码部分:

  1. BOOL CDlgBmp::OnInitDialog()
  2. {
  3.     CDlgBase::OnInitDialog();
  4.     CClientDC dc(this);
  5.    
    COLORREF maskColor = RGB(255,255,255);  
    //掩码颜色
  6.    
  7.     SetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE, GetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE)|
    0x80000); 
    //设定窗体使用扩展模式 
  8.    
    HINSTANCE hInst = LoadLibrary("User32.DLL");
  9.    
    if( hInst )
  10.     {
  11.        
    typedef BOOL( WINAPI *MYFUNC)(HWND,COLORREF,BYTE,DWORD);
  12.         MYFUNC AlphaFunc = NULL;
  13.         AlphaFunc=(MYFUNC)GetProcAddress(hInst,
    "SetLayeredWindowAttributes");
  14.        
    if(AlphaFunc)AlphaFunc(this
    ->GetSafeHwnd(),maskColor,255,1);                  
    //将与掩码颜色相同的窗体部分置为透明
  15.         FreeLibrary(hInst);
  16.     }
  17.     SetDlgItemText( IDC_LEFTTOP,"左上");
  18.     SetDlgItemText( IDC_LEFTBTM,"左下");
  19.     SetDlgItemText( IDC_RIHTTOP,"右上");
  20.     SetDlgItemText( IDC_RIHTBTM,"右下");
  21.    
    return TRUE;
  22. }
  23. void CDlgBmp::OnPaint()
  24. {
  25.     CPaintDC dc(this);
  26.    
  27.     CDC picDC; picDC.CreateCompatibleDC (&dc);         
    //创建兼容DC
  28.     CBitmap * pOldBmp = picDC.SelectObject (&m_bmp);   
    //将颜色为纯白色的图片选定为内存DC的绘图区域
  29.     BITMAP bm; m_bmp.GetBitmap(&bm);
  30.     dc.BitBlt (0,0,bm.bmWidth ,bm.bmHeight,&picDC,0,0,SRCCOPY); 
    //将内存DC图贴回原DC
  31.     dc.SelectObject(pOldBmp);
  32.     Graphics gra(dc.m_hDC);
  33.    
  34.     CRect rt;
  35.     GetClientRect( &rt );
  36.    
  37.     RectF rtF;  rtF.X = rt.left;    rtF.Y = rt.top; rtF.Width = rt.right - rt.left; rtF.Height = rt.bottom -  rt.top;
  38.    
  39.     Pen pn( Color( 128,  255, 0, 0 ), 2 );    
    //在Client区域边界绘制了一个不填充的矩形
  40.     gra.DrawRectangle( &pn, rtF );
  41.     SolidBrush br(Color( 255,255,0,0 ));      
    //在Client区域绘制了一个矩形填充区域
  42.     gra.FillRectangle( &br, 100,75,200,150 );
  43. }

 

http://blog.csdn.net/Tinary3v0/article/details/3097884

抱歉!评论已关闭.