OpenCV-PS擴散毛玻璃效果的實現(xiàn)代碼
實現(xiàn)原理
PS的擴散效果可以產(chǎn)生類似毛玻璃質(zhì)感的效果,使畫面有些毛毛的感覺。其實現(xiàn)可通過操作像素三通道數(shù)值的方式實現(xiàn),定義一個隨機數(shù)器,將圖像中任一點的數(shù)值賦值為,以該點為中心一定尺寸窗口(如3*3,5*5)內(nèi)隨機一個點的數(shù)值。
功能函數(shù)代碼
// 擴散效果
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擴散
適當(dāng)?shù)卣{(diào)整size,可以改變擴散的強度,進(jìn)而帶來不一樣的質(zhì)感。
如果函數(shù)有什么可以改進(jìn)完善的地方,非常歡迎大家指出,一同進(jìn)步何樂而不為呢~
到此這篇關(guān)于OpenCV-PS擴散毛玻璃效果的文章就介紹到這了,更多相關(guān)OpenCV毛玻璃內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信