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

【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转HSVhsv_image = cv.cvtColor(bgr_image, cv.COLOR_BGR2HSV)  # BGR转HSVcv.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通道取值=160cv.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转HSVhsv_image = cv.cvtColor(bgr_image, cv.COLOR_BGR2HSV)  # BGR转HSVcv.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通道取值=160cv.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.mzph.cn/diannao/64566.shtml

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

相关文章

CEF127 编译指南 MacOS 篇 - 编译 CEF(六)

1. 引言 经过前面的准备工作,我们已经完成了所有必要的环境配置。本文将详细介绍如何在 macOS 系统上编译 CEF127。通过正确的编译命令和参数配置,我们将完成 CEF 的构建工作,最终生成可用的二进制文件。 2. 编译前准备 2.1 确认环境变量 …

关于小程序内嵌h5打开新的小程序

关于小程序内嵌h5打开新的小程序 三种方式 https://juejin.cn/post/7055551463489011749 只依赖于h5本身的就是 https://huaweicloud.csdn.net/64f97ebb6b896f66024ca16c.html https://juejin.cn/post/7055551463489011749 navigateToMiniProgram 故小程序webview里的h5无法…

开发平台接口规范:北斗终端->北斗三号卫星->指挥机(北斗终端)->北斗短报文融合平台->客户平台(上行)| 时空信息产品

文章目录 引言I 技术架构和业务流程技术架构北斗终端信息流II 渠道接口验证签名白名单IP渠道配置表设计III 其他辅助功能TCP 发送消息到消息中心nginx转发网关服务异常捕获日志采集IV 知识扩展对请求参数进行校验引言 开发平台的应用场景:平台需要开发能力给下游平台需要接收上…

知识分享第三十天-力扣343.(整数拆分)

343 整数拆分 给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。 示例 1: 输入: 2 输出: 1 解释: 2 1 1, 1 1 1。 示例 2: 输入: 10 输出: 36 解释: 10 3 3 4, 3 3 4 36。 说明: 你可…

搭建Tomcat(六)---Response的实现

目录 引入 一、前端项目容器的搭建 重建项目: 1.创建一个新的项目: 2.创建HTML文件 3.将先前编写的所有tomcatJava文件挪过来 二、配置java文件 1.重启一下MyTomcat 2.配置两个工具包 ①FileUtil ②ResponseUtil(响应头) 三、处理…

机械鹦鹉与真正的智能:大语言模型推理能力的迷思

编者按: 大语言模型真的具备推理能力吗?我们是否误解了"智能"的本质,将模式匹配误认为是真正的推理? 本文深入探讨了大语言模型(LLMs)是否真正具备推理能力这一前沿科学问题,作者的核…

.net winform 实现CSS3.0 泼墨画效果

效果图 代码 private unsafe void BlendImages1(Bitmap img1, Bitmap img2) {// 确定两个图像的重叠区域Rectangle rect new Rectangle(0, 0,Math.Min(img1.Width, img2.Width),Math.Min(img1.Height, img2.Height));// 创建输出图像,尺寸为重叠区域大小Bitmap b…

短视频矩阵:构建多平台曝光的高效运营网络

在当今这个瞬息万变的数字化时代,短视频以其独特的魅力迅速占领了人们的视野,成为信息传播与娱乐消遣的重要一环。随着短视频平台的不断增多和用户群体的日益庞大,如何精准高效地利用短视频进行品牌推广和产品营销,成为了众多企业…

ubuntu+ros新手笔记(三):21讲没讲到的MoveIt2

系统ubuntu22.04 ros2 humble 1 安装MoveIt2 安装参照在ROS2中,通过MoveIt2控制Gazebo中的自定义机械手 安装 MoveIt2可以选择自己编译源码安装,或者直接从二进制安装。 个人建议直接二进制安装,可以省很多事。 sudo apt install ros-humbl…

DotNetBrowser 3.0.0 正式发布!

🛠️ 重要消息:DotNetBrowser 3.0.0 正式发布! 我们很高兴向您介绍全新的 DotNetBrowser 3.0.0 版本。此次更新带来了多项重要功能与优化,进一步提升了 Web 开发的效率和体验。 📢 DotNetBrowser 3.0.0 包含哪些新功…

在 Visual Studio Code 中编译、调试和执行 Makefile 工程 llama2.c

在 Visual Studio Code 中编译、调试和执行 Makefile 工程 llama2.c 1. Installing the extension (在 Visual Studio Code 中安装插件)1.1. Extensions for Visual Studio Code1.2. C/C1.2.1. Pre-requisites 1.3. Makefile Tools 2. Configuring your project (配置项目)2.1.…

EfficientNet:对模型深度、宽度和分辨率的混合缩放策略

论文:https://arxiv.org/abs/1905.11946 项目:https://github.com/tensorflow/tpu/tree/master/models/official/efficientnet Pytorch实现:EfficientNet模型Pytorch版本具体实现-CSDN博客 一、概况 1、概述: 这张图可以清晰明…

大模型学习笔记------SAM模型详解与思考

大模型学习笔记------SAM模型详解与思考 1、SAM框架概述2、Segment Anything Task3、Segment Anything Model SAM模型是Meta 提出的分割一切模型(Segment Anything Model,SAM)突破了分割界限,极大地促进了计算机视觉基础模型的发展…

【嵌入式软件】跑开发板的前置服务配置

在嵌入式开发中,通常需要在 开发板和主机之间共享、传输和挂载文件。 这篇文章是关于如何在 Ubuntu 中配置 Samba、TFTP 和 NFS 协议的详细步骤。这些协议分别用于远程文件共享、文件传输和内核挂载文件系统。 如何安装协议: 参考:ubuntu18配置:详细的内容我手写了一份文档。…

02、服务器的分类和开发项目流程

硬件介绍 1、服务器分类2.开发流程 1、服务器分类 1.1 服务器分类 1u服务器(u表示服务器的厚度) 1U4.45cm; 4u服务器(u表示服务器的厚度) , 服务器有两个电源模块,接在不同的电源,…

图像生成工具WebUI

介绍 Stable Diffusion WebUI(AUTOMATIC1111,简称A1111)是一个为高级用户设计的图形用户界面(GUI),它提供了丰富的功能和灵活性,以满足复杂和高级的图像生成需求。如今各种人工智能满天飞&…

面试经典题目:LeetCode274_H指数

leetcode274——H指数 暴力循环代码分析性能分析 方法1:排序加线性扫描算法步骤: 方法2:计数排序(适用于引用次数有上限)算法步骤: 题目链接:leetcode274_H指数 暴力循环 class Solution { publ…

【前端爬虫】关于如何获取自己的请求头信息(user-agent和cookie)

注意:由于user-agent和cookie中保存了部分账户信息,所以一定不要随意泄露给他人!!! 1.首先打开某个页面,点击键盘的F12键进入控制台,或者鼠标右键页面选择打开控制台 2.然后点击控制台上方的网…

将java项目部署到linux

命令解析 Dockerfile: Dockerfile 是一个文本文件,包含了所有必要的指令来组装(build)一个 Docker 镜像。 docker build: 根据 Dockerfile 或标准指令来构建一个新的镜像。 docker save: 将本地镜像保存为一个 tar 文件。 docker load: 从…

Chrome 浏览器原生功能截长屏

我偶尔需要截取一些网页内容作为素材,但偶尔内容很长无法截全,需要多次截屏再拼接,过于麻烦。所以记录下这个通过浏览器原生功能截长屏的方案。 注意 这种方案并不是百分百完美,如果涉及到一些需要滚动加载的数据或者悬浮区块&am…