服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - OpenCV实现马赛克和毛玻璃滤镜效果

OpenCV实现马赛克和毛玻璃滤镜效果

2021-06-19 11:35-牧野- C/C++

这篇文章主要为大家详细介绍了OpenCV实现马赛克和毛玻璃滤镜效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文为大家分享了OpenCV实现马赛克和毛玻璃滤镜的具体代码,供大家参考,具体内容如下

一、马赛克效果

马赛克的实现原理是把图像上某个像素点一定范围邻域内的所有点用邻域内随机选取的一个像素点的颜色代替,这样可以模糊细节,但是可以保留大体的轮廓。

以下OpenCV程序实现马赛克效果,通过鼠标左键在图像上划定马赛克的矩形框。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#include <core\core.hpp>
#include <highgui\highgui.hpp>
 
using namespace cv;
 
Mat imageSourceCopy; //原始图像
Mat imageSource; //原始图像拷贝
int neightbourHood = 9; //马赛克上每个方框的像素大小
 
RNG rng;
int randomNum; //邻域内随机值
 
Point ptL; //左键按下时坐标
Point ptR; //右键按下时坐标
 
//鼠标回掉函数
void onMouse(int event, int x, int y, int flag, void *ustg);
 
int main()
{
  imageSourceCopy = imread("Test.jpg");
  imageSource = imageSourceCopy.clone();
  //imshow("马赛克", imageSourceCopy);
  namedWindow("马赛克");
  setMouseCallback("马赛克", onMouse);
  waitKey();
}
 
void onMouse(int event, int x, int y, int flag, void *ustg)
{
  if (event == CV_EVENT_LBUTTONDOWN)
  {
    ptL = Point(x, y);
  }
  if (event == CV_EVENT_LBUTTONUP)
  {
    //对鼠标画出的矩形框超出图像范围做处理,否则会越界崩溃
    x > imageSource.cols - 2 * neightbourHood ? x = imageSource.cols - 2 * neightbourHood : x = x;
    y > imageSource.rows - 2 * neightbourHood ? y = imageSource.rows - 2 * neightbourHood : y = y;
 
    //对鼠标从右下往右上画矩形框的情况做处理
    ptR = Point(x, y);
    Point pt = ptR;
    ptR.x < ptL.x ? ptR = ptL, ptL = pt : ptR = ptR;
    for (int i = 0; i < ptR.y - ptL.y; i += neightbourHood)
    {
      for (int j = 0; j < ptR.x - ptL.x; j += neightbourHood)
      {
        randomNum = rng.uniform(-neightbourHood / 2, neightbourHood / 2);
        Rect rect = Rect(j + neightbourHood + ptL.x, i + neightbourHood + ptL.y, neightbourHood, neightbourHood);
        Mat roi = imageSourceCopy(rect);
        Scalar sca = Scalar(
          imageSource.at<Vec3b>(i + randomNum + ptL.y, j + randomNum + ptL.x)[0],
          imageSource.at<Vec3b>(i + randomNum + ptL.y, j + randomNum + ptL.x)[1],
          imageSource.at<Vec3b>(i + randomNum + ptL.y, j + randomNum + ptL.x)[2]);
        Mat roiCopy = Mat(rect.size(), CV_8UC3, sca);
        roiCopy.copyTo(roi);
      }
    }
  }
  imshow("马赛克", imageSourceCopy);
  waitKey();
}

可以通过改变程序中neightbourHood参数的大小调整小矩形快的大小,实现效果:

OpenCV实现马赛克和毛玻璃滤镜效果

二、毛玻璃效果

毛玻璃效果的实现通过用像素点邻域内随机一个像素点的颜色替代当前像素点的颜色实现。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <core\core.hpp>
#include <highgui\highgui.hpp>
 
using namespace cv;
 
int main()
{
  Mat imageSource = imread("Test.jpg");
  Mat imageResult = imageSource.clone();
  RNG rng;
  int randomNum;
  int Number = 5;
 
  for (int i = 0; i < imageSource.rows - Number; i++)
    for (int j = 0; j < imageSource.cols - Number; j++)
    {
      randomNum = rng.uniform(0, Number);
      imageResult.at<Vec3b>(i, j)[0] = imageSource.at<Vec3b>(i + randomNum, j + randomNum)[0];
      imageResult.at<Vec3b>(i, j)[1] = imageSource.at<Vec3b>(i + randomNum, j + randomNum)[1];
      imageResult.at<Vec3b>(i, j)[2] = imageSource.at<Vec3b>(i + randomNum, j + randomNum)[2];
    }
  imshow("毛玻璃效果", imageResult);
  waitKey();
}

实现效果:

OpenCV实现马赛克和毛玻璃滤镜效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。 

原文链接:http://blog.csdn.net/dcrmg/article/details/53749976

延伸 · 阅读

精彩推荐