opencv2 问题复习 第11天

之前一直有个问题都没有解决今天又遇到这个问题

简单来说就是如何把数字加到字符串的后面之前做视音频处理的时候就是搞不定现在出来了,其实是这么的简单

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);
只要确定像素不会爆管就可以

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值