• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Benjamin

            靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 397, 文章 - 0, 評論 - 196, 引用 - 0
            數據加載中……

            關于VC圖片透明處理的補充

            前一陣子我的博客中有篇圖片透明處理的文章,下面對它做個補充。這里也可以用在EVC和VC的各個版本上
            1、透明:包括關鍵色透明和alpha透明,關鍵色透明就是選擇一種顏色作為透明色,一般選取背景色。  
              alpha透明就是和背景融合,一般范圍是0~255,數值越小背景越明顯,0表示完全透明,255表示不透明  
              公式  
              dstred   =   srcred   *   (alpha   /   255.0)   +   dstred   *   (1.0   -   alpha   /   255.0);  
              dstred   =   srcred   *   (alpha   /   255.0)   +   dstred   *   (1.0   -   alpha   /   255.0);  
              dstred   =   srcred   *   (alpha   /   255.0)   +   dstred   *   (1.0   -   alpha   /   255.0);  
               
              2、窗口透明  
              2.1、如果系統是2000以上可以設置窗口的透明屬性如下:  
               
              //至少需要Windows   2000系統  
              ModifyStyleEx(0,WS_EX_LAYERED);   //修改Window的風格  
              //如果不設置屬性,窗口就看不到  
              //SetLayeredWindowAttributes(GetSysColor(COLOR_BTNFACE),0,LWA_COLORKEY);   //透明色是按鈕背景顏色   這個就可以實現不規則窗口  
              SetLayeredWindowAttributes(0,0,LWA_ALPHA);   //半透明  
              //SetLayeredWindowAttributes(GetSysColor(COLOR_BTNFACE),128,LWA_COLORKEY   |   LWA_ALPHA);   //兩個混合  
               
              注意要設置_WIN32_WINNT的值   0x500  
            把上面的代碼加入窗體初始化代碼中就可以了。
            .2、  
              如果是2000以下的系統,可以設置窗口的Region來達到關鍵色透明效果  
              void   MyWnd::SetRegion(COLORREF   clrTrans)  
              {  
              m_bmp.LoadBitmap(IDB_BITMAP1);   //讀取位圖資源  
              BITMAP   bm;  
              CSize   sz;  
              m_bmp.GetBitmap(&bm);  
              sz.cx   =   bm.bmWidth;  
              sz.cy   =   bm.bmHeight;  
              unsigned   char   *pBuffer   =   new   unsigned   char[sz.cx   *   sz.cy   *   (bm.bmBitsPixel   >>   3)];  
              m_bmp.GetBitmapBits(sz.cx   *   sz.cy   *   (bm.bmBitsPixel   >>   3),pBuffer);  
              unsigned   char   *pOriBuffer   =   pBuffer;  
               
              CRgn   rgn,rgn2;  
              rgn.CreateRectRgn(0,0,sz.cx,sz.cy);  
              rgn2.CreateRectRgn(0,0,1,1);  
               
              int   off   =   (bm.bmBitsPixel   >>   3);  
              for(int   y   =   0;   y   <   sz.cy;   y++)  
              {  
              for(int   x   =   0;   x   <   sz.cx;   x++)  
              {  
              if(((*pBuffer)   ==   255)   &&   ((*(pBuffer   +   1))   ==   0)   &&   ((*(pBuffer   +   2))   ==   255))  
              {  
              rgn2.SetRectRgn(x,y,x   +   1,y   +   1);  
              rgn.CombineRgn(&rgn,&rgn2,RGN_DIFF);  
              }  
              pBuffer   +=   off;  
              }  
              }  
               
              delete   []pOriBuffer;  
              SetWindowRgn((HRGN)rgn.GetSafeHandle(),TRUE);  
              }  
            3、AlphaBlend   Alpha透明  
               
              //繪制可以透明的矩形  
              void   DrawAlphaRect(CDC   *pDC,CRect&   r,COLORREF   clr,unsigned   char   alpha)  
              {  
              CDC   memdc;  
              memdc.CreateCompatibleDC(pDC);  
              CBitmap   bmp,*pOldBitmap;  
              bmp.CreateCompatibleBitmap(pDC,r.Width(),r.Height());  
              pOldBitmap   =   memdc.SelectObject(&bmp);  
              memdc.FillSolidRect(0,0,r.Width(),r.Height(),clr);  
              BLENDFUNCTION   bf;  
              bf.BlendOp   =   AC_SRC_OVER;  
              bf.BlendFlags   =   0;  
              bf.SourceConstantAlpha   =   alpha;  
              bf.AlphaFormat   =   0;  
              pDC->AlphaBlend(r.left,r.top,r.Width(),r.Height(),&memdc,0,0,r.Width(),r.Height(),bf);  
              memdc.SelectObject(pOldBitmap);  
              }  
               
              //繪制可以透明的位圖  
              void   DrawAlphaBitmap(CDC   *pDC,CRect&   r,CBitmap&   bmp,unsigned   char   alpha)  
              {  
              CDC   memdc;  
              memdc.CreateCompatibleDC(pDC);  
              CBitmap   *pOldBitmap;  
              CSize   sz   =   bmp.GetBitmapDimension();  
              BITMAP   bm;  
              bmp.GetBitmap(&bm);  
              sz.SetSize(bm.bmWidth,bm.bmHeight);  
              pOldBitmap   =   memdc.SelectObject(&bmp);  
              BLENDFUNCTION   bf;  
              bf.BlendOp   =   AC_SRC_OVER;  
              bf.BlendFlags   =   0;  
              bf.SourceConstantAlpha   =   alpha;  
              bf.AlphaFormat   =   0;  
              pDC->AlphaBlend(r.left,r.top,r.Width(),r.Height(),&memdc,0,0,sz.cx,sz.cy,bf);  
              memdc.SelectObject(pOldBitmap);  
              }  
               
              這樣調用  
              COLORREF   clr   =   RGB(141,173,223);  
              DrawAlphaRect(pDC,CRect(10,50,500,400),clr,192);  
               
              DrawAlphaBitmap(pDC,CRect(10,10,300,200),bmp,128);  

            posted on 2009-05-04 21:43 Benjamin 閱讀(4845) 評論(2)  編輯 收藏 引用 所屬分類: VC

            評論

            # re: 關于VC圖片透明處理的補充  回復  更多評論   

            /繪制可以透明的位圖 這個函數放在那里調用啊?CDC *pDC就是窗口嗎?
            2015-03-20 13:13 | 張銀平

            # re: 關于VC圖片透明處理的補充  回復  更多評論   

            加載圖片的時候調用
            2015-04-17 08:44 | Benjamin
            91精品国产色综合久久| 91精品国产高清久久久久久io | 无码伊人66久久大杳蕉网站谷歌| 99久久久久| 91久久精品国产成人久久| 欧美久久综合性欧美| AV狠狠色丁香婷婷综合久久| 久久精品国产亚洲AV高清热 | 久久久久国产一级毛片高清版| 亚洲午夜久久久久久久久久| 亚洲国产综合久久天堂| 2021最新久久久视精品爱| 国内精品人妻无码久久久影院导航 | 亚洲人AV永久一区二区三区久久| 久久无码人妻精品一区二区三区 | 亚洲午夜久久久久久久久久| 五月丁香综合激情六月久久| 国产精品9999久久久久| 久久国产成人精品麻豆| 成人精品一区二区久久久| 国产毛片久久久久久国产毛片| 一本伊大人香蕉久久网手机| 97超级碰碰碰碰久久久久| 久久久91人妻无码精品蜜桃HD| 色悠久久久久久久综合网| 日本WV一本一道久久香蕉| 亚洲精品蜜桃久久久久久| 狠狠色噜噜狠狠狠狠狠色综合久久 | 久久久久亚洲AV无码专区体验| 2021少妇久久久久久久久久| 欧美亚洲色综久久精品国产| 青草久久久国产线免观| 青青热久久国产久精品| 一级做a爰片久久毛片免费陪| 久久福利青草精品资源站免费| 久久久久国产精品熟女影院| 亚洲精品白浆高清久久久久久| 午夜精品久久久内射近拍高清| 中文国产成人精品久久亚洲精品AⅤ无码精品| 九九热久久免费视频| 久久福利资源国产精品999|