opencv-python图像增强十六:图像马赛克

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、算法流程:
  • 二、算法实现:
    • 2.1 生成背板图:
    • 2.2 图片添加马赛克效果
  • 三,整体代码实现:
  • 四,效果:


前言

在数字时代,图像处理已成为我们日常生活中不可或缺的一部分。无论是社交媒体上的照片编辑,还是专业领域的图像分析,图像处理技术都发挥着至关重要的作用。今天,我们将一起探索图像处理领域的一个有趣应用——图像马赛克。
马赛克作为一种艺术形式,自古以来就广受欢迎。它通过将小块的彩色材料拼接在一起,创造出美丽的图案和画面。而在数字图像处理中,马赛克效果则是一种将图像分解成若干小块,并通过某种方式(如平均颜色)重新组合的技术。这种效果不仅具有艺术价值,而且在隐私保护、数据压缩等方面有着广泛的应用。
在这篇博客中,我们将使用 OpenCV 和 Python 这两大利器来实现图像的马赛克效果。OpenCV 是一个强大的计算机视觉库,它提供了丰富的图像处理功能。Python 则以其简洁明了的语法和强大的社区支持,成为了数据科学和机器学习领域的首选语言。

一、算法流程:

该算法流程首先读取并调整图像大小,然后通过将图像分割成指定大小的块,计算每个块的平均颜色,创建一个马赛克模板,并使用 NumPy 的 np.repeat 函数将模板扩展到整个图像大小,最终生成并显示马赛克化的图像

二、算法实现:

2.1 生成背板图:

首先将图像分割成指定大小的块,然后计算每个块的平均颜色,并将这些平均颜色填充到一个模板数组中,从而创建了一个马赛克化图像的模板。
代码实现:

height, width, channels = image.shape
# 设置马赛克块的大小
block_size = 10# 计算马赛克化后的图像大小
mosaic_height = height // block_size
mosaic_width = width // block_size# 初始化一个数组来保存马赛克化后的图像模板
mosaic_template = np.zeros((mosaic_height, mosaic_width, channels), dtype=np.uint8)# 遍历每个块,计算平均颜色,并填充模板
for i in range(mosaic_height):for j in range(mosaic_width):# 获取当前块的位置y_start = i * block_sizey_end = (i + 1) * block_sizex_start = j * block_sizex_end = (j + 1) * block_size# 获取当前块block = image[y_start:y_end, x_start:x_end]# 计算平均颜色mean_color = np.mean(block, axis=(0, 1))# 填充模板mosaic_template[i, j] = mean_color

原图:
在这里插入图片描述

生成的背板图:
在这里插入图片描述

2.2 图片添加马赛克效果

在获得背板图之后,若想要让图片获得马赛克效果,只需要对背板图的每个像素进行复制并扩增,将背板扩增到原图大小后即可实现马赛克效果,本次扩增选择的函数numpy.repeat(a, repeats, axis=None)

函数参数:
a: 要重复的输入数组。
repeats: 每个元素重复的次数。如果 repeats 是一个整数,那么数组 a 中的所有元素都会重复那么多次;如果 repeats 是一个数组,那么 a 中的每个元素将按照 repeats 中对应元素的值重复相应的次数。
axis: 指定沿着哪个轴进行重复。如果 axis 为 None(默认值),那么 a 将被扁平化成一维数组,然后每个元素都会按照 repeats 指定的次数进行重复;如果指定了 axis,则沿着该轴进行重复操作。

使用代码:

mosaic_image = np.repeat(np.repeat(mosaic_template, block_size, axis=0), block_size, axis=1)

三,整体代码实现:

代码如下(示例):

import cv2
import numpy as np# 读取图像
image_path = r'F:\traditional_vison\1.jpg'
image = cv2.imread(image_path)
image =  cv2.resize(image,(0,0),fx=0.5,fy=0.5)
# 获取图像的宽度和高度
height, width, channels = image.shape# 设置马赛克块的大小
block_size = 10# 计算马赛克化后的图像大小
mosaic_height = height // block_size
mosaic_width = width // block_size# 初始化一个数组来保存马赛克化后的图像模板
mosaic_template = np.zeros((mosaic_height, mosaic_width, channels), dtype=np.uint8)# 遍历每个块,计算平均颜色,并填充模板
for i in range(mosaic_height):for j in range(mosaic_width):# 获取当前块的位置y_start = i * block_sizey_end = (i + 1) * block_sizex_start = j * block_sizex_end = (j + 1) * block_size# 获取当前块block = image[y_start:y_end, x_start:x_end]# 计算平均颜色mean_color = np.mean(block, axis=(0, 1))# 填充模板mosaic_template[i, j] = mean_color# 使用 np.repeat 扩展模板到整个图像大小
mosaic_image = np.repeat(np.repeat(mosaic_template, block_size, axis=0), block_size, axis=1)
cv2.imshow('mosaic_template Image', mosaic_template)
cv2.imshow(' Image',image)
# 显示马赛克化的图像
cv2.imshow('Mosaic Image', mosaic_image)
cv2.waitKey(0)
cv2.destroyAllWindows()# 保存马赛克化的图像

四,效果:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/409440.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

点亮星星的世界:当小孩得了自闭症该怎么办

在这个丰富多彩的世界里,每一个孩子都是独一无二的天使。然而,有一些孩子却仿佛被困在了自己的小小世界中,难以与外界正常交流和互动。他们是自闭症儿童,他们的世界充满了挑战和困惑,也让家长们陷入了深深的担忧和焦虑…

UE5学习笔记17-让人物的视线和鼠标移动时的方向一致,并且不让人物模型旋转,只改变视线方向

一、创建标准动画帧 1.我想让人物在装备武器后根据鼠标的移动方向改变人物的视线方向,并且人物模型不会改变朝向 2.我的动画中存在一个四个方向瞄准的动画,将左下,坐上,左转,右上,右下,右转&…

Android - 音频参数合入

音频参数宏观来看分为两部分,audio和music。不管是哪个平台都需要分别合入这两部分。 A10 music参数 相关工程师调试后会提供 audio_para 文件,将该文件替换至对应工程下的文件编译即可 例: device/sprd/sharkle/sl8541e_1h10_32b/rootdir/system/et…

程序员失业跑滴滴,意外自学AI绘画成主业,月入过万不是梦!

一、突如其来的裁员 那是一个阴沉的下午,我像往常一样,在公司忙碌着。突然,HR叫我去会议室,告诉我由于公司业务调整,我所在的部门被整体裁撤。作为一名程序员,我从未想过自己会面临失业的困境。拿着那份补偿…

大语言模型-PDF文档解析

PDF解析能够提升大语言模型系统的信息处理能力和应用范围,为用户提供更加便捷、高效、个性化的服务体验。本文介绍三种常用的pdf解析方式:Open Parse、pdfplumber、PyMuPD。 一、Open Parse Open Parse是一个能够直观地识别文档布局并有效地对其进行分…

mac安装java17(jdk17)

1. 下载jdk17 官网下载:https://www.oracle.com/java/technologies/downloads 2. 直接安装 安装完后目录会存放在下面目录下 /Library/Java/JavaVirtualMachines 111111deMBP JavaVirtualMachines % ls jdk-11.0.227 jdk-17.jdk 3. 如果你已经安装过java&#…

kafka的12个重要概念

kafka的12个重要概念 1、服务器broker1.1、Broker 的主要功能1.2、Kafka Broker 的架构1.3、配置和管理1.4、高可用性和负载均衡1.5、总结 2、主题topic2.1、主要特点 3、事件Event4、生产者producer4.1、主要功能4.2、Producer 的配置选项4.3、Producer 的工作流程4.4、总结 5…

网页,html,Web端实现RTSP/RTMP实时推流视频和播放

随着技术的不断发展,实时流传输已经成为许多应用的重要组成部分。RTSP(Real-Time Streaming Protocol)作为一种实时流媒体传输协议,广泛应用于视频监控、直播等领域。然而,在Web端实现RTSP实时推流视频播放却面临一些挑…

谈下日本IT业现状以及未来的发展

日本IT业现状 市场规模与增长率: 根据最新数据,日本IT行业的市场规模在不断扩大。例如,2022年日本IT行业的总市值达到了约4500亿美元,年复合增长率约为3.5%。这表明该行业在经济中占据重要地位,并持续保持增长态势。就…

我忘记给我的代码备份了。。。。。。

ok啊,历经1个月,这个项目总算是快写完啦!很烧脑,写这个脑细胞都不知道噶了多少,哎~ 虽然目前还有很大一部分可以改进,我觉得以我目前的能力能写成这样已经很不错了,还是学艺不精啊~ 实际上的话…

分享一个基于python新闻订阅与分享平台flask新闻发布系统(源码、调试、LW、开题、PPT)

💕💕作者:计算机源码社 💕💕个人简介:本人 八年开发经验,擅长Java、Python、PHP、.NET、Node.js、Android、微信小程序、爬虫、大数据、机器学习等,大家有这一块的问题可以一起交流&…

SpringBoot集成kafka开发-消息消费的分区策略(消费者如何判断从哪个分区中消费消息的?)

这里写目录标题 1、kafak消息者消费消息的4种分区策略2、kafka默认的消费分区策略1-RangeAssignor(均匀分配、默认分配策略)2.1、代码验证RangeAssignor的消息分区策略2.1.1、消费者2.1.2、生产者2.1.3、kafak配置类2.1.4、对象实体类2.1.5、项目配置文件…

卸载通过pip安装的所有Python包的详细指南

卸载所有通过pip安装的Python包的方法总结(Windows系统) 方法 1: 使用 pip freeze 和 requirements.txt 步骤: 导出依赖到requirements.txt文件: pip freeze > requirements.txt这个命令会将当前环境中所有已安装的Python包及其版本号输出到requirem…

Django | 从中间件的角度来认识Django发送邮件功能

文章目录 概要中间件中间件 ---> 钩子实现中间件demo 邮件发送过程Django如何做邮件服务配置流程 中间件结合邮件服务实现告警 概要 摘要 业务告警 邮件验证 密码找回 邮件告警 中间件 中间件 —> ‘钩子’ 例如 访问路由 的次数【请求】 中间件类须实现下列五个方法…

ubuntu系统在线安装下载firefox-esr流览器

1、在线firefox流览器 Firefox ESR(Extended Support Release)是火狐浏览器的长期支持版本,针对同一个主版本提供一年左右的安全性与稳定性支持。如果您因为火狐浏览器改版而导致有原本能用的功能变得不能使用的话(例如Firefox 64.0把RSS订阅的功能拿掉了)&#xf…

【持续更新】1DM+ 17.1 Pro 号称安卓上的 idm,下载超快!最新免费高级修改版

这款安卓平台上的下载管理器,号称安卓上的 idm,堪称最快。 其下载速度比普通下载快高达 500%,有以下特点: • 无广告干扰 • 提供深色与浅色主题选择 • 支持直接下载至SD卡(Android 4.4版本除外) • 具备…

文献阅读:Pathway Ensemble Tool癌症通路和治疗法的无偏发现

介绍 正确地识别生物途径的扰动是揭示基本疾病机制和发展急需的治疗策略的关键步骤。然而,目前的工具是否最优化用于无偏发现相关途径仍然不清楚。在这里,我们创建了“基准测试”(Benchmark)来严格评估现有工具,并发现…

5步掌握Python Django+Vue二手房项目,实现房价预测与知识图谱系统

🍊作者:计算机毕设匠心工作室 🍊简介:毕业后就一直专业从事计算机软件程序开发,至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长:按照需求定制化开发项目…

【SpringBoot】电脑商城-07-上传头像

基于SpringMVC的文件上传 1 MultipartFile接口 MultipartFile接口常用的的API见下表: 方法功能描述String getOriginalFilename()获取上传文件的原始文件名,即该文件在客户端中的文件名boolean isEmpty()判断上传的文件是否为空,当没有选择…

1-Wired一线式总线

常见的几种通信接口 一线式总线 定义 一线式:说明CPU和外设之间数据通信只需一根信号线,此信号线必然是数据线,并且数据线连接了一个上拉电阻,默认为高电平串行:说明CPU和外设的数据通信一个时钟周期传输一个bit位 问:没有时钟…