OpenCV 关于两张图片的整合问题

第一,将两张图片上下排列,合成一张图片

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. extern IplImage* stack_imgs( IplImage* img1, IplImage* img2 )  
  2. {  
  3.     IplImage* stacked = cvCreateImage( cvSize( MAX(img1->width, img2->width),  
  4.                                         img1->height + img2->height ),  
  5.                                         IPL_DEPTH_8U, 3 );  
  6.   
  7.     cvZero( stacked );  
  8.     cvSetImageROI( stacked, cvRect( 0, 0, img1->width, img1->height ) );  
  9.     cvAdd( img1, stacked, stacked, NULL );  
  10.     cvSetImageROI( stacked, cvRect(0, img1->height, img2->width, img2->height) );  
  11.     cvAdd( img2, stacked, stacked, NULL );  
  12.     cvResetImageROI( stacked );  
  13.   
  14.     return stacked;  
  15. }  


第二,将两张图片左右排列,合成一张图片

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. extern IplImage* expand_imgs( IplImage* img1, IplImage* img2 )  
  2. {  
  3.     IplImage* expanded = cvCreateImage( cvSize(   
  4.         img1->width + img2->width,MAX(img1->height, img2->height)),   
  5.         IPL_DEPTH_8U, 3 );  
  6.   
  7.     cvZero( expanded );  
  8.     cvSetImageROI( expanded, cvRect( 0, 0, img1->width, img1->height ) );  
  9.     cvAdd( img1, expanded, expanded, NULL );  
  10.     cvSetImageROI( expanded, cvRect(img1->width, 0, img2->width, img2->height) );  
  11.     cvAdd( img2, expanded, expanded, NULL );  
  12.     cvResetImageROI( expanded );  
  13.   
  14.     return expanded;  
  15. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值