



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第OpenCV圖像算法實(shí)現(xiàn)圖像切分圖像合并示例目錄將一張圖片切分成多個(gè)小圖片并將小圖片合并為原圖圖像切分圖像合并驗(yàn)證友情提示
將一張圖片切分成多個(gè)小圖片并將小圖片合并為原圖
最近用到一個(gè)功能,需要將一張?jiān)瓐D切分成多個(gè)小圖像,然后對(duì)小圖像進(jìn)行處理,處理之后再將其整合成一張大圖像。達(dá)到對(duì)原圖進(jìn)行處理的目的,這樣做的好處是將一個(gè)大任務(wù)劃分為多個(gè)小任務(wù),分別進(jìn)行處理以節(jié)約時(shí)間(當(dāng)然需要多線程進(jìn)行協(xié)助,效果才會(huì)更明顯)。
下面,就以2個(gè)模塊進(jìn)行介紹
圖像切分
/*
圖像切分(我是按列進(jìn)行切分的,按照行也是同樣的原理。亦或是按塊)
核心代碼如下:
//用于存儲(chǔ)切分后的小圖像
vectorMatimgs;
//src:待切分原圖像splitCols:切分的每個(gè)小圖像列數(shù)
voidimgSplit(Matsrc,intsplitCols)
//設(shè)置分割后圖像存儲(chǔ)路徑
stringoutpath=".\\split\\";
intcol=src.cols,row=src.rows;
//切分后圖像數(shù)量
intsum=0;
//被整除
if((col%num==0))
sum=col/num;
//迭代器ceil_img存儲(chǔ)子圖像
//vectorMatceil_img;
//迭代器name存儲(chǔ)子圖像的名字,從0到m*n-1
vectorintname;
for(inti=0;isum;i++)
name.push_back(i);
Matimage_cut,roi_img,tim_img;
//存儲(chǔ)完整圖像
for(inti=0;isum;i++)
Rectrect(i*num,0,num,row);
image_cut=Mat(src,rect);
roi_img=image_cut.clone();
imgs.push_back(roi_img);
//寫(xiě)入到指定文件夾
for(inti=0;isum;i++)
imwrite(outpath+to_string(longlong((name[i])))+".jpg",imgs[i]);
else//不能整除
sum=col/num+1;
//迭代器ceil_img存儲(chǔ)子圖像
//vectorMatceil_img;
//迭代器name存儲(chǔ)子圖像的名字,從0到m*n-1
vectorintname;
for(inti=0;isum;i++)
name.push_back(i);
Matimage_cut,roi_img,tim_img;
//存儲(chǔ)完整圖像
for(inti=0;isum-1;i++)
Rectrect(i*num,0,num,row);
image_cut=Mat(src,rect);
roi_img=image_cut.clone();
imgs.push_back(roi_img);
//留余圖像(因?yàn)橛袝r(shí)候原圖像總列數(shù)不能被整除,但又不能有損原圖)
Rectrect((sum-1)*num,0,col%num,row);
image_cut=Mat(src,rect);
roi_img=image_cut.clone();
imgs.push_back(roi_img);
//寫(xiě)入到指定文件夾
for(inti=0;isum;i++)
imwrite(outpath+to_string(longlong((name[i])))+".jpg",imgs[i]);
圖像合并
/*
只要學(xué)會(huì)合并兩幅圖像,那么多幅圖像合并就不在話下了
//按列合并兩幅圖像
MatmergeCols(Matsrc1,Matsrc2)
inttotalCols=src1.cols+src2.cols;
Matdst(src1.rows,totalCols,src1.type());
Matsubmat=dst.colRange(0,src1.cols);
src1.copyTo(submat);
submat=dst.colRange(src1.cols,totalCols);
src2.copyTo(submat);
returndst;
//多幅圖像合并
voidimgMerge()
intimgSum=imgs.size();
Matdst=imgs[0];
for(inti=1;iimgSum;i++)
dst=mergeCols(dst,imgs[i]);
驗(yàn)證
執(zhí)行下面代碼可以驗(yàn)證(當(dāng)然,你要根據(jù)自己的需求進(jìn)行個(gè)別修改,比如切分后圖像保存路徑這些細(xì)節(jié))
voidsplit_mergeRun()
Matsrc=imread("img.jpg");
imgSplit(src,100);
imgMerge();
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 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ì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年幼兒園小班上學(xué)期班務(wù)總結(jié)模版
- 主播簡(jiǎn)約合同范例
- 創(chuàng)新型醫(yī)療器械的臨床試驗(yàn)設(shè)計(jì)
- 供貨安裝安全合同樣本
- 醫(yī)療保健領(lǐng)域中區(qū)塊鏈UI的改進(jìn)方案
- 供貨擔(dān)保合同范例
- 公司委托經(jīng)營(yíng)代理合同范例
- 醫(yī)療倫理醫(yī)護(hù)人員在緊急情況下的責(zé)任與擔(dān)當(dāng)
- 醫(yī)療物聯(lián)網(wǎng)IoT中區(qū)塊鏈技術(shù)的隱私保護(hù)探討
- 公共廁所看管合同范例
- 山西省部分重點(diǎn)中學(xué)2024-2025學(xué)年高三4月模擬檢測(cè)語(yǔ)文試題(含答案)
- 2024年生物醫(yī)學(xué)工程試題及答案
- 2025年全國(guó)防災(zāi)減災(zāi)日(5.12)應(yīng)知應(yīng)會(huì)知識(shí)測(cè)試競(jìng)賽題庫(kù)與答案
- 六年級(jí)家長(zhǎng)會(huì)心理教育專題課件
- 四川宜賓環(huán)球集團(tuán)有限公司招聘筆試題庫(kù)2025
- 如何設(shè)計(jì)高質(zhì)量的課件:制作教學(xué)指南
- 2025年農(nóng)村商業(yè)銀行人員招聘考試筆試試題(含答案)
- 2025年江蘇省新高考高三聯(lián)考數(shù)學(xué)試卷試題(含答案詳解)
- 2025年江蘇省蘇州市昆山八校聯(lián)考中考零模英語(yǔ)試題(原卷版+解析版)
- 生物技術(shù)與生物醫(yī)藥產(chǎn)業(yè)發(fā)展趨勢(shì)分析
- 工程第一次監(jiān)理例會(huì)會(huì)議紀(jì)要
評(píng)論
0/150
提交評(píng)論