最近正在努力学习opencv图像处理,下面是我的程序文件,我用的是opencv2.4.10在vc2010编译的
#include "opencv2/opencv.hpp"
#include <iostream>
using namespace cv;
using namespace std;
#define WINDOW_NAME "TEST"
Mat image;
Mat g_srcImage1;
Mat g_srcImage2;
Mat g_srcImage;
const int g_nMaxAlphaValue=100;
int g_nAlphaValueSlider;
double g_dAlphaValue;
double g_dBetaValue;
void on_Trackbar(int,void*)
{
g_dAlphaValue=(double) g_nAlphaValueSlider/g_nMaxAlphaValue;
g_dBetaValue=(1.0-g_dAlphaValue);
addWeighted(g_srcImage1,g_dAlphaValue,g_srcImage2,g_dBetaValue,0.0,g_srcImage);
imshow(WINDOW_NAME,g_srcImage);
}
int main(int argc , char** argv)
{
g_srcImage1=imread("3.jpg");
g_srcImage2=imread("4.jpg");
g_nAlphaValueSlider=70;
namedWindow(WINDOW_NAME,1);
char TrackbarName[50];
sprintf(TrackbarName,"alph %d",g_nMaxAlphaValue);
createTrackbar(TrackbarName,WINDOW_NAME,&g_nAlphaValueSlider,g_nMaxAlphaValue,on_Trackbar);
on_Trackbar(g_nAlphaValueSlider,0);
waitKey(0);
return 0;
}
这是测试后的结果,同过改变线性混合的值,可以改变混合后的效果。
注意:如果程序提示内存错误,请自行把图片的裁剪为大小大小一样的,否则会报错。