python学opencv|读取图像(十六)修改HSV图像HSV值

news2024/12/20 9:34:04

【1】引言

前序学习进程中,我们已经掌握了对HSV通道和BGR通道的拆分和合并,并通过自由组合的形式,获得了和初始图像完全不一样的新图像,相关文章可以参考下述链接:

python学opencv|读取图像(十四)BGR图像和HSV图像通道拆分-CSDN博客

python学opencv|读取图像(十五)BGR图像和HSV图像通道合并-CSDN博客

在此基础上,我们掌握了如何抓取各个通道的具体值,自然地,我们会想到修改各个通道的具体值。

在更早的时候,其实我们已经掌握了如何修改BGR图像各个通道的值,并获得了灰度和彩色图像,相关链接包括且不限于下述:
python学opencv|读取图像(六)读取图像像素RGB值_opencv读取灰度图-CSDN博客

python学opencv|读取图像(八)用numpy创建纯黑灰度图-CSDN博客

python学opencv|读取图像(十)用numpy创建彩色图像-CSDN博客

【2】代码测试

在前述基础上,我们本次课程直接对HSV图像进行通道设定。

【2.1】BGR转HSV

第一步,将BGR图像转化为HSV图像,在pycharm等编辑器中输入以下代码:

import cv2 as cv  # 引入CV模块
import numpy as np  # 引入numpy模块

bgr_image = cv.imread('cv-ini-000.png')

if bgr_image is not None:
    cv.imshow('cv-ini-000', bgr_image)  # 在屏幕上展示图片
    cv.imwrite('cv-ini-000-save.png', bgr_image)  # 保存图片

    # BGR转HSV
    hsv_image = cv.cvtColor(bgr_image, cv.COLOR_BGR2HSV)  # BGR转HSV
    cv.imshow('cv-ini-000-hsv', hsv_image)  # 在屏幕上展示图片
    cv.imwrite('cv-ini-000-save-hsv.png', hsv_image)  # 保存图片
    cv.waitKey()  # 不会自动关闭图像
    cv.destroyAllWindows()  # 释放所有窗口
else:
    print("There is no any photo")

使用的cv-ini-000.bng图像为:

12d90e58f55743d49b2a4d156d07496c.png

图1 cv-ini-000.bng

转换后的HSV图像为:

aab33249c31a4a5b92d82040ac3e5a42.png

图2 cv-ini-000-save-hsv.png

【2.2】HSV通道拆分

在获得HSV图像基础上,对HSV的通道进行拆分。

在pycharm等编辑器中补充下述代码:

    h,s,v=cv.split(hsv_image) #HSV拆分
    cv.imshow('H', h)  # 显示H通道
    cv.imwrite('cv-ini-000-save-hsv-h.png', h)  # 保存图片

这部分代码的意思是,先将BGR图转化的HSV图拆分为HSV三个通道,然后把H通道图像输出在屏幕上:

be15b54aff6c40b0846603d9b549f3b1.png

图3  cv-ini-000-save-hsv-h.png

然后把H通道数值强行转化为160。在此之前,我们梳理一下HSV的取值范围:

色调H:光的颜色,取值范围[0,180];

饱和度S:色彩的深浅,取值范围[0,255];

亮度V:光的明暗,取值范围[0,255]。

然后我们继续输入下述代码:

    h[:,:]=160 #强制H通道取值=160
    cv.imshow('H=160', h)  # 显示H通道
    cv.imwrite('cv-ini-000-save-hsv-h=160.png', h)  # 保存图片

运行后,获得的cv-ini-000-save-hsv-h=160.png图像为:

b457ef17916442518fad017e22f26197.png

图4 cv-ini-000-save-hsv-h=160.png

因为是单通道图像,所以是纯色,这个图像是符合预期的。

【2.3】HSV通道合并

然后我们再把通道合并,看看效果,继续输入下述代码:

    h160svm_image=cv.merge([h,s,v]) #合并HSV通道
    cv.imshow('H=160SV', h160svm_image)  # 显示合并图像
    cv.imwrite('cv-ini-000-save-hsv-h=160sv.png', h160svm_image)  # 保存图片

运行后的图像为:

4676964c632448fc9c1d95f06abadcf5.png

图5 cv-ini-000-save-hsv-h=160sv.png

图5和图2不同,根本原因就在于图5中的H=180。

出于好奇,我们读取一下特定点的HSV值,来对比图5和图2的这种不同。继续补充下述代码:

    print('hsv_image[100,100]=',hsv_image[100,100]) #读取原hsv_image图像的HSV值
    print('h160svm_image[100,100]=',h160svm_image[100,100]) #读取H=160后的h160sv_image图像的HSV值
    print('hsv_image[600,800]=', hsv_image[600, 800])  # 读取原hsv_image图像的HSV值
    print('h160svm_image[600,800]=', h160svm_image[600, 800])  # 读取H=160后的h160sv_image图像的HSV值

运行后的输出为:

8c92f43094d34c0caf61b1301cf4da01.png

图6 HSV值读取

由图6可见,确实是H通道的值在约束H值以后,每一个像素点都有H=160。

设置SV通道值得方法类似,不再赘述。

至此的完整代码为:

import cv2 as cv  # 引入CV模块
import numpy as np  # 引入numpy模块

bgr_image = cv.imread('cv-ini-000.png')

if bgr_image is not None:
    cv.imshow('cv-ini-000', bgr_image)  # 在屏幕上展示图片
    cv.imwrite('cv-ini-000-save.png', bgr_image)  # 保存图片

    # BGR转HSV
    hsv_image = cv.cvtColor(bgr_image, cv.COLOR_BGR2HSV)  # BGR转HSV
    cv.imshow('cv-ini-000-hsv', hsv_image)  # 在屏幕上展示图片
    cv.imwrite('cv-ini-000-save-hsv.png', hsv_image)  # 保存图片

    h,s,v=cv.split(hsv_image) #HSV拆分
    cv.imshow('H', h)  # 显示H通道
    cv.imwrite('cv-ini-000-save-hsv-h.png', h)  # 保存图片

    h[:,:]=160 #强制H通道取值=160
    cv.imshow('H=160', h)  # 显示H通道
    cv.imwrite('cv-ini-000-save-hsv-h=160.png', h)  # 保存图片

    h160svm_image=cv.merge([h,s,v]) #合并HSV通道
    cv.imshow('H=160SV', h160svm_image)  # 显示合并图像
    cv.imwrite('cv-ini-000-save-hsv-h=160sv.png', h160svm_image)  # 保存图片
    print('hsv_image[100,100]=',hsv_image[100,100]) #读取原hsv_image图像的HSV值
    print('h160svm_image[100,100]=',h160svm_image[100,100]) #读取H=160后的h160sv_image图像的HSV值
    print('hsv_image[600,800]=', hsv_image[600, 800])  # 读取原hsv_image图像的HSV值
    print('h160svm_image[600,800]=', h160svm_image[600, 800])  # 读取H=160后的h160sv_image图像的HSV值

    cv.waitKey()  # 不会自动关闭图像
    cv.destroyAllWindows()  # 释放所有窗口
else:
    print("There is no any photo")

【3】总结

掌握了设置HSV图像HSV值的技巧。

 

 

 

 

 

 

 

 

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

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

相关文章

用QT制作的倒计时软件

一、pro代码 RC_ICONS countdown.ico 二、mainwindow.cpp代码 #include "mainwindow.h" #include "ui_mainwindow.h"#include <QDateTime> #include <QMessageBox> #include <QSettings>MainWindow::MainWindow(QWidget *parent): QM…

VScode MAC按任意键关闭终端 想要访问桌面文件

说明 最近配置MAC上CPP的运行环境&#xff0c;在安装必要的CPP插件后&#xff0c;配置launch和task等json文件后&#xff0c;点击运行三角形&#xff0c;每次都会跳出main想要访问桌面上的文件。并且输出也是在调试控制台&#xff0c;非常逆天。 尝试 尝试1:尽管我尝试将ta…

【一本通】线段

【一本通】线段 C语言代码Java代码C代码 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 数轴上有 n条线段&#xff0c;选取其中 k条线段使得这 k条线段两两没有重合部分&#xff0c;问最大的k为多少? 输入 输入文件segment.in的第一行为…

学习日志024--opencv中处理轮廓的函数

目录 前言​​​​​​​ 一、 梯度处理的sobel算子函数 功能 参数 返回值 代码演示 二、梯度处理拉普拉斯算子 功能 参数 返回值 代码演示 三、Canny算子 功能 参数 返回值 代码演示 四、findContours函数与drawContours函数 功能 参数 返回值 代码演示 …

关于分页的样式问题

在最近写网页的时候遇到了一个关于样式的问题&#xff0c;今天我来跟大家来说一下。像是分页中的颜色效果&#xff0c;斑马纹颜色要注意颜色不要过于深。 这种的颜色就有一点深看着很不舒服&#xff0c;应将当前的颜色改为淡一点的&#xff0c;也可以利用rgba调整透明度&#x…

机器学习周报(12.9-12.15)

文章目录 摘要Abstract 1 Swin Transformer1.1 输入1.2 Patch Partition1.3 Linear Embedding1.4 Patch Merging1.5 Swin Transformer Block1.6 代码总结 摘要 本篇博客介绍了采用类似于卷积核的移动窗口进行图像特征提取的Swin Transformer网络模型&#xff0c;这是一种基于T…

基于Spring Boot的校园车辆管理系统

一、系统背景与意义 随着校园规模的不断扩大和车辆数量的增加&#xff0c;传统的车辆管理方式已经难以满足高效、准确管理车辆的需求。因此&#xff0c;开发一个基于Spring Boot的校园车辆管理系统具有重要的现实意义。该系统可以实现对校园车辆的信息化管理&#xff0c;提高车…

SpringBoot3整合FastJSON2如何配置configureMessageConverters

在 Spring Boot 3 中整合 FastJSON 2 主要涉及到以下几个步骤&#xff0c;包括添加依赖、配置 FastJSON 作为 JSON 处理器等。下面是详细的步骤&#xff1a; 1. 添加依赖 首先&#xff0c;你需要在你的 pom.xml 文件中添加 FastJSON 2 的依赖。以下是 Maven 依赖的示例&#…

隐私清理工具Goversoft Privazer

PrivaZer 是一款专为隐私保护而生的 Windows 系统清理工具&#xff0c;支持深度扫描、清除无用文件和隐私痕迹。 PrivaZer - 深度扫描磁盘&#xff0c;自动清理上网痕迹&#xff0c;全面保护 Windows 的网络隐私 释放磁盘空间 硬盘空间告急&#xff0c;想清理却又无从下手&…

UDP网络编程套接

目录 本文核心 预备知识 1.端口号 认识TCP协议 认识UDP协议 网络字节序 socket编程接口 sockaddr结构 UDP套接字编程 服务端 客户端 TCP与UDP传输的区别 可靠性&#xff1a; 传输方式&#xff1a; 用途&#xff1a; 头部开销&#xff1a; 速度&#xff1a; li…

3.zabbix中文设置

1、zabbix中文设置 2、中文乱码的原因 zabbix使用DejaVuSan.ttf字体&#xff0c;不支持中文&#xff0c;导致中文出现乱码。解决方法很简单&#xff0c;把我们电脑里面字体文件传到zabbix服务器上。 3、解决zabbix乱码方法 3.1、从Window服务器找到相应的字休复制到zabbix S…

【Vue3学习】setup语法糖中的ref,reactive,toRef,toRefs

在 Vue 3 的组合式 API&#xff08;Composition API&#xff09;中&#xff0c;ref、reactive、toRef 和 toRefs 是四个非常重要的工具函数&#xff0c;用于创建和管理响应式数据。 一、ref 用ref()包裹数据,返回的响应式引用对象&#xff0c;包含一个 .value 属性&#xff0…

图书馆管理系统(三)基于jquery、ajax

任务3.4 借书还书页面 任务描述 这部分主要是制作借书还书的界面&#xff0c;这里我分别制作了两个网页分别用来借书和还书。此页面&#xff0c;也是通过获取books.txt内容然后添加到表格中&#xff0c;但是借还的操作没有添加到后端中去&#xff0c;只是一个简单的前端操作。…

springboot450房屋租赁管理系统(论文+源码)_kaic

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统房屋租赁管理系统信息管理难度大&#xff0c;容错率低&am…

vue框架的搭建

1什么是Node.js&#xff1b; Node.js 是一个免费、开源、跨平台的 JavaScript 运行时环境, 它让开发人员能够创建服务器 Web 应用、命令行工具和脚本 Node.js下载&#xff1a; 下载Node 16.20.2 安装Node.js 安装Node.js 测试安装 运行命令行 win键R 查看node版本 输入&am…

TCP基础了解

什么是 TCP &#xff1f; TCP 是面向连接的、可靠的、基于字节流的传输层通信协议。 面向连接&#xff1a;一定是「一对一」才能连接&#xff0c;不能像 UDP 协议可以一个主机同时向多个主机发送消息&#xff0c;也就是一对多是无法做到的&#xff1b; 可靠的&#xff1a;无论…

电商数据采集电商,行业数据分析,平台数据获取|稳定的API接口数据

电商数据采集可以通过多种方式完成&#xff0c;其中包括人工采集、使用电商平台提供的API接口、以及利用爬虫技术等自动化工具。以下是一些常用的电商数据采集方法&#xff1a; 人工采集&#xff1a;人工采集主要是通过基本的“复制粘贴”的方式在电商平台上进行数据的收集&am…

C语言-稀疏数组转置

1.题目要求 2.代码实现 #include <stdio.h> #define MAX_TERM 80// 定义稀疏矩阵结构体 typedef struct juzhen {int row;int col;int value; } Juzhen;// 显示稀疏矩阵 void show(Juzhen a[], int count_a) {printf(" i row col val\n");for (int i 1; i &…

在 Spring Boot 3 中实现基于角色的访问控制

基于角色的访问控制 (RBAC) 是一种有价值的访问控制模型,可增强安全性、简化访问管理并提高效率。它在管理资源访问对安全和运营至关重要的复杂环境中尤其有益。 我们将做什么 我们有一个包含公共路由和受限路由的 Web API。受限路由需要数据库中用户的有效 JWT。 现在用户…

计算机毕业设计python+spark+hive动漫推荐系统 漫画推荐系统 漫画分析可视化大屏 漫画爬虫 漫画推荐系统 漫画爬虫 知识图谱 大数据毕设

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…