使用Python和Pillow创建照片马赛克应用

news2024/9/21 20:44:08

在这篇博客中,我们将探讨如何使用Python创建一个简单而有趣的桌面应用程序。我们的目标是构建一个应用,允许用户选择一张照片,然后在照片的右下角添加马赛克效果。这个项目将展示如何结合使用wxPython来创建图形用户界面(GUI)和Pillow库来处理图像。
D:\spiderdocs\eraselogo.py

项目概述

我们的应用程序将具有以下功能:

  1. 一个用于选择照片文件的按钮
  2. 一个用于应用马赛克效果的按钮
  3. 一个显示当前状态的文本标签

当用户点击"添加马赛克"按钮时,程序将在选定照片的右下角添加马赛克效果,并将结果保存为新的图片文件。

所需库

为了构建这个应用,我们需要安装两个主要的库:

  • wxPython: 用于创建图形用户界面
  • Pillow: 用于图像处理

你可以使用pip安装这些库:

pip install wxPython Pillow

全部代码

import wx
import os
from PIL import Image

class PhotoMosaicApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Photo Mosaic App')
        panel = wx.Panel(self)
        
        self.photo_path = None
        
        # 创建控件
        self.select_button = wx.Button(panel, label='选择照片')
        self.mosaic_button = wx.Button(panel, label='添加马赛克')
        self.status_text = wx.StaticText(panel, label='请选择一张照片')
        
        # 绑定事件
        self.select_button.Bind(wx.EVT_BUTTON, self.on_select)
        self.mosaic_button.Bind(wx.EVT_BUTTON, self.on_mosaic)
        
        # 设置布局
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.select_button, 0, wx.ALL | wx.CENTER, 5)
        sizer.Add(self.mosaic_button, 0, wx.ALL | wx.CENTER, 5)
        sizer.Add(self.status_text, 0, wx.ALL | wx.CENTER, 5)
        
        panel.SetSizer(sizer)
        self.Show()
    
    def on_select(self, event):
        with wx.FileDialog(self, "选择照片", wildcard="图片文件 (*.jpg;*.png)|*.jpg;*.png",
                           style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST) as fileDialog:
            if fileDialog.ShowModal() == wx.ID_CANCEL:
                return
            self.photo_path = fileDialog.GetPath()
            self.status_text.SetLabel(f'已选择: {os.path.basename(self.photo_path)}')
    
    def on_mosaic(self, event):
        if not self.photo_path:
            wx.MessageBox('请先选择一张照片', '提示', wx.OK | wx.ICON_INFORMATION)
            return
        
        try:
            # 打开图片
            img = Image.open(self.photo_path)
            width, height = img.size
            
            # 定义右下角区域
            mosaic_size = min(width, height) // 4
            mosaic_area = (width - mosaic_size, height - mosaic_size, width, height)
            
            # 裁剪右下角区域并缩小
            mosaic = img.crop(mosaic_area).resize((20, 20), Image.NEAREST)
            
            # 将缩小的区域放大回原始大小,形成马赛克效果
            mosaic = mosaic.resize((mosaic_size, mosaic_size), Image.NEAREST)
            
            # 将马赛克区域粘贴回原图
            img.paste(mosaic, (width - mosaic_size, height - mosaic_size))
            
            # 保存结果
            output_path = os.path.splitext(self.photo_path)[0] + '_mosaic.png'
            img.save(output_path)
            
            self.status_text.SetLabel(f'马赛克添加成功,已保存为: {os.path.basename(output_path)}')
        except Exception as e:
            wx.MessageBox(f'处理图片时出错: {str(e)}', '错误', wx.OK | wx.ICON_ERROR)

if __name__ == '__main__':
    app = wx.App()
    frame = PhotoMosaicApp()
    app.MainLoop()

代码实现

让我们逐步实现这个应用程序:

  1. 首先,我们导入必要的模块并创建主应用类:
import wx
import os
from PIL import Image

class PhotoMosaicApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Photo Mosaic App')
        panel = wx.Panel(self)
        
        self.photo_path = None
        
        # 创建控件
        self.select_button = wx.Button(panel, label='选择照片')
        self.mosaic_button = wx.Button(panel, label='添加马赛克')
        self.status_text = wx.StaticText(panel, label='请选择一张照片')
        
        # 绑定事件
        self.select_button.Bind(wx.EVT_BUTTON, self.on_select)
        self.mosaic_button.Bind(wx.EVT_BUTTON, self.on_mosaic)
        
        # 设置布局
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.select_button, 0, wx.ALL | wx.CENTER, 5)
        sizer.Add(self.mosaic_button, 0, wx.ALL | wx.CENTER, 5)
        sizer.Add(self.status_text, 0, wx.ALL | wx.CENTER, 5)
        
        panel.SetSizer(sizer)
        self.Show()
  1. 接下来,我们实现选择照片的功能:
def on_select(self, event):
    with wx.FileDialog(self, "选择照片", wildcard="图片文件 (*.jpg;*.png)|*.jpg;*.png",
                       style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST) as fileDialog:
        if fileDialog.ShowModal() == wx.ID_CANCEL:
            return
        self.photo_path = fileDialog.GetPath()
        self.status_text.SetLabel(f'已选择: {os.path.basename(self.photo_path)}')
  1. 然后,我们实现添加马赛克的核心功能:
def on_mosaic(self, event):
    if not self.photo_path:
        wx.MessageBox('请先选择一张照片', '提示', wx.OK | wx.ICON_INFORMATION)
        return
    
    try:
        # 打开图片
        img = Image.open(self.photo_path)
        width, height = img.size
        
        # 定义右下角区域
        mosaic_size = min(width, height) // 4
        mosaic_area = (width - mosaic_size, height - mosaic_size, width, height)
        
        # 裁剪右下角区域并缩小
        mosaic = img.crop(mosaic_area).resize((20, 20), Image.NEAREST)
        
        # 将缩小的区域放大回原始大小,形成马赛克效果
        mosaic = mosaic.resize((mosaic_size, mosaic_size), Image.NEAREST)
        
        # 将马赛克区域粘贴回原图
        img.paste(mosaic, (width - mosaic_size, height - mosaic_size))
        
        # 保存结果
        output_path = os.path.splitext(self.photo_path)[0] + '_mosaic.png'
        img.save(output_path)
        
        self.status_text.SetLabel(f'马赛克添加成功,已保存为: {os.path.basename(output_path)}')
    except Exception as e:
        wx.MessageBox(f'处理图片时出错: {str(e)}', '错误', wx.OK | wx.ICON_ERROR)
  1. 最后,我们添加主程序入口:
if __name__ == '__main__':
    app = wx.App()
    frame = PhotoMosaicApp()
    app.MainLoop()

代码解析

让我们来解析一下关键部分的代码:

  1. GUI创建: 我们使用wxPython创建了一个简单的窗口,包含两个按钮和一个状态文本。wx.BoxSizer用于垂直排列这些控件。

  2. 文件选择: wx.FileDialog用于创建一个文件选择对话框,允许用户选择JPG或PNG格式的图片。

  3. 图像处理:

    • 我们使用Pillow的Image.open()方法打开选定的图片。
    • 通过计算图片尺寸的1/4来确定马赛克区域的大小。
    • 使用crop()方法裁剪右下角区域。
    • 将裁剪区域缩小到20x20像素,然后再放大回原始大小,创造马赛克效果。
    • 最后使用paste()方法将马赛克区域粘贴回原图。
  4. 异常处理: 我们使用try-except块来捕获和处理可能发生的错误,提高应用程序的健壮性。

运行应用程序

要运行这个应用程序,只需要将上述代码保存为一个Python文件(例如photo_mosaic_app.py),然后在命令行中运行:

python photo_mosaic_app.py

结果

在这里插入图片描述

在这里插入图片描述

结论

通过这个项目,我们展示了如何结合使用wxPython和Pillow来创建一个简单但功能完整的桌面应用程序。这个应用不仅实现了基本的图像处理功能,还提供了用户友好的界面。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux 基本指令讲解 上

linux 基本指令 clear 清屏 Alt Enter 全屏/退出全屏 pwd 显示当前用户所处路径 cd 改变目录 cd /root/mikecd … 返回上级目录cd - 返回最近所处的路径cd ~ 直接返回当前用户自己的家目 roor 中:/root普通用户中:/home/mike mkdir 创建一个文件夹(d) …

通义灵码:AI 研发趋势与效果提升实践丨SDCon 全球软件技术大会演讲全文整理

作者:张昕东 大家好,我是来自阿里云通义灵码团队的张昕东。很高兴和各位同仁做这次分享,分享的主题是人机协同趋势与效果提升实践。我们所做的模型提升和功能开发是为了促进人机在研发领域的协同,而当今的人机协同现状又决定了我…

基于Spring Boot的农田智能管理系统

目录 前言 功能设计 系统实现 获取源码 博主主页:百成Java 往期系列:Spring Boot、SSM、JavaWeb、python、小程序 前言 农田智能管理系统是基于SpringBoot框架开发的一款针对农田管理的智能化平台。随着农业现代化的发展,农田管理需要更…

docker拉取kafka镜像|启动kafka容器

1、kafka官网快速开始模块查看如何拉取kafka的docker镜像 https://kafka.apache.org/quickstart 2、移除本机已拉取kafka的docker镜像 docker rmi apache/kafka:3.7.03、拉取kafka的docker镜像 docker pull apache/kafka:3.7.04、启动kafka容器 docker run -p 9092:9092 ap…

iOS 18(macOS 15)Vision 中新增的任意图片智能评分功能试玩

概述 在 WWDC 24 中库克“大厨”除了为 iOS 18 等平台重磅新增了 Apple Intelligence 以外,苹果也利用愈发成熟的机器学习引擎扩展了诸多内置框架,其中就包括 Vision。 想用本机人工智能自动为我们心仪的图片打一个“观赏分”吗?“如意如意&…

【2.3】回溯算法-重新排序得到 2 的幂

一、题目 给定正整数N&#xff0c;我们按任何顺序&#xff08;包括原始顺序&#xff09;将 数字重新排序 &#xff0c;注意其前导数字不能为零。 如果我们可以通过上述方式得到2的幂&#xff0c;返回 true&#xff1b;否则&#xff0c;返回false。 提示&#xff1a; 1 < …

学习记录第二十六天

进程运行 1&#xff0c;子进程和父进程做相同的事----创建子进程 执行任务 2&#xff0c;子进程做与父进程不同的事 ----fork exec exec族 l VS v :主要是第二个参数的传参方式不同 p :表示寻找可执行文件 是通过PATA环境变量 e : 表示可以给…

升级软文发稿开源系统源码论文期刊一键发布

升级软文发稿运营管理源码—论文期刊一键发布 软文发稿系统源码&#xff08;软文发布系统&#xff09;在基于旧版本的媒介软文发布平台项目改造升级了新的功能模块简称&#xff08;3.0版&#xff09;本系统还是基于开源的PHPMYSQLlayui&#xff08;前端界面&#xff09;代码进行…

唐山网站建设方案优化

唐山作为一个重要的工业城市&#xff0c;网站建设在这里具有重要的意义。为了更好地服务于市民和企业&#xff0c;唐山网站建设方案需要不断优化和更新。下面将从内容、技术和设计三个方面来探讨唐山网站建设方案的优化。 首先是内容方面。唐山作为一个历史悠久且拥有丰富文化底…

如何提高遭受网络攻击后的恢复速度

现实促使组织探索提供更快恢复和增强安全性的替代网络保护和恢复方法&#xff0c;尤其是在更严格的法规驱动下&#xff0c;这种紧迫感愈加明显。以下是一些提高网络安全策略恢复速度的方法。 近年来&#xff0c;勒索软件攻击已成为一个重大且令人担忧的趋势&#xff0c;其频率和…

Spring之最基础的创建与Bean的存储与获取(还有Maven加载jar包报错的解决方法)

目录 创建Spring项目 如何解决Maven加载jar包报错 存储Bean和取Bean 在Java中对象也称为Bean。所以后面我提到Bean&#xff0c;大家要知道我说的是什么。 创建Spring项目 我的idea是2022版本的&#xff0c;如果大家和我一样可以参考我的。 1.创建一个Maven项目。图片上忘了…

【TiDB】08-离线部署TiDB 8.1

目录 1、环境检查 1.1、检测及关闭系统 swap 1.2、设置TiDB节点的临时空间 1.3、安装NTP服务 1.3.1、更新apt源 1.3.2、安装NTP 1.3.3、将本机作为NTP服务器 1.3.4、客户端连接 1.4、配置SSH互信及sudo免密码 2、离线安装 2.1、下载离线安装包 2.2、解压安装 2.3、…

YOLOv8改进 | 主干网络 | 动态调整目标的感受野的LSKNet【旋转目标检测SOTA】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 专栏目录 &#xff1a;《YOLOv8改进有效…

程序员最常用的操作——git

软件安装 官方下载&#xff08;比较慢&#xff09;&#xff1a;https://git-scm.com/downloads gitee 注册账号 https://gitee.com/ 新建仓库 honey2024 先全局配置下邮箱 配置 git config --global user.email “your_emailexample.com” git config --global user.name…

虚幻5|AI行为树,进阶篇

一&#xff0c;打开敌人的角色蓝图&#xff0c;编写以下蓝图&#xff0c;该蓝图只是创建一个敌人并非ai行为树 1.编写蓝图 2.打开主界面&#xff0c;创建一个导航网格体积&#xff0c;上一章都有讲&#xff0c;在添加体积这里面&#xff0c;找到导航网格体积&#xff0c;点击创…

安装buf工具和环境变量

安装buf工具和环境变量 下载buf的可执行文件&#xff1a; 访问buf官方的GitHub releases页面。 没梯子的就用csdn下载吧 https://download.csdn.net/download/qq_27229113/89638643 找到最新版本的buf。 在Assets部分&#xff0c;下载适合Windows的二进制文件&#xff0c;一…

如何利用宝塔给WordPress网站搬家?详细分步教程

对于使用WordPress建站的站长来说&#xff0c;网站搬家是一项必备技能。无论是重装系统、升级配置还是服务器迁移&#xff0c;掌握网站搬家的技巧可以让你在选择服务器时更加灵活。本文将详细介绍如何使用宝塔面板来搬迁WordPress网站。 1. 备份数据库 记住数据库用户名和密码…

Python 批量读取西门子PLC

需要安装 pip install python-snap7 import snap7 from snap7.util import * import struct # PLC的IP地址, Rack和Slot plc snap7.client.Client() plc.connect(127.0.0.1, 0, 1) # IP, Rack, Slot # 读取DB1中的10个字节&#xff0c;起始于0位置 db_number …

企业多样化需求一键满足:可道云teamOS,助力定制专属企业网盘

在这个飞速发展的数字化时代&#xff0c;企业的运营需求越来越多样化&#xff0c;如何高效地管理数据、实现安全协作&#xff0c;成为摆在我们面前的重要课题。 幸运的是&#xff0c;我遇到了可道云teamOS。 首先&#xff0c;可道云teamOS的自定义用户权限功能让我印象深刻。…

Bug定义及生命周期(七)

BUG 定义 软件的bug&#xff0c;软件程序的漏洞或缺陷 – 常见&#xff0c;首先发现 软件可改进的细节&#xff0c;或与需求文档存在差异的功能实现等 测试工程师&#xff1a;发现bug&#xff0c;定位bug&#xff0c;提交bug&#xff0c;回归bug 类型 确定bug类型&#xff…