OpenCV-图像颗粒感

简介: OpenCV-图像颗粒感

实现原理

      图像形成颗粒感的效果,可以通过引入一个随机波动噪声实现,对图像三通道数据进行某个程度的调整,用level参数控制。直观看上去的效果,就是图像不再光滑,而是有点像素点状的感觉。

功能函数代码

// 颗粒感
cv::Mat Grainy(cv::Mat src, int level)
{
  int row = src.rows;
  int col = src.cols;
  if (level > 50)
    level = 50;
  if (level < 0)
    level = 0;
  cv::Mat result = src.clone();
  for (int i = 0; i < row; ++i)
  {
    uchar *t = result.ptr<uchar>(i);
    for (int j = 0; j < col; ++j)
    {
      for (int k = 0; k < 3; ++k)
      {
        int temp = t[3 * j + k];
        temp += ((rand() % (2 * level)) - level);
        if (temp < 0)temp = 0;
        if (temp > 255)temp = 255;
        t[3 * j + k] = temp;
      }
    }
  }
  return result;
}

C++测试代码

#include <iostream>
#include <string>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
cv::Mat Grainy(cv::Mat src, int level);
int main()
{
  cv::Mat src = imread("dragon.jpg");
  int level1 = 20,level2=50;
  cv::Mat result1 = Grainy(src, level1);
  cv::Mat result2 = Grainy(src, level2);
  cv::imshow("original", src);
  cv::imshow("result1", result1);
  cv::imshow("result2", result2);
  waitKey(0);
  return 0;
}
// 颗粒感
cv::Mat Grainy(cv::Mat src, int level)
{
  int row = src.rows;
  int col = src.cols;
  if (level > 50)
    level = 50;
  if (level < 0)
    level = 0;
  cv::Mat result = src.clone();
  for (int i = 0; i < row; ++i)
  {
    uchar *t = result.ptr<uchar>(i);
    for (int j = 0; j < col; ++j)
    {
      for (int k = 0; k < 3; ++k)
      {
        int temp = t[3 * j + k];
        temp += ((rand() % (2 * level)) - level);
        if (temp < 0)temp = 0;
        if (temp > 255)temp = 255;
        t[3 * j + k] = temp;
      }
    }
  }
  return result;
}

测试效果

图1 原图

图2 level为20的颗粒感

图3 level为50的颗粒感

      适当地调整level,可以一定程度上增加图片的美感,营造出类似海报质感的效果。


      如果函数有什么可以改进完善的地方,非常欢迎大家指出,一同进步何乐而不为呢~


      如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

相关文章
|
3月前
|
监控 API 计算机视觉
OpenCV这么简单为啥不学——1.3、图像缩放resize函数
OpenCV这么简单为啥不学——1.3、图像缩放resize函数
45 0
|
4月前
|
监控 算法 开发工具
Baumer工业相机堡盟工业相机如何联合NEOAPI SDK和OpenCV实现获取图像并对图像进行边缘检测(C#)
Baumer工业相机堡盟工业相机如何联合NEOAPI SDK和OpenCV实现获取图像并对图像进行边缘检测(C#)
41 1
|
3天前
|
编解码 物联网 计算机视觉
【OpenCV】—图像金子塔与图片尺寸缩放
【OpenCV】—图像金子塔与图片尺寸缩放
|
3天前
|
计算机视觉 索引
【OpenCV】—ROI区域图像叠加&图像混合
【OpenCV】—ROI区域图像叠加&图像混合
|
21天前
|
编解码 计算机视觉 Python
opencv 图像金字塔(python)
opencv 图像金字塔(python)
|
2月前
|
存储 计算机视觉
OpenCV(三十九):积分图像
OpenCV(三十九):积分图像
18 0
|
2月前
|
计算机视觉
OpenCV(三十):图像膨胀
OpenCV(三十):图像膨胀
22 0
|
2月前
|
计算机视觉
OpenCV(二十九):图像腐蚀
OpenCV(二十九):图像腐蚀
25 0
|
2月前
|
计算机视觉
OpenCV(二十七):图像距离变换
OpenCV(二十七):图像距离变换
20 0
|
2月前
|
计算机视觉 Python
OpenCV 4基础篇| OpenCV图像的拆分和合并
OpenCV 4基础篇| OpenCV图像的拆分和合并