溫馨提示×

溫馨提示×

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

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

C++?OpenCV如何實現(xiàn)圖像修復(fù)功能

發(fā)布時間:2022-01-10 16:10:47 來源:億速云 閱讀:246 作者:柒染 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)C++ OpenCV如何實現(xiàn)圖像修復(fù)功能,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

前言

下面將使用OpenCV C++ 對有瑕疵的圖像進(jìn)行修復(fù)。OpenCV 提供了inpaint API可進(jìn)行圖像修復(fù)。

一、OpenCV inpaint

C++?OpenCV如何實現(xiàn)圖像修復(fù)功能

原圖如圖所示。本案例的需求是希望能夠?qū)D像上的紅線給消除。OpenCV 提供的inpaint API能夠?qū)崿F(xiàn)這個效果。

void inpaint(

InputArray src, 原圖

InputArray inpaintMask, 二進(jìn)制掩模,指示要修復(fù)的像素

OutputArray dst, 目標(biāo)圖像

double inpaintRadius, 像素周圍的鄰域補(bǔ)繪。通常,如果要修復(fù)的區(qū)域很小,則使用較小的值僅產(chǎn)生較少模糊

int flags INPAINT_NS 或 INPAINT_TELEA

)

使用這個API最重要的就是生成一張二進(jìn)制掩模圖像(要修復(fù)的地方)。我們可以使用鼠標(biāo)響應(yīng)事件完成。

	//使用鼠標(biāo)響應(yīng)事件在 inpaintMask 繪制掩模,用于圖片修復(fù)
	if (event == EVENT_LBUTTONUP || !(flags & EVENT_FLAG_LBUTTON))
	{
		prevPt = Point(-1, -1);
	}
	else if (event == EVENT_LBUTTONDOWN)
	{
		prevPt = Point(x, y);
	}
	else if (event == EVENT_MOUSEMOVE && (flags & EVENT_FLAG_LBUTTON))
	{
		prevPt = Point(x, y);
		//繪制掩模圖像
		circle(inpaintMask, prevPt, 2, Scalar::all(255), -1);
		//imshow("inpaintMask", inpaintMask);

		//圖像修復(fù)
		Mat result;
		inpaint(src, inpaintMask, result, 1, INPAINT_NS);
		//imshow("image", result);
	}

C++?OpenCV如何實現(xiàn)圖像修復(fù)功能

如圖為掩模圖像,接下來使用inpaint就可以對圖像進(jìn)行修復(fù)了。

二、源碼

#include <iostream>
#include<opencv2/opencv.hpp>
#include<opencv2/photo.hpp>
using namespace cv;
using namespace std;

/*
void inpaint(
		InputArray src,   原圖
		InputArray inpaintMask, 二進(jìn)制掩模,指示要修復(fù)的像素
		OutputArray dst,  目標(biāo)圖像
		double inpaintRadius, 像素周圍的鄰域補(bǔ)繪。通常,如果要修復(fù)的區(qū)域很小,則使用較小的值僅產(chǎn)生較少模糊
		int flags     INPAINT_NS  或 INPAINT_TELEA
		)
*/


Mat src, inpaintMask;
Point prevPt(-1, -1);

static void onMouse(int event, int x, int y, int flags, void*)
{
	//使用鼠標(biāo)響應(yīng)事件在 inpaintMask 繪制掩模,用于圖片修復(fù)
	if (event == EVENT_LBUTTONUP || !(flags & EVENT_FLAG_LBUTTON))
	{
		prevPt = Point(-1, -1);
	}
	else if (event == EVENT_LBUTTONDOWN)
	{
		prevPt = Point(x, y);
	}
	else if (event == EVENT_MOUSEMOVE && (flags & EVENT_FLAG_LBUTTON))
	{
		prevPt = Point(x, y);

		//繪制掩模圖像
		circle(inpaintMask, prevPt, 2, Scalar::all(255), -1);
		//imshow("inpaintMask", inpaintMask);

		//圖像修復(fù)
		Mat result;
		inpaint(src, inpaintMask, result, 1, INPAINT_NS);
		//imshow("image", result);
	}
}


int main()
{
	src = imread("girl.jpg");
	
	if (src.empty())
	{
		cout << "No Image!" << endl;
		system("pause");
		return -1;
	}

	namedWindow("image", WINDOW_AUTOSIZE);
	imshow("image", src);

	inpaintMask = Mat::zeros(src.size(), CV_8U);  //二進(jìn)制掩模,指示要修復(fù)的像素
	setMouseCallback("image", onMouse, NULL);

	waitKey(0);
	destroyAllWindows();
	system("pause");
	return 0;	
}

三、效果顯示

C++?OpenCV如何實現(xiàn)圖像修復(fù)功能

如圖為使用inpaint修復(fù)的效果,可以看出基本上將瑕疵都給去掉了。

以上就是C++ OpenCV如何實現(xiàn)圖像修復(fù)功能,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

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

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

AI