實(shí)現(xiàn)原理
PS的擴(kuò)散效果可以產(chǎn)生類似毛玻璃質(zhì)感的效果,使畫面有些毛毛的感覺。其實(shí)現(xiàn)可通過操作像素三通道數(shù)值的方式實(shí)現(xiàn),定義一個(gè)隨機(jī)數(shù)器,將圖像中任一點(diǎn)的數(shù)值賦值為,以該點(diǎn)為中心一定尺寸窗口(如3*3,5*5)內(nèi)隨機(jī)一個(gè)點(diǎn)的數(shù)值。
功能函數(shù)代碼
// 擴(kuò)散效果
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.ptruchar>(i);
for (int j = size; j col- size; ++j)
{
int tmp = rng.uniform(0, 2*size+1);
t[3 * j] = src.atuchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)));
t[3 * j + 1] = src.atuchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 1);
t[3 * j + 2] = src.atuchar>(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;
}
// 擴(kuò)散效果
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.ptruchar>(i);
for (int j = size; j col- size; ++j)
{
int tmp = rng.uniform(0, 2*size+1);
t[3 * j] = src.atuchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)));
t[3 * j + 1] = src.atuchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 1);
t[3 * j + 2] = src.atuchar>(i - size + tmp / (2 * size + 1), 3 * (j - size + tmp % (2 * size + 1)) + 2);
}
}
return result;
}
測試效果
圖1 原圖
圖2 5*5擴(kuò)散
圖3 11*11擴(kuò)散
適當(dāng)?shù)卣{(diào)整size,可以改變擴(kuò)散的強(qiáng)度,進(jìn)而帶來不一樣的質(zhì)感。
如果函數(shù)有什么可以改進(jìn)完善的地方,非常歡迎大家指出,一同進(jìn)步何樂而不為呢~
到此這篇關(guān)于OpenCV-PS擴(kuò)散毛玻璃效果的文章就介紹到這了,更多相關(guān)OpenCV毛玻璃內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- OpenCV實(shí)現(xiàn)馬賽克和毛玻璃濾鏡效果
- 詳解opencv中畫圓circle函數(shù)和橢圓ellipse函數(shù)
- 使用python-opencv讀取視頻,計(jì)算視頻總幀數(shù)及FPS的實(shí)現(xiàn)
- Eclipse下基于Java的OpenCV開發(fā)環(huán)境配置教程