成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)

OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)

熱門標(biāo)簽:高德地圖標(biāo)注收入咋樣 地圖標(biāo)注多個(gè) 萊蕪電信外呼系統(tǒng) 企業(yè)微信地圖標(biāo)注 銀川電話機(jī)器人電話 沈陽(yáng)防封電銷電話卡 怎么辦理400客服電話 B52系統(tǒng)電梯外呼顯示E7 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)違法嗎

本文主要介紹了OpenCV實(shí)現(xiàn)背景分離(證件照背景替換),具有一定的參考價(jià)值,感興趣的可以了解一下

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

圖像背景分離是常見(jiàn)的圖像處理方法之一,屬于圖像分割范疇。如何較優(yōu)地提取背景區(qū)域,難點(diǎn)在于兩個(gè):

  • 背景和前景的分割。針對(duì)該難點(diǎn),通過(guò)人機(jī)交互等方法獲取背景色作為參考值,結(jié)合差值均方根設(shè)定合理閾值,實(shí)現(xiàn)前景的提取,PS上稱為蒙版;提取過(guò)程中,可能會(huì)遇到前景像素丟失的情況,對(duì)此可通過(guò)開(kāi)閉運(yùn)算或者提取外部輪廓線的方式,將前景內(nèi)部填充完畢。
  • 前景邊緣輪廓區(qū)域的融合。如果不能很好地融合,就能看出明顯的摳圖痕跡,所以融合是很關(guān)鍵的一步。首先,對(duì)蒙版區(qū)(掩膜)進(jìn)行均值濾波,其邊緣區(qū)會(huì)生成介于0-255之間的緩存區(qū);其次,通過(guò)比例分配的方式對(duì)緩存區(qū)的像素點(diǎn)上色,我固定的比例為前景0.3背景0.7,因?yàn)楸尘盀閱紊珔^(qū),背景比例高,可以使得緩存區(qū)顏色傾向于背景區(qū),且實(shí)現(xiàn)較好地過(guò)渡;最后,蒙版為0的區(qū)域上背景色,蒙版為255的區(qū)域不變。

至此,圖像實(shí)現(xiàn)了分割,完成背景分離。C++實(shí)現(xiàn)代碼如下。

功能函數(shù)代碼

// 背景分離
cv::Mat BackgroundSeparation(cv::Mat src, Inputparama input)
{
	cv::Mat bgra, mask;
	// 轉(zhuǎn)化為BGRA格式,帶透明度,4通道
	cvtColor(src, bgra, COLOR_BGR2BGRA);
	mask = cv::Mat::zeros(bgra.size(), CV_8UC1);
	int row = src.rows;
	int col = src.cols;
 
	// 異常數(shù)值修正
	input.p.x = max(0, min(col, input.p.x));
	input.p.y = max(0, min(row, input.p.y));
	input.thresh = max(5, min(100, input.thresh));
	input.transparency = max(0, min(255, input.transparency));
	input.size = max(0, min(30, input.size));
 
	// 確定背景色
	uchar ref_b = src.atVec3b>(input.p.y, input.p.x)[0];
	uchar ref_g = src.atVec3b>(input.p.y, input.p.x)[1];
	uchar ref_r = src.atVec3b>(input.p.y, input.p.x)[2];
 
	// 計(jì)算蒙版區(qū)域(掩膜)
	for (int i = 0; i  row; ++i)
	{
		uchar *m = mask.ptruchar>(i);
		uchar *b = src.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			if ((geiDiff(b[3*j],b[3*j+1],b[3*j+2],ref_b,ref_g,ref_r)) >input.thresh)
			{
				m[j] = 255;
			}
		}
	}
 
	// 尋找輪廓,作用是填充輪廓內(nèi)黑洞
	vectorvectorPoint>> contour;
	vectorVec4i> hierarchy;
	// RETR_TREE以網(wǎng)狀結(jié)構(gòu)提取所有輪廓,CHAIN_APPROX_NONE獲取輪廓的每個(gè)像素
	findContours(mask, contour, hierarchy, RETR_EXTERNAL, CHAIN_APPROX_NONE);
	drawContours(mask, contour, -1, Scalar(255), FILLED,4);
 
	// 閉運(yùn)算
	cv::Mat element = getStructuringElement(MORPH_ELLIPSE, Size(5, 5));
	cv::morphologyEx(mask, mask, MORPH_CLOSE, element);
 
	// 掩膜濾波,是為了邊緣虛化
	cv::blur(mask, mask, Size(2 * input.size+1, 2 * input.size + 1));
 
	// 改色
	for (int i = 0; i  row; ++i)
	{
		uchar *r = bgra.ptruchar>(i);
		uchar *m = mask.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			// 蒙版為0的區(qū)域就是標(biāo)準(zhǔn)背景區(qū)
			if (m[j] == 0)
			{
				r[4 * j] = uchar(input.color[0]);
				r[4 * j + 1] = uchar(input.color[1]);
				r[4 * j + 2] = uchar(input.color[2]);
				r[4 * j + 3] = uchar(input.transparency);
			}
			// 不為0且不為255的區(qū)域是輪廓區(qū)域(邊緣區(qū)),需要虛化處理
			else if (m[j] != 255)
			{
				// 邊緣處按比例上色
				int newb = (r[4 * j] * m[j] * 0.3 + input.color[0] * (255 - m[j])*0.7) / ((255 - m[j])*0.7+ m[j] * 0.3);
				int newg = (r[4 * j+1] * m[j] * 0.3 + input.color[1] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newr = (r[4 * j + 2] * m[j] * 0.3 + input.color[2] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newt = (r[4 * j + 3] * m[j] * 0.3 + input.transparency * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				newb = max(0, min(255, newb));
				newg = max(0, min(255, newg));
				newr = max(0, min(255, newr));
				newt = max(0, min(255, newt));
				r[4 * j] = newb;
				r[4 * j + 1] = newg;
				r[4 * j + 2] = newr;
				r[4 * j + 3] = newt;
			}
		}
	}
	return bgra;
}

C++測(cè)試代碼

#include opencv2/opencv.hpp>
#include iostream>
#include algorithm>
#include time.h>
using namespace cv;
using namespace std;
 
// 輸入?yún)?shù)
struct Inputparama {
	int thresh = 30;                               // 背景識(shí)別閾值,該值越小,則識(shí)別非背景區(qū)面積越大,需有合適范圍,目前為5-60
	int transparency = 255;                        // 背景替換色透明度,255為實(shí),0為透明
	int size = 7;                                  // 非背景區(qū)邊緣虛化參數(shù),該值越大,則邊緣虛化程度越明顯
	cv::Point p = cv::Point(0, 0);                 // 背景色采樣點(diǎn),可通過(guò)人機(jī)交互獲取,也可用默認(rèn)(0,0)點(diǎn)顏色作為背景色
	cv::Scalar color = cv::Scalar(255, 255, 255);  // 背景色
};
 
cv::Mat BackgroundSeparation(cv::Mat src, Inputparama input);
 
// 計(jì)算差值均方根
int geiDiff(uchar b,uchar g,uchar r,uchar tb,uchar tg,uchar tr)
{	
	return  int(sqrt(((b - tb)*(b - tb) + (g - tg)*(g - tg) + (r - tr)*(r - tr))/3));
}
 
int main()
{
	cv::Mat src = imread("111.jpg");
	Inputparama input;
	input.thresh = 100;
	input.transparency = 255;
	input.size = 6;
	input.color = cv::Scalar(0, 0, 255);
 
	clock_t s, e;
	s = clock();
	cv::Mat result = BackgroundSeparation(src, input);
	e = clock();
	double dif = e - s;
	cout  "time:"  dif  endl;
 
	imshow("original", src);
	imshow("result", result);
	imwrite("result1.png", result);
	waitKey(0);
	return 0;
}
 
// 背景分離
cv::Mat BackgroundSeparation(cv::Mat src, Inputparama input)
{
	cv::Mat bgra, mask;
	// 轉(zhuǎn)化為BGRA格式,帶透明度,4通道
	cvtColor(src, bgra, COLOR_BGR2BGRA);
	mask = cv::Mat::zeros(bgra.size(), CV_8UC1);
	int row = src.rows;
	int col = src.cols;
 
	// 異常數(shù)值修正
	input.p.x = max(0, min(col, input.p.x));
	input.p.y = max(0, min(row, input.p.y));
	input.thresh = max(5, min(100, input.thresh));
	input.transparency = max(0, min(255, input.transparency));
	input.size = max(0, min(30, input.size));
 
	// 確定背景色
	uchar ref_b = src.atVec3b>(input.p.y, input.p.x)[0];
	uchar ref_g = src.atVec3b>(input.p.y, input.p.x)[1];
	uchar ref_r = src.atVec3b>(input.p.y, input.p.x)[2];
 
	// 計(jì)算蒙版區(qū)域(掩膜)
	for (int i = 0; i  row; ++i)
	{
		uchar *m = mask.ptruchar>(i);
		uchar *b = src.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			if ((geiDiff(b[3*j],b[3*j+1],b[3*j+2],ref_b,ref_g,ref_r)) >input.thresh)
			{
				m[j] = 255;
			}
		}
	}
 
	// 尋找輪廓,作用是填充輪廓內(nèi)黑洞
	vectorvectorPoint>> contour;
	vectorVec4i> hierarchy;
	// RETR_TREE以網(wǎng)狀結(jié)構(gòu)提取所有輪廓,CHAIN_APPROX_NONE獲取輪廓的每個(gè)像素
	findContours(mask, contour, hierarchy, RETR_EXTERNAL, CHAIN_APPROX_NONE);
	drawContours(mask, contour, -1, Scalar(255), FILLED,4);
 
	// 閉運(yùn)算
	cv::Mat element = getStructuringElement(MORPH_ELLIPSE, Size(5, 5));
	cv::morphologyEx(mask, mask, MORPH_CLOSE, element);
 
	// 掩膜濾波,是為了邊緣虛化
	cv::blur(mask, mask, Size(2 * input.size+1, 2 * input.size + 1));
 
	// 改色
	for (int i = 0; i  row; ++i)
	{
		uchar *r = bgra.ptruchar>(i);
		uchar *m = mask.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			// 蒙版為0的區(qū)域就是標(biāo)準(zhǔn)背景區(qū)
			if (m[j] == 0)
			{
				r[4 * j] = uchar(input.color[0]);
				r[4 * j + 1] = uchar(input.color[1]);
				r[4 * j + 2] = uchar(input.color[2]);
				r[4 * j + 3] = uchar(input.transparency);
			}
			// 不為0且不為255的區(qū)域是輪廓區(qū)域(邊緣區(qū)),需要虛化處理
			else if (m[j] != 255)
			{
				// 邊緣處按比例上色
				int newb = (r[4 * j] * m[j] * 0.3 + input.color[0] * (255 - m[j])*0.7) / ((255 - m[j])*0.7+ m[j] * 0.3);
				int newg = (r[4 * j+1] * m[j] * 0.3 + input.color[1] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newr = (r[4 * j + 2] * m[j] * 0.3 + input.color[2] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newt = (r[4 * j + 3] * m[j] * 0.3 + input.transparency * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				newb = max(0, min(255, newb));
				newg = max(0, min(255, newg));
				newr = max(0, min(255, newr));
				newt = max(0, min(255, newt));
				r[4 * j] = newb;
				r[4 * j + 1] = newg;
				r[4 * j + 2] = newr;
				r[4 * j + 3] = newt;
			}
		}
	}
	return bgra;
}

測(cè)試效果

圖1 原圖和紅底色效果圖對(duì)比

圖2 原圖和藍(lán)底色效果圖對(duì)比

圖3 原圖和透明底色效果圖對(duì)比

如源碼所示,函數(shù)輸入?yún)?shù)共有5項(xiàng),其說(shuō)明如下:

  • thresh為背景識(shí)別閾值,該值范圍為5-100,用來(lái)區(qū)分背景區(qū)和前景區(qū),合理設(shè)置,不然可能出現(xiàn)前景區(qū)大片面積丟失的情況。
  • p為背景色采樣點(diǎn),可通過(guò)人機(jī)交互的方式人為選中背景區(qū)顏色,默認(rèn)為圖像原點(diǎn)的顏色。
  • color為重繪背景色。
  • transparency為重繪背景色的透明度,255為實(shí)色,0為全透明。
  • size為邊緣虛化參數(shù),控制均值濾波的窗口尺寸,范圍為0-30。

我對(duì)比了百度搜索證件照一鍵改色網(wǎng)站的效果,基本一致,它們處理一次4塊錢,我們這是免費(fèi)的,授人以魚(yú)不如授人以漁對(duì)吧,學(xué)到就是賺到。當(dāng)然人家的功能肯定更強(qiáng)大,估計(jì)集成了深度學(xué)習(xí)一類的框架,我們還需要調(diào)參。美中不足的地方就由兄弟們一起改進(jìn)了。

細(xì)心的biliy發(fā)現(xiàn)了我貼圖的問(wèn)題,如圖1圖2圖3所示,領(lǐng)口處被當(dāng)做背景色了,這樣當(dāng)然不行,接下來(lái)開(kāi)始改進(jìn)功能。

1)首先分析原因,之所以領(lǐng)口被當(dāng)做背景色,是因?yàn)轭I(lǐng)口為白色,同背景色一致,且連接圖像邊緣處,進(jìn)行輪廓分析時(shí),錯(cuò)將這個(gè)領(lǐng)口識(shí)別為輪廓外,如圖4所示。

 

圖4 識(shí)別失敗

2)正如圖4所示,僅僅用閉運(yùn)算是無(wú)法有效補(bǔ)償?shù)?,如果將窗口尺寸加大還可能使其他位置過(guò)度填充,接下來(lái)考慮如何只填充這類大洞。先將處理圖像的寬高各擴(kuò)展50個(gè)pixel,這樣做的好處是令輪廓的識(shí)別更精準(zhǔn)和清晰,并且避免了頭頂處因貼近圖像邊緣,而導(dǎo)致的過(guò)度膨脹現(xiàn)象。

cv::Mat tmask = cv::Mat::zeros(row + 50, col + 50, CV_8UC1);
mask.copyTo(tmask(cv::Range(25, 25 + mask.rows), cv::Range(25, 25 + mask.cols)));

3)之后進(jìn)行黑帽運(yùn)算,即閉運(yùn)算減原圖,得到圖5。

 

圖5 黑帽運(yùn)算

4)用Clear_MicroConnected_Area函數(shù)清除小面積連通區(qū),得到圖6。

(該函數(shù)介紹見(jiàn):https://www.jb51.net/article/221904.htm)

 

圖6 清除小面積連通區(qū)

5)黑帽運(yùn)算結(jié)果加至原輪廓圖,并截取實(shí)際圖像尺寸。

// 黑帽運(yùn)算獲取同背景色類似的區(qū)域,識(shí)別后填充
cv::Mat hat;
cv::Mat element = getStructuringElement(MORPH_ELLIPSE, Size(31, 31));
cv::morphologyEx(tmask, hat, MORPH_BLACKHAT, element);
hat.setTo(255, hat > 0);
cv::Mat hatd;
// 清除小面積區(qū)域
Clear_MicroConnected_Areas(hat, hatd, 450);
tmask = tmask + hatd;
// 截取實(shí)際尺寸
mask = tmask(cv::Range(25, 25 + mask.rows), cv::Range(25, 25 + mask.cols)).clone();

6)至此,就得到完整的輪廓了,如圖7所示,完整代碼見(jiàn)后方。

 

圖7 完整輪廓圖

完整改進(jìn)代碼

#include opencv2/opencv.hpp>
#include iostream>
#include algorithm>
#include time.h>
using namespace cv;
using namespace std;
 
// 輸入?yún)?shù)
struct Inputparama {
	int thresh = 30;                               // 背景識(shí)別閾值,該值越小,則識(shí)別非背景區(qū)面積越大,需有合適范圍,目前為5-60
	int transparency = 255;                        // 背景替換色透明度,255為實(shí),0為透明
	int size = 7;                                  // 非背景區(qū)邊緣虛化參數(shù),該值越大,則邊緣虛化程度越明顯
	cv::Point p = cv::Point(0, 0);                 // 背景色采樣點(diǎn),可通過(guò)人機(jī)交互獲取,也可用默認(rèn)(0,0)點(diǎn)顏色作為背景色
	cv::Scalar color = cv::Scalar(255, 255, 255);  // 背景色
};
 
cv::Mat BackgroundSeparation(cv::Mat src, Inputparama input);
void Clear_MicroConnected_Areas(cv::Mat src, cv::Mat dst, double min_area);
 
// 計(jì)算差值均方根
int geiDiff(uchar b,uchar g,uchar r,uchar tb,uchar tg,uchar tr)
{	
	return  int(sqrt(((b - tb)*(b - tb) + (g - tg)*(g - tg) + (r - tr)*(r - tr))/3));
}
 
int main()
{
	cv::Mat src = imread("111.jpg");
	Inputparama input;
	input.thresh = 100;
	input.transparency = 255;
	input.size = 6;
	input.color = cv::Scalar(0, 0, 255);
 
	clock_t s, e;
	s = clock();
	cv::Mat result = BackgroundSeparation(src, input);
	e = clock();
	double dif = e - s;
	cout  "time:"  dif  endl;
 
	imshow("original", src);
	imshow("result", result);
	imwrite("result1.png", result);
	waitKey(0);
	return 0;
}
 
// 背景分離
cv::Mat BackgroundSeparation(cv::Mat src, Inputparama input)
{
	cv::Mat bgra, mask;
	// 轉(zhuǎn)化為BGRA格式,帶透明度,4通道
	cvtColor(src, bgra, COLOR_BGR2BGRA);
	mask = cv::Mat::zeros(bgra.size(), CV_8UC1);
	int row = src.rows;
	int col = src.cols;
 
	// 異常數(shù)值修正
	input.p.x = max(0, min(col, input.p.x));
	input.p.y = max(0, min(row, input.p.y));
	input.thresh = max(5, min(200, input.thresh));
	input.transparency = max(0, min(255, input.transparency));
	input.size = max(0, min(30, input.size));
 
	// 確定背景色
	uchar ref_b = src.atVec3b>(input.p.y, input.p.x)[0];
	uchar ref_g = src.atVec3b>(input.p.y, input.p.x)[1];
	uchar ref_r = src.atVec3b>(input.p.y, input.p.x)[2];
 
	// 計(jì)算蒙版區(qū)域(掩膜)
	for (int i = 0; i  row; ++i)
	{
		uchar *m = mask.ptruchar>(i);
		uchar *b = src.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			if ((geiDiff(b[3*j],b[3*j+1],b[3*j+2],ref_b,ref_g,ref_r)) >input.thresh)
			{
				m[j] = 255;
			}
		}
	}
 
	cv::Mat tmask = cv::Mat::zeros(row + 50, col + 50, CV_8UC1);
	mask.copyTo(tmask(cv::Range(25, 25 + mask.rows), cv::Range(25, 25 + mask.cols)));
 
	// 尋找輪廓,作用是填充輪廓內(nèi)黑洞
	vectorvectorPoint>> contour;
	vectorVec4i> hierarchy;
	// RETR_TREE以網(wǎng)狀結(jié)構(gòu)提取所有輪廓,CHAIN_APPROX_NONE獲取輪廓的每個(gè)像素
	findContours(tmask, contour, hierarchy, RETR_EXTERNAL, CHAIN_APPROX_NONE);
	drawContours(tmask, contour, -1, Scalar(255), FILLED,16);
 
	// 黑帽運(yùn)算獲取同背景色類似的區(qū)域,識(shí)別后填充
	cv::Mat hat;
	cv::Mat element = getStructuringElement(MORPH_ELLIPSE, Size(31, 31));
	cv::morphologyEx(tmask, hat, MORPH_BLACKHAT, element);
	hat.setTo(255, hat > 0);
	cv::Mat hatd;
	Clear_MicroConnected_Areas(hat, hatd, 450);
	tmask = tmask + hatd;
	mask = tmask(cv::Range(25, 25 + mask.rows), cv::Range(25, 25 + mask.cols)).clone();
 
	// 掩膜濾波,是為了邊緣虛化
	cv::blur(mask, mask, Size(2 * input.size+1, 2 * input.size + 1));
 
	// 改色
	for (int i = 0; i  row; ++i)
	{
		uchar *r = bgra.ptruchar>(i);
		uchar *m = mask.ptruchar>(i);
		for (int j = 0; j  col; ++j)
		{
			// 蒙版為0的區(qū)域就是標(biāo)準(zhǔn)背景區(qū)
			if (m[j] == 0)
			{
				r[4 * j] = uchar(input.color[0]);
				r[4 * j + 1] = uchar(input.color[1]);
				r[4 * j + 2] = uchar(input.color[2]);
				r[4 * j + 3] = uchar(input.transparency);
			}
			// 不為0且不為255的區(qū)域是輪廓區(qū)域(邊緣區(qū)),需要虛化處理
			else if (m[j] != 255)
			{
				// 邊緣處按比例上色
				int newb = (r[4 * j] * m[j] * 0.3 + input.color[0] * (255 - m[j])*0.7) / ((255 - m[j])*0.7+ m[j] * 0.3);
				int newg = (r[4 * j+1] * m[j] * 0.3 + input.color[1] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newr = (r[4 * j + 2] * m[j] * 0.3 + input.color[2] * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				int newt = (r[4 * j + 3] * m[j] * 0.3 + input.transparency * (255 - m[j])*0.7) / ((255 - m[j])*0.7 + m[j] * 0.3);
				newb = max(0, min(255, newb));
				newg = max(0, min(255, newg));
				newr = max(0, min(255, newr));
				newt = max(0, min(255, newt));
				r[4 * j] = newb;
				r[4 * j + 1] = newg;
				r[4 * j + 2] = newr;
				r[4 * j + 3] = newt;
			}
		}
	}
	return bgra;
}
 
void Clear_MicroConnected_Areas(cv::Mat src, cv::Mat dst, double min_area)
{
	// 備份復(fù)制
	dst = src.clone();
	std::vectorstd::vectorcv::Point> > contours;  // 創(chuàng)建輪廓容器
	std::vectorcv::Vec4i> 	hierarchy;
 
	// 尋找輪廓的函數(shù)
	// 第四個(gè)參數(shù)CV_RETR_EXTERNAL,表示尋找最外圍輪廓
	// 第五個(gè)參數(shù)CV_CHAIN_APPROX_NONE,表示保存物體邊界上所有連續(xù)的輪廓點(diǎn)到contours向量?jī)?nèi)
	cv::findContours(src, contours, hierarchy, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_NONE, cv::Point());
 
	if (!contours.empty()  !hierarchy.empty())
	{
		std::vectorstd::vectorcv::Point> >::const_iterator itc = contours.begin();
		// 遍歷所有輪廓
		while (itc != contours.end())
		{
			// 定位當(dāng)前輪廓所在位置
			cv::Rect rect = cv::boundingRect(cv::Mat(*itc));
			// contourArea函數(shù)計(jì)算連通區(qū)面積
			double area = contourArea(*itc);
			// 若面積小于設(shè)置的閾值
			if (area  min_area)
			{
				// 遍歷輪廓所在位置所有像素點(diǎn)
				for (int i = rect.y; i  rect.y + rect.height; i++)
				{
					uchar *output_data = dst.ptruchar>(i);
					for (int j = rect.x; j  rect.x + rect.width; j++)
					{
						// 將連通區(qū)的值置0
						if (output_data[j] == 255)
						{
							output_data[j] = 0;
						}
					}
				}
			}
			itc++;
		}
	}
}

改進(jìn)效果

圖8 原圖與紅底對(duì)比圖

圖9 原圖與藍(lán)底對(duì)比圖

圖10 原圖與透明底對(duì)比圖

到此這篇關(guān)于OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)的文章就介紹到這了,更多相關(guān)OpenCV 背景分離內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Opencv實(shí)現(xiàn)摳圖背景圖替換功能
  • 基于OpenCV python3實(shí)現(xiàn)證件照換背景的方法
  • Python + opencv對(duì)拍照得到的圖片進(jìn)行背景去除的實(shí)現(xiàn)方法
  • python3基于OpenCV實(shí)現(xiàn)證件照背景替換
  • opencv3/C++實(shí)現(xiàn)視頻背景去除建模(BSM)
  • 用opencv給圖片換背景色的示例代碼

標(biāo)簽:三亞 湘西 安慶 呼倫貝爾 銀川 烏魯木齊 呼倫貝爾 葫蘆島

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)》,本文關(guān)鍵詞  OpenCV,實(shí)現(xiàn),背景,分離,證件,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    美女写真理伦片在线看| 天天做天天摸天天爽国产一区| 欧美日韩亚洲国产| 国产精品美女网站| xxxxx性| 日韩精品视频中文在线观看| 最新日本中文字幕| 色一情一乱一伦一区二区三区丨| 26uuu另类亚洲欧美日本老年| av无码久久久久久不卡网站| 国产精品自拍视频在线| 国产95在线|亚洲| 成人激情视频在线观看| 亚洲欧美日韩成人高清在线一区| 91精品国产一区二区| 国产乱淫片视频| 1024视频在线| 成人亚洲欧美日韩在线观看| 亚洲国产av一区二区三区| 东方伊人免费在线观看| 九九九热视频| 色呦呦网站在线观看| 99热这里只有精品8| 中文字幕亚洲一区| 91黄色国产视频| 亚洲精品小说| 亚洲国产高清一区二区三区| 粗大的内捧猛烈进出在线视频| 欧美日韩看看2015永久免费| www.色就是色.com| 国产精品自在自线| 波多野结衣久草一区| 亚洲精品中文字幕成人片| 日韩人妻精品中文字幕| 日韩伦理精品| www.8ⅹ8ⅹ羞羞漫画在线看| 五月激激激综合网色播| 99国产高清| 欧美日韩精品区别| 国产欧美日韩综合精品一区二区三区| 欧美性色黄大片手机版| 成年免费视频| 精品国产一区二区三区香蕉沈先生| 亚洲综合av影视| 中文字幕第一页久久| 午夜精品一区二区三区免费视频| 97中文在线观看| 欧美午夜视频一区二区| 国产suv精品一区二区69| 自拍偷拍亚洲图片| 亚洲免费视频在线观看| 另类视频一区二区三区| 国产美女无遮挡永久免费| 欧美成人性福生活免费看| 亚洲另类春色国产| 88国产精品视频一区二区三区| 日本免费一区二区三区四区| 成人在线免费观看一区| 在线视频毛片| 国产av不卡一区二区| 亚洲福利一区二区| 白虎精品一区| 国产午夜福利精品| 欧美在线视频精品| 久久亚洲精品一区| 人人爽人人爽人人片av| 中文字幕+乱码+中文乱码91| baoyu135国产精品免费| 亚洲不卡中文字幕无码| 欧美性极品xxxx娇小| 精品伦理精品一区| 日韩精品久久久久| 水莓100在线视频| 制服丝袜中文字幕一区| 国产精品18在线| 中文字幕在线观看不卡视频| 日韩精品中文字幕一区二区三区| 一区二区日本| 国产在线www| 羞羞小视频视频| 欧美视频在线观看免费| 一区二区久久精品66国产精品| 77777亚洲午夜久久多人| 日本搞黄视频| 日本高清免费在线视频| 无码免费一区二区三区免费播放| 在线一级视频| 欧美深性狂猛ⅹxxx深喉| 成人免费视频网| 3dmax动漫人物在线看| 欧美无遮挡国产欧美另类| 手机在线免费av| 久草视频视频在线播放| www.啪啪.com| 精品资源在线看| 一级做a爰片久久毛片美女图片| 久久日免费视频| 久久久精品国产亚洲| 欧美精品1区2区| 美女999久久久精品视频| 免费在线黄色电影| 粉嫩小泬无遮挡久久久久久| 精品乱人伦小说| 日韩影视高清在线观看| 亚洲成人最新网站| 国产伦精品一区二区三区视频小说| 国产人妻人伦精品| 日操夜操天天操| 久久久久亚洲av无码麻豆| 一区二区三区免费播放| 日韩丰满少妇无码内射| 97在线播放视频| 精品剧情v国产在线观看在线| 国产国产一区| 久草资源在线视频| 午夜精品久久久久久久99热浪潮| 91久久国产精品| 成年人深夜福利| 日韩毛片在线一区二区毛片| 国产91在线观看丝袜| 欧美大片在线观看| 日本在线一区二区| 手机在线观看毛片| 国产精品午夜免费| 一本久久精品| 午夜av一区二区| 日本一二三区视频| 国产精品亚洲综合久久小说| 日韩欧美主播在线| 亚洲最大成人综合| 亚洲欧美日韩在线观看a三区| 色妞色视频一区二区三区四区| www.av欧美| 色中文字幕在线| 在线观看视频色| 亚洲一级少妇| 国产高清免费在线播放| 久久69精品久久久久久久电影好| 国产1卡2卡三卡四卡网站| 另类小说视频一区二区| 成人黄色一区二区| 色棕色天天综合网| 又黄又爽的视频在线观看| 福利一区二区三区四区| av天堂一区二区| 亚洲精品日韩激情在线电影| av中文字幕亚洲| 一区二区三区四区视频| av电影在线免费观看| 鲁大师成人一区二区三区| 疯狂做受xxxx高潮欧美日本| 日韩中文字幕免费| 182在线观看视频| 色偷偷色偷偷色偷偷在线视频| 最近中文字幕无免费| 久久久久久亚洲中文字幕无码| 国产精品入口麻豆免费| 开心九九激情九九欧美日韩精美视频电影| 亚洲第一福利视频在线| 一区二区三区国产| 国产精品久久久久久影院8一贰佰| 亚洲人成影院77777| 黄色一区二区在线| 日本免费精品| 中文字幕av免费| 亚洲日本一区二区三区在线不卡| 久久精子c满五个校花| 一区二区三区视频在线观看免费| 欧美成人3dxxxx| 免费观看视频www| 国产成人精品一区二区三区免费| 呻吟揉丰满对白91乃国产区| 青青国产精品| 久久福利一区二区| 你懂的免费在线观看视频网站| 久久久久99精品成人片三人毛片| 国产成人综合亚洲网站| 日本粉色视频在线观看| 日韩在线观看不卡| 国产成人免费av在线| 中文字幕亚洲欧美日韩在线不卡| 亚洲h动漫在线| 实拍女处破www免费看| www.18av.com| 精品999日本| 最新中文字幕2018| 中文字幕99页| 中文字幕欧美区| 97超碰国产精品| 成人网av.com/| 免费xxxxx网站中文字幕| 国产有码在线一区二区视频| 日韩av在线播放不卡| 国产在线播放你懂的| 成人免费在线观看网站| www午夜视频| 日本人视频jizz页码69| 一二三区视频在线观看| 天堂va欧美ⅴa亚洲va一国产| 自拍视频网站| 麻豆影视在线观看_| 精品中文字幕在线2019| 免费av在线网站| 亚洲一二三在线| www.欧美色| 久久精品免费一区二区三区| 波多野结衣家庭教师视频| 免费网站成人| 日韩一级精品视频在线观看| 日韩欧美国产1| 欧美一区二区在线视频观看| 这里只有精品在线播放| 日本一级黄色录像| 97国产suv精品一区二区62| 99热99这里只有精品| 91av在线不卡| 日日干天天干| 五月开心播播网| 一区二区在线电影| 中文字幕av久久爽av| 久久久久久久伊人| 欧美熟妇另类久久久久久多毛| 在线观看免费视频污| 日韩三级一区| 91精品国产乱码久久久久| 呻吟揉丰满对白91乃国产区| 亚洲爱爱综合网| 午夜性色福利影院| 一区二区三区一级片| 香蕉久久久久久久| 欧美三区免费完整视频在线观看| 国内精品写真在线观看| 国产精品作爱| 婷婷色在线视频| 91精品久久久久久久久99蜜臂| 国产丝袜在线观看视频| 欧美伊久线香蕉线新在线| 国产精品一区二区中文字幕| 国产一区二区三区久久久| 在线一区二区三区四区| hs网站在线观看| 国产日韩欧美一区二区三区乱码| 午夜激情在线观看视频| 日本aⅴ大伊香蕉精品视频| 青娱乐精品在线| 欧美在线精品一区二区三区| 操你啦在线视频| 亚洲欧美www| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 午夜视频在线观看一区| 99视频资源网| 国产视频一区二区不卡| 亚洲精品少妇网址| 日本一二三区在线视频| 亚洲国产日韩欧美一区二区三区| 午夜国产精品视频免费体验区| 中文字幕精品—区二区日日骚| 妞干网在线播放| 青青青伊人色综合久久| 91九色蝌蚪91por成人| 丰满大乳奶做爰ⅹxx视频| 国产高清在线观看| 2019日韩中文字幕mv| 日韩欧美一区免费| 91成年人视频| 免费在线看污片| 老司机亚洲精品一区二区| 亚洲精品国产一区| 在线综合亚洲欧美在线视频| 欧美日韩精品一区二区天天拍小说| 日韩av影视综合网| 日韩中文字幕观看| 香蕉视频一区| 草莓污污视频在线观看| 国产伦精品一区二区三区视频青涩| 久久男人资源视频| 久久久久久91亚洲精品中文字幕| 欧美日本三区| 国产精品久久久久久av下载红粉| 91精品国产色综合久久不卡蜜臀| 成人久久综合| 1024精品久久久久久久久| 天堂av中文在线观看| 成人免费毛片a| 七七成人影院| 日本一级理论片在线大全| 亚洲成人av观看| 欧美激情免费视频| 国产精品一区二区三区四| 国产主播中文字幕| 国产精品情侣呻吟对白视频| 在线观看中文字幕2021| 欧美xxxbbb| 国产伦精品一区二区三区免| 亚洲小说区图片| 狠狠躁夜夜躁人人躁婷婷91| 日本特黄特色aaa大片免费| 亚洲国产精品影视| 国产无遮挡裸体免费视频| 拔插拔插海外华人免费| 日韩av手机在线播放| 亚洲精选在线观看| 久久精品国产2020观看福利| 欧美大片免费观看网址| 国产精品久久国产三级国电话系列| 91理论电影在线观看| 欧美日韩国内自拍| 欧洲成人午夜精品无码区久久| 欧美日韩激情视频一区二区三区| 欧美日韩性生活片| 四虎影院成人| 石原莉奈一区二区三区高清在线| 992kp快乐看片永久免费网址| 亚洲电影影音先锋| 国产一区二区在线免费| 久久久精品国产sm调教网站| v天堂中文在线| 日本三级电影在线看| 久久男女视频| 免费国产自线拍一欧美视频| av亚洲精华国产精华精华| 午夜久久tv| 狂野欧美性猛交xxxx乱大交| 久久精品久久久久电影| 麻豆freexxxx性91精品| 艳妇乳肉豪妇荡乳av无码福利| 女女色综合影院| 特级丰满少妇一级|