之前一直有个问题都没有解决今天又遇到这个问题
简单来说就是如何把数字加到字符串的后面之前做视音频处理的时候就是搞不定现在出来了,其实是这么的简单
string a[3];
for (int i=0;i<3;i++)
{
char ch[2];//如果这里声明的空间只有一个的话会导致程序结束时候崩溃
a[i] = "das";
sprintf(ch,"%d",i);//直接把这个数字转换成字符串就可以了
a[i] += ch;
cout<<a[i]<<endl;
}
我一直都没搞明白怎么才叫提取颜色的三个通道,split提取之后貌似必须附加到某个gray_image上才能看出来效果
cv::Mat image1;
cv::Mat image2;
image1= cv::imread("D:\\images\\rain.jpg");
image2= cv::imread("D:\\images\\rain.jpg",0);
cv::Mat result1,result2,result3;
std::vector<cv::Mat> planes;
// split 1 3-channel image into 3 1-channel images
cv::split(image1,planes);
planes[0]+= image2;
merge(planes,result1);
imshow("blue",result1);
cv::split(image1,planes);
planes[1]+= image2;
merge(planes,result2);
imshow("green",result2);
cv::split(image1,planes);
planes[2]+= image2;
merge(planes,result3);
imshow("red",result3);
waitKey(0);
system("pause");
return 0;
今天开始复习opencv2这本书感觉这本书写的太强大了,我这种菜鸟级别的估计搞个十回八回的也不全明白
下面我复习一个椒盐噪声和滤波吧
#include <iostream>
#include <highgui.h>
#include <cv.h>
using namespace std;
using namespace cv;
void salt(Mat& image, int n)
{
for(int k=0; k<n; k++)
{
int i = rand()%image.cols;
int j = rand()%image.rows;
if(image.channels() == 1)
{
image.at<uchar>(j,i) = 255;
}
else
{
image.at<Vec3b>(j,i)[0] = 255;
image.at<Vec3b>(j,i)[1] = 255;
image.at<Vec3b>(j,i)[2] = 255;
}
}
}
int main()
{
Mat image = imread("/home/administrator/zhoufeng/circle1.jpeg");
salt(image, 500);
cv::namedWindow("image");
cv::imshow("image",image);
//测试用滤波的手段消除椒盐噪声
Mat result;
Mat kernel;
int ddepth;
int kernel_size;
ddepth = -1;
int ind = 0;
while(true)
{
//每0.5秒刷新一次图像
int c = waitKey(500);
//按esc键退出程序
if((char)c == 27)
{
break;
}
kernel_size = 3+2*(ind%5);
kernel = Mat::ones(kernel_size,kernel_size,CV_32F)/(float)(kernel_size*kernel_size);
filter2D(image,result,ddepth,kernel);
imshow("滤波结果",result);
ind++;
}
cv::waitKey(0);
return 0;
}
随着中心kernel的变大图像的噪声越少但是也越模糊
我们平时对于数组的操作中有数组的翻转,其实图像也有这个功能或者说可以这么做
#include <iostream>
#include <highgui.h>
#include <cv.h>
using namespace std;
using namespace cv;
int main()
{
Mat image = imread("/home/administrator/zhoufeng/lena.jpg");
cv::namedWindow("image");
cv::imshow("image",image);
Mat result_image;
result_image.create(image.rows,image.cols,image.type());
for(int i=0;i<image.rows;i++)
{
for(int j=0;j<image.cols;j++)
{
result_image.at<cv::Vec3b>(i,j)[0] = image.at<cv::Vec3b>(i,image.cols-j-1)[0];
result_image.at<cv::Vec3b>(i,j)[1] = image.at<cv::Vec3b>(i,image.cols-j-1)[1];
result_image.at<cv::Vec3b>(i,j)[2] = image.at<cv::Vec3b>(i,image.cols-j-1)[2];
}
}
cv::namedWindow("after_process");
cv::imshow("after_process",result_image);
cv::waitKey(0);
return 0;
}
就是把数组的每一行中间的那个像素前后翻转一下就可以了,我的这个程序写的不是很好,其实可以利用swap前后交换一下效率更高
之前一再使用ROI 可是一直搞不明白为啥使用,最后发现加水印的时候如果大小不一致的话可以将大图的一部分扣出来也就是所谓的ROI,当然这还是有一个问题就是,叠加之后图像的像素有可能饱和(saturate),解决这个问题可以使用掩码来搞定
#include <iostream>
#include <highgui.h>
#include <cv.h>
using namespace std;
using namespace cv;
int main()
{
Mat image = imread("/home/administrator/zhoufeng/OpenCV-2.4.4/opencv/samples/c/lena.jpg");
cv::namedWindow("image");
cv::imshow("image",image);
Mat logo = imread("/home/administrator/zhoufeng/OpenCV-2.4.4/opencv/samples/c/JCB.png");
cv::namedWindow("logo");
cv::imshow("logo",logo);
Mat imageROI = image(Rect(50,50,logo.cols,logo.rows));
Mat mask = imread("/home/administrator/zhoufeng/OpenCV-2.4.4/opencv/samples/c/JCB.png",0);
logo.copyTo(imageROI,mask);
imshow("结果图像",image);
cv::waitKey(0);
return 0;
}
也可以直接
addWeighted(imageROI,1.0,logo,1.0,0.,imageROI);
只要确定像素不会爆管就可以