• <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
            久久国产午夜精品一区二区三区| 久久久亚洲欧洲日产国码aⅴ| 国产精品久久久久久久午夜片| 99久久精品九九亚洲精品| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 93精91精品国产综合久久香蕉 | 无码任你躁久久久久久| 狠狠综合久久综合88亚洲| 精品国产乱码久久久久久1区2区 | 午夜精品久久久久久| 97久久精品无码一区二区| 久久综合视频网| 精品国产一区二区三区久久久狼 | 久久精品国产亚洲av高清漫画| 久久AAAA片一区二区| 国内精品久久久久影院优| 久久久亚洲精品蜜桃臀| 久久99精品国产| 久久人人爽人人爽人人AV| 无码任你躁久久久久久久| 亚洲国产精品婷婷久久| 久久国产精品99国产精| 久久久久久曰本AV免费免费| 久久无码人妻精品一区二区三区| 丁香五月网久久综合| 亚洲色欲久久久综合网东京热| 久久亚洲天堂| 久久一区二区免费播放| 久久精品国产亚洲Aⅴ香蕉| 国产高潮国产高潮久久久91| 国产99精品久久| 69久久夜色精品国产69| 精品国产VA久久久久久久冰| 天天爽天天狠久久久综合麻豆| 亚洲中文字幕久久精品无码喷水| 欧美一区二区久久精品| 麻豆精品久久久久久久99蜜桃| 久久99热这里只有精品国产| 国产激情久久久久久熟女老人| 亚洲伊人久久大香线蕉综合图片| 亚洲综合熟女久久久30p|