【个人】项目实训 _ 图片风格_怀旧滤镜

2023-10-18 14:20

本文主要是介绍【个人】项目实训 _ 图片风格_怀旧滤镜,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、怀旧滤镜核心代码
  • 二、UI界面
    • 1.更改glass_effect.py文件
    • 2.在对应UI.py文件中添加action
    • 3.在主UI.py文件中添加信号发射函数
  • 三、解决问题
  • 四、参考链接


一、怀旧滤镜核心代码

新建 pasttime_effect.py 文件

import cv2
import numpy as np#读取原始图片
original_image = cv2.imread('2.jpg')# 获取图像的行和列
original_rows, original_cols = original_image.shape[:2]#新建目标图像
pasttime_image = np.zeros((original_rows,original_cols,3),dtype="uint8")#图片怀旧特效
for i in range(original_rows):for j in range(original_cols):B = 0.272*original_image[i,j][2] + 0.534*original_image[i,j][1] + 0.131*original_image[i,j][0]G = 0.349*original_image[i,j][2] + 0.686*original_image[i,j][1] + 0.168*original_image[i,j][0]R = 0.393*original_image[i,j][2] + 0.769*original_image[i,j][1] + 0.189*original_image[i,j][0]if B>255:B=255if G>255:G=255if R>255:R=255pasttime_image[i,j] = np.uint8((B,G,R))# 处理完成,显示图像
cv2.imshow('original_image', original_image)
cv2.imshow('glass_effect_image', pasttime_image)cv2.waitKey()
cv2.destroyAllWindows()

代码思想:

图像怀旧特效是指图像经历岁月的昏暗效果,让图片变的偏黄偏暗,给人以怀旧复古的感觉。

可以利用怀旧 RGB 三色公式计算通道新数值:

    R2 = 0.393*R + 0.769*G + 0.189*BB2 = 0.272*R + 0.534*G + 0.131*BG2 = 0.349*R + 0.686*G + 0.168*B

效果如下:

在这里插入图片描述


二、UI界面

1.更改glass_effect.py文件

def pasttimeeffect_fun(instance):# 读取原始图像original_image = instance.m_image
    instance.m_image = pasttime_imageinstance.updata_image()

2.在对应UI.py文件中添加action

    # 创建一个action,当该action被触发时显示油漆特效处理后的图片action_pasttime_img_show = QAction('&怀旧滤镜', instance)action_pasttime_img_show.triggered.connect(instance.pasttime_effect_emit)# 艺术风格迁移选项新增一个action:怀旧滤镜tempMenu.addAction(action_pasttime_img_show)

3.在主UI.py文件中添加信号发射函数

引入模块

from part3 import m_init_style_transfer,glass_effect,paint_effect,pasttime_effect

定义信号发射函数

    def pasttime_effect_emit(self):pasttime_effect.pasttimeeffect_fun(self)

效果如下:

在这里插入图片描述


三、解决问题

使用界面后发现,效果图片时偏蓝色而非偏黄色,但是核心代码并没有改动。

此时,将核心代码中的 R 与 B 互换位置,即可得到真正的偏黄色的怀旧风格图片。

原因可能是使用界面进入的图片为 RGB 通道而非 BGR 通道。

R = 0.272 * original_image2[i, j][2] + 0.534 * original_image2[i, j][1] + 0.131 * original_image2[i, j][0]
G = 0.349 * original_image2[i, j][2] + 0.686 * original_image2[i, j][1] + 0.168 * original_image2[i, j][0]
B = 0.393 * original_image2[i, j][2] + 0.769 * original_image2[i, j][1] + 0.189 * original_image2[i, j][0]

效果如下:
在这里插入图片描述
成功。


四、参考链接

参考链接:图像处理:怀旧滤镜效果

这篇关于【个人】项目实训 _ 图片风格_怀旧滤镜的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/233114

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-