#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
void salt(cv::Mat image, int n){
int i, j;
for (int k = 0; k < n; k++)
{
i = std::rand() % image.cols;
j = std::rand() % image.rows;
if (image.type() == CV_8UC1) //灰度图像
{
image.at<uchar>(j, i) = 255; //置为白色噪声
}
else if (image.type() == CV_8UC3) { // color image
image.at<cv::Vec3b>(j, i)[0] = 255;
image.at<cv::Vec3b>(j, i)[1] = 255;
image.at<cv::Vec3b>(j, i)[2] = 255;
}
}
}
int main(){
IplImage *iplImage = cvLoadImage("demo.jpg");
cv::Mat image(iplImage, false);
cv::Mat logo = cv::imread("roi.png");
cv::Mat imageROI(image, cv::Rect(image.cols - logo.cols, image.rows - logo.rows, logo.cols, logo.rows)); //在image中获取一个ROI
logo.copyTo(imageROI); //给ROI赋值图像
salt(image, 3000);
cv::namedWindow("Image1");
cv::imshow("Image1", image); //用名称来标识窗口
cv::waitKey(0);
}
添加椒盐噪声
最新推荐文章于 2022-08-26 16:13:14 发布