计算机视觉-滤镜小程序

python 复制代码
import os

import tkinter

import cv2

from PIL import Image, ImageTk

from tkinter import filedialog, Frame

import numpy as np



class Application(Frame):

    def __init__(self, master=None):

        self.camera_height = 300

        self.camera_width = 500

        self.Source_Img_Label = None

        self.Source_Img = None

        self.py_path = os.path.abspath(os.path.dirname(__file__))

        Frame.__init__(self, master, bg='white')

        self.pack(expand=tkinter.YES, fill=tkinter.BOTH)

        self.window_init()

        self.String_var = tkinter.StringVar()

        self.createWidgets()


    def window_init(self):

        self.master.title('滤镜小程序')

        self.master.configure(bg='white')

        width, height = (self.camera_width, self.camera_height)

        self.master.geometry("{}x{}".format(width, height))


    def createWidgets(self):

        # 左侧面板:操作按钮

        self.fml = Frame(self, bg='white')

        self.fml_top = Frame(self.fml, bg='white')

        self.fml_buttons = Frame(self.fml, bg='white')


        # 文件路径输入框

        self.Img_Path_Text = tkinter.Entry(self.fml_top, textvariable=self.String_var, borderwidth=1, state=tkinter.DISABLED)

        self.Img_Path_Text.pack(side='left', fill=tkinter.X, expand=True)


        # 选择文件按钮

        self.Img_Path_Button = tkinter.Button(self.fml_top, text='选择', command=self.AskPicture)

        self.Img_Path_Button.pack(side='right', padx=5)


        # 功能按钮

        self.Outline_Button = tkinter.Button(self.fml_buttons, text='轮廓', command=self.outlinePicture)

        self.Outline_Button.pack(side='left', padx=5, expand=True)


        self.Sharpen_Button = tkinter.Button(self.fml_buttons, text='锐化', command=self.sharpenPicture)

        self.Sharpen_Button.pack(side='left', padx=5, expand=True)


        self.Emboss_Button = tkinter.Button(self.fml_buttons, text='浮雕', command=self.embossPicture)

        self.Emboss_Button.pack(side='left', padx=5, expand=True)


        self.fml_top.pack(side=tkinter.TOP, fill=tkinter.X)

        self.fml_buttons.pack(side=tkinter.TOP, fill=tkinter.X)

        self.fml.pack(side=tkinter.LEFT, fill=tkinter.Y)


        # 右侧面板:图像显示区域

        self.fm2 = Frame(self, bg='white')

        self.Source_Img_Label = tkinter.Label(self.fm2, bg='white', image=None, width=200, height=200)

        self.Source_Img_Label.image = None


        # 使用 pack 方法并设置 pady 参数以实现垂直居中

        self.Source_Img_Label.pack(side='top', pady=(self.camera_height - 200) // 2)

        self.fm2.pack(side=tkinter.LEFT, fill=tkinter.BOTH, expand=True)


    def CvtPIL(self, srcImg):

        Rgb_Img = cv2.cvtColor(srcImg, cv2.COLOR_BGR2RGB)  # 正确的颜色空间转换

        Rgb_Img = Image.fromarray(Rgb_Img)

        Rgb_Img = ImageTk.PhotoImage(Rgb_Img)

        self.Source_Img_Label.configure(image=Rgb_Img)

        self.Source_Img_Label.image = Rgb_Img


    def AskPicture(self):

        Picture_Path = filedialog.askopenfilename()

        if not Picture_Path:

            self.String_var.set('未选择文件')

            return

        self.String_var.set(Picture_Path)

        self.Source_Img = cv2.imread(Picture_Path)

        if self.Source_Img is None:

            self.String_var.set('文件读取错误')

            return

        self.CvtPIL(self.Source_Img)


    def outlinePicture(self):

        if self.Source_Img is None:

            self.String_var.set('文件选择错误')

            return

        kernel = np.array([[-1, -1, -1],

                           [-1, 8, -1],

                           [-1, -1, -1]], dtype="float32")

        dstimg = cv2.filter2D(self.Source_Img, -1, kernel)

        self.CvtPIL(dstimg)


    def embossPicture(self):

        if self.Source_Img is None:

            self.String_var.set('文件选择错误')

            return

        kernel = np.array([[-2, -1, 0],

                           [-1, 1, 1],

                           [0, 1, 2]], dtype="float32")

        dstimg = cv2.filter2D(self.Source_Img, -1, kernel)

        self.CvtPIL(dstimg)


    def sharpenPicture(self):

        if self.Source_Img is None:

            self.String_var.set('文件选择错误')

            return

        kernel = np.array([[-1, -1, -1],

                           [-1, 9, -1],

                           [-1, -1, -1]], dtype="float32")

        dstimg = cv2.filter2D(self.Source_Img, -1, kernel)

        self.CvtPIL(dstimg)



if __name__ == '__main__':

    app = Application()

    app.mainloop()
相关推荐
CarmenHu10 分钟前
pytorch常用API
人工智能·pytorch·python
魔力之心40 分钟前
TensorFlow2 study notes[1]
人工智能·python·tensorflow
猎嘤一号2 小时前
Windows11桌面解锁守护脚本
开发语言·python·opencv
蓝婷儿3 小时前
Python 数据建模与分析项目实战预备 Day 2 - 数据构建与字段解析(模拟简历结构化数据)
开发语言·python·机器学习
青衫客363 小时前
浅谈 Python 中的 yield——yield的返回值与send()的关系
开发语言·python
测试老哥4 小时前
Python+Selenium实现自动化测试
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
Dxy12393102167 小时前
Python PDFplumber详解:从入门到精通的PDF处理指南
开发语言·python·pdf
在努力的韩小豪9 小时前
如何从0开始构建自己的第一个AI应用?(Prompt工程、Agent自定义、Tuning)
人工智能·python·llm·prompt·agent·ai应用·mcp
Otaku love travel10 小时前
实施运维文档
运维·windows·python
测试老哥10 小时前
软件测试之单元测试
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例