Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2086796
  • 博文数量: 909
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 12260
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-06 20:50
文章分类

全部博文(909)

文章存档

2008年(909)

我的朋友

分类:

2008-05-06 22:40:15

一起学习
多层图像合成修正版

作者:葛军

下载源代码

起因:我也是VC知识库网站受益人,昨天开始调试《多层图像合成》的例子,因为没有找到源码,而文中的代码有点不全和错误,费了好多时间才调试出来,觉得本例子对图象处理很有借鉴之处,现拿出来供大家参考以下,在此向原作者致谢,以下大部分是原作者文章的摘录,我仅做了少量修改。

关键字:图像合成

相关背景:多层图像的合成在实际开发中具有非常广泛的应用。首先两个设备DC分别装入了前景图和背景图,然后另一个DC载入一幅二值图像,作为mask图。将载入了前景图的设备环境m_dcFore的背景色设为前景图的背景色,将m_dcFore拷贝到载入了mask图的设备环境maskDc,得到一个新的mask图。新mask图就是前景图中背景色的地方转为白色,其他转为黑色的一幅图。在将前景图拷贝到mask图的过程中,系统首先将前景图转换为单色图。当位图在彩色与单色之间转换时,系统会使用设备的背景色,与背景色相同的地方转换为白色,其他的转换为黑色。设m_dcFore的前景色为白色,背景色为黑色,m_dcFore与maskDc做‘与’运算,得到新的前景图。在做‘与’运算时,系统先将单色图转换为彩色图,并用彩色图的前景色和背景色作为转换后的颜色。所以,新的前景图的背景色转变为黑色,其他的保持不变。设背景图的前景色为黑色,背景色为白色,载入了背景图的设备环境m_dcBk与maskDc做‘与’运算,得到新的背景图。新的背景图的前景色转变为黑色,其他的保持不变。将新的背景图与新的前景图做‘或’运算,得到的新图保持了背景图的背景,更融合前景图的前景,达到了我们想要的理想效果。

实现环境:Visual C 6.0

实现过程:

首先创建一个单文档或多文档的工程取名为CTestSelDrawPicApp。

在Resources中引入我们要合成的两幅Bmp图像(一幅作为背景图、另一幅为前景图),分别命名为IDB_BK、IDB_FORE。

给CCTestSelDrawPicView类建两个CBitmap类型的成员变量,分别命名为m_bmpBk、m_bmpFore。

在CCTestSelDrawPicView类中新建两个CDC类型的成员变量,分别命名为m_dcBk、m_dcFore。

在初始化函数中将两幅Bmp图像装入。在CCTestSelDrawPicView::OnInitialUpdate()函数中加入如下代码:

m_bmpBk.LoadBitmap(IDB_BK); //将背景图载入

m_bmpFore.LoadBitmap(IDB_FORE); //将前景图载入

CClientDC dc(this); //获得当前客户区设备环境

m_dcBk.CreateCompatibleDC(&dc); //创建与当前设备相兼容的设备

m_dcFore.CreateCompatibleDC(&dc); 
在CPicView类的OnDraw(CDC* pDC)函数中加入如下代码:
   CBitmap* poldBk=m_dcBk.SelectObject(&m_bmpBk); //选入背景图

   CBitmap* poldFore=m_dcFore.SelectObject(&m_bmpFore);



   CRect rect;

   GetClientRect(&rect); //得到客户区矩形

   CDC maskDc; //创建设备环境maskDc

   CBitmap maskBitmap;

   maskDc.CreateCompatibleDC(pDC); //创建与当前设备相兼容的设备

   maskBitmap.CreateBitmap(rect.Width(),rect.Height(),1,1,NULL ); //创建一个单色图

   CBitmap* pOldMaskDCBitmap = maskDc.SelectObject( &maskBitmap ); //选入单色图

   CBrush brush(RGB(255,255,255));

   CBrush * oldbrush;

   oldbrush=maskDc.SelectObject(&brush);

   maskDc.FillRect(&rect,&brush);

   //取得要消除的背景色值

   COLORREF clrTrans= m_dcFore.GetPixel(2, 2);



   // 设置前景图的背景色

   COLORREF clrSaveBk = m_dcFore.SetBkColor(clrTrans);



   //将前景图拷贝到maskDc

    maskDc.BitBlt(0,0,rect.Width(),rect.Height(), &m_dcFore, 0,0,SRCCOPY);  



   //将前景图拷贝到maskDc,此时maskDc如下图: 



                         



   //前景图与mask做‘与’运算 

    m_dcFore.SetBkColor(RGB(0,0,0));

    m_dcFore.SetTextColor(RGB(255,255,255));

    m_dcFore.BitBlt(0,0,rect.Width(), rect.Height(),&maskDc,0,0,SRCAND);



           

                       



   //背景图与mask做‘与’运算

    m_dcBk.SetBkColor(RGB(255,255,255));

    m_dcBk.SetTextColor(RGB(0,0,0));

    m_dcBk.BitBlt(0,0,rect.Width(),rect.Height(),&maskDc,0,0,SRCAND);



//背景图与前景图做‘或’运算 m_dcBk.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),&m_dcFore,0,0,SRCPAINT);

//将合成后的图像显示 pDC->BitBlt(0,0,rect.Width(),rect.Height(),&m_dcBk,0,0,SRCCOPY); pDC->SelectObject(oldbrush); m_bmpBk.SelectObject(poldBk); m_bmpFore.SelectObject(poldFore);
全文完 下载本文示例代码


多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版多层图像合成修正版
阅读(446) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~