




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第OpenCV實(shí)現(xiàn)背景分離(證件照背景替換)我對(duì)比了百度搜索證件照一鍵改色網(wǎng)站的效果,基本一致,它們處理一次4塊錢(qián),我們這是免費(fèi)的,授人以魚(yú)不如授人以漁對(duì)吧,學(xué)到就是賺到。當(dāng)然人家的功能肯定更強(qiáng)大,估計(jì)集成了深度學(xué)習(xí)一類(lèi)的框架,我們還需要調(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)考慮如何只填充這類(lèi)大洞。先將處理圖像的寬高各擴(kuò)展50個(gè)pixel,這樣做的好處是令輪廓的識(shí)別更精準(zhǔn)和清晰,并且避免了頭頂處因貼近圖像邊緣,而導(dǎo)致的過(guò)度膨脹現(xiàn)象。
cv::Mattmask=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):/article/221904.htm)
圖6清除小面積連通區(qū)
5)黑帽運(yùn)算結(jié)果加至原輪廓圖,并截取實(shí)際圖像尺寸。
//黑帽運(yùn)算獲取同背景色類(lèi)似的區(qū)域,識(shí)別后填充
cv::Mathat;
cv::Matelement=getStructuringElement(MORPH_ELLIPSE,Size(31,31));
cv::morphologyEx(tmask,hat,MORPH_BLACKHAT,element);
hat.setTo(255,hat
cv::Mathatd;
//清除小面積區(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)代碼
#includeopencv2/opencv.hpp
#includeiostream
#includealgorithm
#includetime.h
usingnamespacecv;
usingnamespacestd;
//輸入?yún)?shù)
structInputparama{
intthresh=30;//背景識(shí)別閾值,該值越小,則識(shí)別非背景區(qū)面積越大,需有合適范圍,目前為5-60
inttransparency=255;//背景替換色透明度,255為實(shí),0為透明
intsize=7;//非背景區(qū)邊緣虛化參數(shù),該值越大,則邊緣虛化程度越明顯
cv::Pointp=cv::Point(0,0);//背景色采樣點(diǎn),可通過(guò)人機(jī)交互獲取,也可用默認(rèn)(0,0)點(diǎn)顏色作為背景色
cv::Scalarcolor=cv::Scalar(255,255,255);//背景色
cv::MatBackgroundSeparation(cv::Matsrc,Inputparamainput);
voidClear_MicroConnected_Areas(cv::Matsrc,cv::Matdst,doublemin_area);
//計(jì)算差值均方根
intgeiDiff(ucharb,ucharg,ucharr,uchartb,uchartg,uchartr)
returnint(sqrt(((b-tb)*(b-tb)+(g-tg)*(g-tg)+(r-tr)*(r-tr))/3));
intmain()
cv::Matsrc=imread("111.jpg");
Inputparamainput;
input.thresh=100;
input.transparency=255;
input.size=6;
input.color=cv::Scalar(0,0,255);
clock_ts,e;
s=clock();
cv::Matresult=BackgroundSeparation(src,input);
e=clock();
doubledif=e-s;
cout"time:"difendl;
imshow("original",src);
imshow("result",result);
imwrite("result1.png",result);
waitKey(0);
return0;
//背景分離
cv::MatBackgroundSeparation(cv::Matsrc,Inputparamainput)
cv::Matbgra,mask;
//轉(zhuǎn)化為BGRA格式,帶透明度,4通道
cvtColor(src,bgra,COLOR_BGR2BGRA);
mask=cv::Mat::zeros(bgra.size(),CV_8UC1);
introw=src.rows;
intcol=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));
//確定背景色
ucharref_b=src.atVec3b(input.p.y,input.p.x)[0];
ucharref_g=src.atVec3b(input.p.y,input.p.x)[1];
ucharref_r=src.atVec3b(input.p.y,input.p.x)[2];
//計(jì)算蒙版區(qū)域(掩膜)
for(inti=0;irow;++i)
uchar*m=mask.ptruchar
uchar*b=src.ptruchar
for(intj=0;jcol;++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::Mattmask=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)黑洞
vectorvectorPointcontour;
vectorVec4ihierarchy;
//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)算獲取同背景色類(lèi)似的區(qū)域,識(shí)別后填充
cv::Mathat;
cv::Matelement=getStructuringElement(MORPH_ELLIPSE,Size(31,31));
cv::morphologyEx(tmask,hat,MORPH_BLACKHAT,element);
hat.setTo(255,hat
cv::Mathatd;
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(inti=0;irow;++i)
uchar*r=bgra.ptruchar
uchar*m=mask.ptruchar
for(intj=0;jcol;++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ū)),需要虛化處理
elseif(m[j]!=255)
//邊緣處按比例上色
intnewb=(r[4*j]*m[j]*0.3+input.color[0]*(255-m[j])*0.7)/((255-m[j])*0.7+m[j]*0.3);
intnewg=(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);
intnewr=(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);
intnewt=(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;
returnbgra;
voidClear_MicroConnected_Areas(cv::Matsrc,cv::Matdst,doublemin_area)
//備份復(fù)制
dst=src.clone();
std::vectorstd::vectorcv::Pointcontours;//創(chuàng)建輪廓容器
std::vectorcv::Vec4ihierarchy;
//尋找輪廓的函數(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()
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 網(wǎng)絡(luò)游戲虛擬貨幣發(fā)行與游戲角色扮演服務(wù)合同
- 東南亞倉(cāng)儲(chǔ)庫(kù)存盤(pán)點(diǎn)與倉(cāng)儲(chǔ)設(shè)備租賃合同
- 兒童綜合保障計(jì)劃退保服務(wù)協(xié)議
- 游戲美術(shù)資源制作設(shè)計(jì)師勞務(wù)合同
- 互聯(lián)網(wǎng)金融服務(wù)反欺詐補(bǔ)充合同
- 數(shù)字出版物區(qū)域獨(dú)家代理權(quán)轉(zhuǎn)讓合同
- 工業(yè)自動(dòng)化軟件許可及市場(chǎng)推廣合作協(xié)議
- 太陽(yáng)能電池技術(shù)升級(jí)補(bǔ)充協(xié)議
- 跨國(guó)公司員工離職保密協(xié)議及全球競(jìng)業(yè)限制條款
- 保險(xiǎn)業(yè)務(wù)審核補(bǔ)充合同
- 2025屆高考語(yǔ)文復(fù)習(xí):2024年新課標(biāo)二卷第九題說(shuō)題 課件
- 污水管道疏通試題及答案
- 2025年移動(dòng)式壓力容器R2操作證考試筆試試題(200題)附答案
- 造價(jià)咨詢(xún)管理制度體系
- 中馬欽州產(chǎn)業(yè)園管委會(huì)筆試試題
- 2024年農(nóng)藝師新政策解讀試題及答案
- 2025年版中等職業(yè)教育專(zhuān)業(yè)教學(xué)標(biāo)準(zhǔn) 750107 繪畫(huà)
- 應(yīng)急物資使用方法培訓(xùn)
- 坡改梯專(zhuān)項(xiàng)工程施工組織設(shè)計(jì)方案
- 人教版(2024)七年級(jí)下冊(cè)英語(yǔ)UNIT 6 Rain or Shine 綜合素質(zhì)評(píng)價(jià)測(cè)試卷(含答案)
- 建筑工程總承包企業(yè)業(yè)財(cái)一體化應(yīng)用與完善探討
評(píng)論
0/150
提交評(píng)論