多层图像合成

发表于:2007-07-01来源:作者:点击数: 标签:
多层图像合成 关键字:图像合成 相关背景:多层图像的合成在实际 开发 中具有非常广泛的应用。首先两个设备DC分别装入了前景图和背景图,然后另一个DC载入一幅二值图像,作为mask图。将载入了前景图的设备环境m_dcFore的背景色设为前景图的背景色,将m_dcFor

 多层图像合成


关键字:图像合成


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


实现环境:Visual C++ 6.0


实现过程:


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


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


                             


给CPicView类建两个CBitmap类型的成员变量,分别命名为m_bmpBk、m_bmpFore。在初始化函数中将两幅Bmp图像装入。在CPicView::OnInitialUpdate()函数中加入如下代码:


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


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


在CPicView类中新建两个CDC类型的成员变量,分别命名为m_dcBk、m_dcFore。在初始化函数中加入如下代码:


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


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


        m_dcFore. CreateCompatibleDC(&dc);


              CBitmap* poldBk=m_dcBk.SelectObject(m_bmpBk);   //选入背景图


        CBitmap* poldFore=m_dcFore.SelectObject(m_bmpFore);


在CPicView类的OnDraw(CDC* pDC)函数中加入如下代码:


  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 ); //选入单色图


 


m_dcFore.SetBkColor(RGB());  //设前景色的背景色


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


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


                     


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_bmpBk.SetBkColor(RGB(255,255,255));


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


    m_bmpBk.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),&maskDc,0,0,SRCAND);


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



  m_bmpBk.BitBlt(rect.left,rect.top,rect.Width(),rect.Height(),&memDc,0,0,SRCPAINT);


  //背景图与前景图做‘或’运算



    pDC->BitBlt(0,0,rect.Width(),rect.Height(),&m_bmpBk,0,0,SRCCOPY);


  //将合成后的图像显示


 


  m_bmpBk.SelectObject(poldBk);


  m_bmpFore.SelectObject(poldFore);


原文转自:http://www.ltesting.net