百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python实现多张图片合成一张马赛克图片

off999 2024-12-01 02:18 25 浏览 0 评论

目录

  • 前言
  • 开发环境
  • 实现代码
    • 先导入所需模块
    • 读取图片文件
    • 读取所有源图片并计算对应颜色的平均值
    • 合法图像列表
    • 平均颜色列表
    • 遍历
    • 主函数
    • 模块调用执行
  • 完整效果


前言

最近有网友私信我,问如何把多张图片合成一张马赛克图片的样子

说是女儿从出生到现在,所有的照片,大概有上百张,所以想使用这些照片合成一张,当做生日礼物

那我们今天就用上次爬表情包的图片来做一次马赛克图片,2万张合成一张,想想就很激动

私信小编01即可获取大量Python学习资源

欢迎加入,一起讨论学习

图片素材

4K高清原图


开发环境

Python 3.6

Pycharm


实现代码


先导入所需模块

1

2

3

4

5

6

import cv2

import glob

import argparse

import numpy as np

from tqdm import tqdm # 进度条

from itertools import product # 迭代器


读取图片文件

1

2

3

4

5

6

7

8

9

10

def parsArgs():

parser = argparse.ArgumentParser('拼接马赛克图片')

parser.add_argument('--targetpath', type=str, default='examples/3.jpg', help='目标图像路径')

parser.add_argument('--outputpath', type=str, default='output.jpg', help='输出图像的路径')

parser.add_argument('--sourcepath', type=str, default='sourceimages', help='用来拼接图像的所有源图像文件路径')

parser.add_argument('--blocksize', type=int, default=15, help='马赛克快的大小')

args = parser.parse_args()

return args


读取所有源图片并计算对应颜色平均值

1

2

def readSourceImages(sourcepath,blocksize):

print('开始读取图像')


合法图像列表

设置一个列表,存放符合要求的颜色图像

1

sourceimages = []


平均颜色列表

1

avgcolors = []


遍历

每遍历一次,进度条走一次

1

2

3

4

5

6

7

8

9

10

11

12

for path in tqdm(glob.glob("{}/*.jpg".format(sourcepath))):

image = cv2.imread(path, cv2.IMREAD_COLOR)

if image.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('结束读取')

return sourceimages,np.array(avgcolors)


主函数

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

def main(args):

targetimage = cv2.imread(args.targetpath)

outputimage = np.zeros(targetimage.shape,np.uint8) # int8 int16 int32 int64

sourceimages,avgcolors = readSourceImages(args.sourcepath,args.blocksize)

print('开始制作')

for i, j in tqdm(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.imshow('result', outputimage)

print('制作完成')


模块调用执行

1

2

3

if __name__ == '__main__':

# run

main(parseArgs())


完整效果

到此这篇关于Python实现多张图片合成一张马赛克图片的文章就介绍到这了

相关推荐

u盘被写保护怎么消除(u盘被写保护了咋办)
  • u盘被写保护怎么消除(u盘被写保护了咋办)
  • u盘被写保护怎么消除(u盘被写保护了咋办)
  • u盘被写保护怎么消除(u盘被写保护了咋办)
  • u盘被写保护怎么消除(u盘被写保护了咋办)
小米平板1(小米平板1刷安卓10稳定版)

小米平板1有开发版。具体来说,小米平板1最初发布时,已经提供了一套完整的ROM(即”MIUI“系统)供用户使用,这套系统包含了越来越多的功能,以满足用户的需求。同时,小米也会发布一些针对开发人员的版本...

华为万能钥匙wifi免费下载(华为万能钥匙wifi免费下载官方)
  • 华为万能钥匙wifi免费下载(华为万能钥匙wifi免费下载官方)
  • 华为万能钥匙wifi免费下载(华为万能钥匙wifi免费下载官方)
  • 华为万能钥匙wifi免费下载(华为万能钥匙wifi免费下载官方)
  • 华为万能钥匙wifi免费下载(华为万能钥匙wifi免费下载官方)
配置windows update已完成100%

楼主我的情况跟你类似我是删除了windows更新清理文件15g左右然后昨天删除之后正常关机,今天早上一来电脑开机然后就一直在“配置Windowsupdate已完成100%请勿关闭计算...

自己制作pe系统(自己制作pe系统最简单三个步骤)

1,在搜索框输入pe系统,下载pe的制作软件2,点击下载按钮3,安装完了以后一般会有个启动图标4,打开PE制作软件,插上U盘,软件会自动识别,点击开始制作按钮5,也可以点击高级设置按钮6,在高级界面可...

阿里云盘ios版(阿里云盘 安卓版)

阿里云盘目前是可以使用ipad的。iPad可以下载阿里云盘。阿里云盘是一款速度快、不打扰、够安全、易于分享的网盘,由阿里巴巴集团出品。阿里云盘最大的亮点就是全员不限速,曾公布“无论免费付费,未来都不...

惠普打印机怎么用(惠普打印机怎么用微信打印文件)

1、首先要确保打印机在电脑里的程序安装完成,以及数据线连接正常。2、将需要扫描的文件放置在打印机面板上,并盖好盖子。3、打开“我的电脑”,找到控制面板进入,锁定“硬件和声音”功能。点击“查看设备的打印...

老电脑装xp打不开网站(老电脑装xp打不开网站怎么回事)

原因分析及解决方法:1.宽带未连接。重新连接宽带。2.路由器故障。拆除路由器后,进行宽带连接试用。3.偶发性故障,如ADSL断流,电脑内存数据溢出等。重启电脑、modem试用。4.浏览器故障,应用不恰...

win7系统破解激活工具(windows7破解激活)

方法如下:1、开机到欢迎界面时,按Ctrl+Alt+Delete,跳出帐号窗口,输入用户名:administrator,回车。2、如果这个帐号也有密码采用开机启动时按F8选“带命令行的安全模式”。...

怎么制作winpeu盘启动盘(制作winpe启动盘有什么作用)

我们应先理解U盘启动盘:简单理解就是用U盘启动盘代替电脑以前的光驱,所以它只有3个最基本的功能:1、帮助电脑正常启动。比如电脑无限在启动界面循环;2、格式化硬盘。格式化硬盘所有分区,再重新分区;3、重...

磁力搜索引擎入口(磁力搜索器引擎)

01.磁力熊磁力熊,是一个内容丰富、功能最为强大的一个磁力搜索网站,通过它不仅仅可以搜索到大量纯净的1080P高分电影,像一些比较小众的影视剧这里也都能找到。02.夕阳小站夕阳小站,虽然网站整体界面设...

手机变成安全模式怎么解除(手机变成安全模式是怎么回事)

解除比较安全模式的方法主要有三种:1、按电源键长按机器会弹出重启菜单,将手机重启即可解除比较安全模式。2、查询手机操作手册,进入设置里找到“比较安全模式”,可以改变比较安全模式的状态,即可解除比较安全...

win7官方最小精简版(最小win7精简版系统239m)
win7官方最小精简版(最小win7精简版系统239m)

推荐win7系统精简版一、雨林木风系统v1906雨林雨林木风GhostWin7SP1旗舰版一如既往注重稳定与安全,本次6月版本更新优化注册表增强系统运行效率,不对系统关键文件进行修改保证稳定性,关闭系统可能会感染病毒的端口,更新最新...

2026-01-11 14:51 off999

华硕牌子电脑怎么样(华硕牌子电脑怎么样值得买吗)

1、华硕笔记本电脑在市场上有很高的认知度和认可度。除了在零售市场有出色口碑外,在特殊领域华硕笔记本一样有惊人的表现;2、华硕笔记本电脑的优点在于它的主板性能好还有就是它的散热效果也不错,性能比较稳定;...

两个文件夹内容自动同步(两个文件夹内容自动同步,删除不了)

D:盘中点右键,新建公文包B,将文件夹A拖到公文包B中。如果以后文件夹A中的文件修改了,打开公文包B,点菜单上的“公文包、全部更新”。则公文包B就会自动更新文件,与文件夹A中的保持一致。这种方法可以有...

取消回复欢迎 发表评论: