OpenCV-PS扩散毛玻璃效果的实现代码
作者:翟天保Steven 时间:2022-03-17 22:45:52
实现原理
PS的扩散效果可以产生类似毛玻璃质感的效果,使画面有些毛毛的感觉。其实现可通过操作像素三通道数值的方式实现,定义一个随机数器,将图像中任一点的数值赋值为,以该点为中心一定尺寸窗口(如3*3,5*5)内随机一个点的数值。
功能函数代码
// 扩散效果
cv::Mat Diffusion(cv::Mat src,int size)
{
int row = src.rows;
int col = src.cols;
RNG rng;
cv::Mat result = src.clone();
for (int i = size; i < row- size; ++i)
{
uchar* t = result.ptr<uchar>(i);
for (int j = size; j < col- size; ++j)
{
int tmp = rng.uniform(0, 2*size+1);
t[3 * j] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)));
t[3 * j + 1] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 1);
t[3 * j + 2] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 2);
}
}
return result;
}
C++测试代码
#include <iostream>
#include <string>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
cv::Mat Diffusion(cv::Mat src, int size);
int main()
{
cv::Mat src = imread("test.jpg");
int size = 5;
cv::Mat result = Diffusion(src,size);
cv::imshow("original", src);
cv::imshow("result", result);
waitKey(0);
return 0;
}
// 扩散效果
cv::Mat Diffusion(cv::Mat src,int size)
{
int row = src.rows;
int col = src.cols;
RNG rng;
cv::Mat result = src.clone();
for (int i = size; i < row- size; ++i)
{
uchar* t = result.ptr<uchar>(i);
for (int j = size; j < col- size; ++j)
{
int tmp = rng.uniform(0, 2*size+1);
t[3 * j] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)));
t[3 * j + 1] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 1);
t[3 * j + 2] = src.at<uchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 2);
}
}
return result;
}
测试效果
图1 原图
图2 5*5扩散
图3 11*11扩散
适当地调整size,可以改变扩散的强度,进而带来不一样的质感。
如果函数有什么可以改进完善的地方,非常欢迎大家指出,一同进步何乐而不为呢~
来源:https://blog.csdn.net/zhaitianbao/article/details/120037764
标签:OpenCV,毛玻璃,扩散
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python闭包装饰器使用方法汇总
2022-12-21 05:47:17
python批量修改xml文件中的信息
2022-03-29 22:50:53
Python3安装pip工具的详细步骤
2021-09-27 15:38:09
![](https://img.aspxhome.com/file/2023/3/72923_0s.png)
Python访问MongoDB,并且转换成Dataframe的方法
2022-07-18 20:32:07
Django实现内容缓存实例方法
2021-04-19 20:47:41
基于python爬取链家二手房信息代码示例
2022-09-01 18:36:25
![](https://img.aspxhome.com/file/2023/5/105085_0s.jpg)
python连接字符串的方法小结
2023-12-29 16:24:49
CentOS6.9 Python环境配置(python2.7、pip、virtualenv)
2022-04-30 14:37:08
八条常见的CSS错误及修复方法
2010-04-08 16:54:00
![](https://img.aspxhome.com/file/UploadPic/20104/8/spec-18s.jpg)
python实现决策树
2021-11-07 19:14:05
如何使用Django Admin管理后台导入CSV
2022-12-28 19:56:52
![](https://img.aspxhome.com/file/2023/5/69635_0s.png)
Python tkinter库图形绘制例子分享
2023-05-29 13:19:51
![](https://img.aspxhome.com/file/2023/4/117414_0s.png)
python生成指定尺寸缩略图的示例
2022-04-14 01:14:49
PHP解析xml格式数据工具类示例
2023-11-19 20:05:53
MySQL如何查询当前正在运行的SQL语句
2009-02-13 13:40:00
关于select元素的两个小问题
2008-12-25 13:41:00
pyecharts如何实现显示数据为百分比的柱状图
2021-06-27 17:11:52
![](https://img.aspxhome.com/file/2023/4/72134_0s.png)
FrontPage2002简明教程七:HTML在FrontPage中的应用
2008-09-17 11:33:00
![](https://img.aspxhome.com/file/UploadPic/200810/17/20081017113624552s.jpg)
python+pygame实现简易五子棋小游戏的三种方式
2023-09-26 06:01:43
![](https://img.aspxhome.com/file/2023/7/97687_0s.png)
Matplotlib中%matplotlib inline如何使用
2021-11-22 15:17:41
![](https://img.aspxhome.com/file/2023/4/89314_0s.png)