OpenCV-PS擴(kuò)散毛玻璃效果的實(shí)現(xiàn)代碼
實(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.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; } // 擴(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.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擴(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)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。