




下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第Python實(shí)現(xiàn)多張圖片合成一張馬賽克圖片目錄前言開(kāi)發(fā)環(huán)境實(shí)現(xiàn)代碼先導(dǎo)入所需模塊讀取圖片文件讀取所有源圖片并計(jì)算對(duì)應(yīng)顏色平均值合法圖像列表平均顏色列表遍歷主函數(shù)模塊調(diào)用執(zhí)行完整效果
前言
最近有網(wǎng)友私信我,問(wèn)如何把多張圖片合成一張馬賽克圖片的樣子
說(shuō)是女兒從出生到現(xiàn)在,所有的照片,大概有上百?gòu)垼韵胧褂眠@些照片合成一張,當(dāng)做生日禮物
那我們今天就用上次爬表情包的圖片來(lái)做一次馬賽克圖片,2萬(wàn)張合成一張,想想就很激動(dòng)
圖片素材
4K高清原圖
開(kāi)發(fā)環(huán)境
Python3.6
Pycharm
實(shí)現(xiàn)代碼
先導(dǎo)入所需模塊
importcv2
importglob
importargparse
importnumpyasnp
fromtqdmimporttqdm#進(jìn)度條
fromitertoolsimportproduct#迭代器
讀取圖片文件
defparsArgs():
parser=argparse.ArgumentParser('拼接馬賽克圖片')
parser.add_argument('--targetpath',type=str,default='examples/3.jpg',help='目標(biāo)圖像路徑')
parser.add_argument('--outputpath',type=str,default='output.jpg',help='輸出圖像的路徑')
parser.add_argument('--sourcepath',type=str,default='sourceimages',help='用來(lái)拼接圖像的所有源圖像文件路徑')
parser.add_argument('--blocksize',type=int,default=15,help='馬賽克快的大小')
args=parser.parse_args()
returnargs
讀取所有源圖片并計(jì)算對(duì)應(yīng)顏色平均值
defreadSourceImages(sourcepath,blocksize):
print('開(kāi)始讀取圖像')
合法圖像列表
設(shè)置一個(gè)列表,存放符合要求的顏色圖像
sourceimages=[]
平均顏色列表
avgcolors=[]
遍歷
每遍歷一次,進(jìn)度條走一次
forpathintqdm(glob.glob("{}/*.jpg".format(sourcepath))):
image=cv2.imread(path,cv2.IMREAD_COLOR)
ifimage.shape[-1]!=3:
continue
#縮放尺寸
image=cv2.resize(image,(blocksize,blocksize))
#圖像顏色平均值
avgcolor=np.sum(np.sum(image,axis=0),axis=0)/(blocksize*blocksize)
sourceimages.append(image)
avgcolors.append(avgcolor)
print('結(jié)束讀取')
returnsourceimages,np.array(avgcolors)
主函數(shù)
defmain(args):
targetimage=cv2.imread(args.targetpath)
outputimage=np.zeros(targetimage.shape,np.uint8)#int8int16int32int64
sourceimages,avgcolors=readSourceImages(args.sourcepath,args.blocksize)
print('開(kāi)始制作')
fori,jintqdm(product(range(int(targetimage.shape[1]/args.blocksize)),range(int(targetimage.shape[0]/args.blocksize)))):
block=targetimage[j*args.blocksize:(j+1)*args.blocksize,i*args.blocksize:(i+1)*args.blocksize,:]
avgcolor=np.sum(np.sum(block,axis=0),axis=0)/(args.blocksize*args.blocksize)
distances=np.linalg.norm(avgcolor-avgcolors,axis=1)
idx=np.argmin(distances)
outputimage[j*args.blocksize:(j+1)*args.blocksize,i*args.blocksize:(i+1)*args.blocksize,:]=\
sourceimages[idx]
cv2.imwrite(args.outputpath,outputimage)
cv2.im
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 運(yùn)營(yíng)咨詢顧問(wèn)合同協(xié)議
- 月結(jié)貨款協(xié)議書(shū)
- 汽車(chē)分伙協(xié)議書(shū)
- 《晚期肺癌持續(xù)治療策略》課件
- 遺產(chǎn)協(xié)議書(shū)范本
- 軟件制圖交易合同協(xié)議
- 手車(chē)位買(mǎi)賣(mài)協(xié)議書(shū)
- 舊船買(mǎi)賣(mài)協(xié)議書(shū)
- 追償糾紛和解協(xié)議書(shū)模板
- 教育咨詢員服務(wù)合同書(shū)
- 福州一號(hào)線盾構(gòu)法地鐵工程整體施工組織設(shè)計(jì)
- 公務(wù)員考試-經(jīng)濟(jì)基礎(chǔ)知識(shí)模擬題-計(jì)量經(jīng)濟(jì)學(xué)-協(xié)整與誤差修正模型
- 資源與運(yùn)營(yíng)管理-第一次形考任務(wù)-國(guó)開(kāi)-參考資料
- 五年級(jí)下冊(cè)數(shù)學(xué)教案 - 8.1《復(fù)式條形統(tǒng)計(jì)圖》 北師大版
- 2025年二建《建筑工程管理與實(shí)務(wù)》考前必刷必練題庫(kù)500題(含真題、重點(diǎn)題)
- 2025云南師范大學(xué)輔導(dǎo)員考試題庫(kù)
- 學(xué)生健康檔案管理制度
- 4.2《 依法履行義務(wù)》教學(xué)設(shè)計(jì) -2024-2025學(xué)年統(tǒng)編版道德與法治八年級(jí)下冊(cè)
- 學(xué)生常見(jiàn)病預(yù)防
- 中國(guó)糖尿病防治指南(2024版)解讀
- 協(xié)力安全管理
評(píng)論
0/150
提交評(píng)論