溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果

發(fā)布時(shí)間:2021-09-02 13:52:06 來(lái)源:億速云 閱讀:127 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

實(shí)現(xiàn)原理

PS的擴(kuò)散效果可以產(chǎn)生類似毛玻璃質(zhì)感的效果,使畫面有些毛毛的感覺(jué)。其實(shí)現(xiàn)可通過(guò)操作像素三通道數(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++測(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;
}

測(cè)試效果

OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果

圖1 原圖

OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果

圖2 5*5擴(kuò)散

OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果

圖3 11*11擴(kuò)散

適當(dāng)?shù)卣{(diào)整size,可以改變擴(kuò)散的強(qiáng)度,進(jìn)而帶來(lái)不一樣的質(zhì)感。

感謝各位的閱讀!關(guān)于“OpenCV如何實(shí)現(xiàn)PS擴(kuò)散毛玻璃效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI