OpenCv(二)——边界填充、阈值处理

news2025/4/14 2:07:16

目录

一、边界填充

(1)constant边界填充,填充指定宽度的像素

 (2)REFLECT镜像边界填充

(3)REFLECT_101镜像边界填充改进

(4) REPLICATE使用最边界的像素值代替

 (5)WRAP上下左右边依次替换

二、阈值处理【重要】

(1)读取图片并显示

(2)图像二值化处理,变为纯白和纯黑的图片

(3) 图像二值化处理并反转,将偏白色转化为纯黑色,将偏黑色转化为纯白色

(4) 当图片的数值超过阈值,则将该数值定为该阈值,低于阈值的数值保持不变

 (5)当图片的数值超过阈值,则保持不变,低于阈值的数值则设置为0,效果是将图片变暗。

 (6)当图片的数值超过阈值,则设置为0,低于阈值的数值则保持不变。

三、图像通道及表示知识补充


一、边界填充

cv2.copyMakeBorder()是OpenCV库中的一个函数,用于给图像添加额外的边界(padding)。

copyMakeBorder(src, top,bottom, left, right, borderType, value)

它有以下几个参数:

        src:要扩充边界的原始图像。

        top, bottom, left, right:相应方向上的边框宽度,要求是int整数类型的。

        borderType:定义要添加边框的类型,它可以是以下的一种:

        cv2.BORDER_CONSTANT:添加的边界框像素值为常数(需要额外再给定一个参数)。        

        cv2.BORDER_REFLECT:添加的边框像素将是边界元素的镜面反射,类似于gfedcba|abcdefgh|hgfedcba。 (交界处也复制了)

        cv2.BORDER_REFLECT_101 或 cv2.BORDER_DEFAULT:和上面类似,但是有一些细微的不同,类似于gfedcb|abcdefgh|gfedcba (交接处删除了)

cv2.BORDER_REPLICATE:使用最边界的像素值代替,类似于aaaaaa|abcdefgh|hhhhhhh cv2.BORDER_WRAP:上下左右边依次替换,cdefgh|abcdefgh|abcdefg

        value:是指示图像填充边界的颜色,这里的颜色可以查找色码表,或者是线上颜色提取获取到目标颜色的RGB的值。

(1)constant边界填充,填充指定宽度的像素

 cv2.BORDER_CONSTANT:添加的边界框像素值为常数(需要额外再给定一个参数value设置填充的颜色)。        

import cv2
ys = cv2.imread('yueshan.png')    #读取原图,每个边界填充都需要在原图的基础上完成,所以在使用时要先读取原图,把原图作为参数传入下面的方法中
ys=cv2.resize(ys,dsize=None,fx=0.5,fy=0.5)  #  图片缩放
# ys=cv2.resize(ys,(640,480))    #图片大小调整
top,bottom,left,right = 50,50,50,50

constant = cv2.copyMakeBorder(ys,top,bottom,left,right,borderType=cv2.BORDER_CONSTANT,value=(229,25,80))

cv2.imshow('yuantu', ys)
cv2.waitKey(0)
cv2.imshow('CONSTANT', constant)
cv2.waitKey(0)

效果:

 

 (2)REFLECT镜像边界填充

 cv2.BORDER_REFLECT:添加的边框像素将是边界元素的镜面反射,“|”的两边是填充的内容,类似于gfedcba|abcdefgh|hgfedcba。 (交界处也复制了)

reflect = cv2.copyMakeBorder(ys,top,bottom,left,right,borderType=cv2.BORDER_REFLECT)
cv2.imshow('REFLECT', reflect)
cv2.waitKey(0)

 效果:

(3)REFLECT_101镜像边界填充改进

cv2.BORDER_REFLECT_101 或 cv2.BORDER_DEFAULT:和上面类似,但是有一些细微的不同,“|”的两边是填充的内容,类似于gfedcb|abcdefgh|gfedcba (交接处删除了),这里的边界a和h被删除了

reflect101 = cv2.copyMakeBorder(ys,top,bottom,left,right,borderType=cv2.BORDER_REFLECT101)
cv2.imshow('REFLECT_101', reflect101)
cv2.waitKey(0)

 效果:这里与reflect对比的效果不是特别明显

(4) REPLICATE使用最边界的像素值代替

cv2.BORDER_REPLICATE:使用最边界的像素值代替,“|”的两边是填充的内容,类似于aaaaaa|abcdefgh|hhhhhhh

replicate = cv2.copyMakeBorder(ys,top,bottom,left,right,borderType=cv2.BORDER_REPLICATE)
cv2.imshow('REPLICATE', replicate)
cv2.waitKey(0)

 效果:

 (5)WRAP上下左右边依次替换

cv2.BORDER_WRAP:上下左右边依次替换,“|”的两边是填充的内容,cdefgh|abcdefgh|abcdefg

wrap = cv2.copyMakeBorder(ys,top,bottom,left,right,borderType=cv2.BORDER_WRAP)
cv2.imshow('WRAP', wrap)
cv2.waitKey(0)

 效果:

二、阈值处理【重要】

阈值处理是指剔除图像内像素值高于一定值或低于一定值的像素点。使用的方法为:
retval,dst=cv2.threshold(src,thresh,maxval,type)

threshold函数总共有两个返回值
        retval代表返回的阈值
        dst代表阈值分割结果图像,与原始图像具有相同的大小和类型

参数:

        src代表要进行阈值分割的图像,可以是多通道的(彩色的RGB三通道),8位或32位浮点型数值
        thresh代表要设定的阈值
        maxval代表type参数位THRESH_BINARY或者THRESH_BINARY_INV类型时,需要设定的最大值
type代表阈值分割的类型,具体内容如下表所示:
     选项                             像素值>thresh              其他情况
cv2.THRESH_BINARY         maxval                          0
cv2.THRESH_BINARY_INV         0                       maxval
cv2.THRESH_TRUNC          thresh                      当前灰度值
cv2.THRESH_TOZERO         当前灰度值                   0
cv2.THRESH_TOZERO_INV         0                    当前灰度值

(1)读取图片并显示

imread转换灰度图有两种方法,方法一:cv2.imread('zl.png',cv2.COLOR_BGR2GRAY)

方法二:cv2.imread('zl.png',0)

import cv2
image = cv2.imread('zl.png',0) #灰度图,
cv2.imshow('gray', image)  #原灰度图
cv2.waitKey(0)

(2)图像二值化处理,变为纯白和纯黑的图片

cv2.THRESH_BINARY 大于当前设置的阈值则将该点的设置为最大值,其他情况则为0

ret, binary = cv2.threshold(image, 175, 255, cv2.THRESH_BINARY)
cv2.imshow('binary', binary)  #偏白的变纯白,偏黑的变纯黑
cv2.waitKey(0)

(3) 图像二值化处理并反转,将偏白色转化为纯黑色,将偏黑色转化为纯白色

cv2.THRESH_BINARY_INV 大于当前设置的阈值则将该点的设置为0,其他情况则为最大值

ret1, binaryinv = cv2.threshold(image, 175, 255, cv2.THRESH_BINARY_INV)
cv2.imshow('binaryinv', binaryinv)  #偏白的变纯黑,偏黑的变纯白
cv2.waitKey(0)

(4) 当图片的数值超过阈值,则将该数值定为该阈值,低于阈值的数值保持不变

cv2.THRESH_TRUNC大于当前设置的阈值则将该点的设置为阈值,其他情况则为当前的灰度值即保持不变

ret2, trunc = cv2.threshold(image, 175, 255, cv2.THRESH_TRUNC)
cv2.imshow('trunc', trunc)   #白色变得一样灰蒙蒙,偏黑的不变
cv2.waitKey(0)

 (5)当图片的数值超过阈值,则保持不变,低于阈值的数值则设置为0,效果是将图片变暗。

cv2.THRESH_TOZERO_INV 大于当前设置的阈值则将该点的设置为当前灰度值,保持不变,其他情况则为0

ret3, tozero = cv2.threshold(image, 175, 255, cv2.THRESH_TOZERO)
cv2.imshow('tozero', tozero)  #偏白色不变,偏黑的就变纯黑
cv2.waitKey(0)

 (6)当图片的数值超过阈值,则设置为0,低于阈值的数值则保持不变。

cv2.THRESH_TOZERO_INV 大于当前设置的阈值则将该点的设置为0,其他情况则为当前灰度值,保持不变

ret4, tozeroinv = cv2.threshold(image, 175, 255, cv2.THRESH_TOZERO_INV)
cv2.imshow( 'tozeroinv', tozeroinv)   #偏白色变纯黑,偏黑的不变
cv2.waitKey(0)

三、图像通道及表示知识补充

一张灰色图片上有许许多多的像素块,每个像素块都有一个数值,这个数值的取值范围时[0 ~ 255],数值越小颜色越暗越黑,数值越大颜色越亮表现为越白。

彩色图片则有三个通道RGB,针对每一个通道都有一个对应的值,以上面介绍边界填充的value为例,value=(229,25,80),需要注意,在opencv中通道的顺序为BGR,也就是B=229,G=25,R=80.分别是英文的缩写,蓝色(blue)绿色(green)红色(red).

上面的阈值也是指一个在0~255之间的值。

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

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

相关文章

理解OSPF Stub区域和各类LSA特点

之前学习到OSPF特殊区域和各类类型LSA的分析后,一直很混乱,在网上也难找到详细的解释,在看了 HCNP书本内容后,对这块类容理解更加清晰,本次内容,我们使用实验示例,来对OSPF特殊区域和各 类型LSA…

CAN/FD CAN总线配置 最新详解 包含理论+实战(附带源码)

看前须知:本篇文章不会说太多理论性的内容(重点在理论结合实践),顾及实操,应用,一切理论内容支撑都是为了后续实际操作进行铺垫,重点在于读者可以看完文章应用。(也为节约读者时间&a…

MoE Align Sort在医院AI医疗领域的前景分析(代码版)

MoE Align & Sort技术通过优化混合专家模型(MoE)的路由与计算流程,在医疗数据处理、模型推理效率及多模态任务协同中展现出显著优势,其技术价值与应用意义从以下三方面展开分析: 一、方向分析 1、提升医疗数据处理效率 在医疗场景中,多模态数据(如医学影像、文本…

【已解决】Webstorm 每次使用 git pull/push 都要输入令牌/密码登录

解决办法:勾上【使用凭据帮助程序】(英文:Use credential helper)

软路由安装指南

1.openwrt下载 : 选择合适的安装包,我用的软路由CPU主板是j3160,属于X86_64架构,所以筛选的时候使用X86_64的安装镜像 openwrt的官方地址可能国内打不开,需要科学上网 openwrt安装镜像下载地址 我准备用U盘引导小主机开机,进而安装openwrt操作系统,所以下载 .img.gz 文…

3500 阶乘求和

3500 阶乘求和 ⭐️难度&#xff1a;中等 &#x1f31f;考点&#xff1a;2023、思维、省赛 &#x1f4d6; &#x1f4da; import java.util.Scanner;public class Main {public static void main(String[] args) {long sum 0;for(int i1;i<50;i) { // 之后取模都相等su…

软件工程(应试版)图形工具总结(二)

遇到的问题&#xff0c;都有解决方案&#xff0c;希望我的博客能为你提供一点帮助。 教材参考《软件工程导论&#xff08;第六版&#xff09;》 七、 层次图&#xff08;H图&#xff09;与HIPO图 1、概述 1.1、层次图&#xff08;Hierarchy Chart / H图&#xff09; ​核心…

思维链、思维树、思维图与思维森林在医疗AI编程中的应用蓝图

在医疗AI编程中,思维链(Chain of Thought, CoT)、思维树(Tree of Thoughts, ToT)、思维图(可能指知识图谱或逻辑图)以及思维森林(Forest-of-Thought, FoT)等技术框架通过模拟人类认知和推理过程,显著提升了AI在复杂医疗场景中的决策能力和可解释性: 1. 思维链(CoT)…

1.Qt信号与槽

本篇主要介绍信号和槽&#xff0c;如何关联信号和槽以及用QPixmap在窗口中自适应显示图片 本文部分ppt、视频截图原链接&#xff1a;[萌马工作室的个人空间-萌马工作室个人主页-哔哩哔哩视频] 1. 信号 一般不需要主动发送信号&#xff0c;只有自定义的一些控件才需要做信号的…

MySQL 基础入门

写在前面 关于MySQL的下载安装和其图形化软件Navicat的下载安装,网上已经有了很多的教程,这里就不再赘述了,本文主要是介绍了关于MySQL数据库的基础知识。 MySQL数据库 MySQL数据库基础 MySQL数据库概念 MySQL 数据库&#xff1a; 是一个关系型数据库管理系统 。 支持SQL语…

数据分析与知识发现 论文阅读【信息抽取】

文章目录 基于知识蒸馏的半监督古籍实体抽取数据集模型实验结果 基于大语言模型的专利命名实体识别方法研究数据集评估公式实验 基于数据增强和多任务学习的突发公共卫生事件谣言识别研究数据集实验结果 参考 基于知识蒸馏的半监督古籍实体抽取 数据集 本文在有监督数据集的基…

Compose组件转换XML布局

文章目录 学习JetPack Compose资源前言&#xff1a;预览界面的实现Compose组件的布局管理一、Row和Colum组件&#xff08;LinearLayout&#xff09;LinearLayout&#xff08;垂直方向 → Column&#xff09;LinearLayout&#xff08;水平方向 → Row&#xff09; 二、相对布局 …

Linux开发工具——vim

&#x1f4dd;前言&#xff1a; 上篇文章我们讲了Linux开发工具——apt&#xff0c;这篇文章我们来讲讲Linux开发工具——vim &#x1f3ac;个人简介&#xff1a;努力学习ing &#x1f4cb;个人专栏&#xff1a;Linux &#x1f380;CSDN主页 愚润求学 &#x1f304;其他专栏&a…

Vue3学习二

认识组件的嵌套 还可以将Main中内容再划分 scoped防止组件与组件之间的样式相互污染 组件的通信 父子组件之间通信的方式 父组件传递给子组件 给传过来的内容做限制 type为传的内容的属性类型&#xff0c;required为true表示该内容是必须传的&#xff0c;default为&#xff0c…

[ deepseek 指令篇章 ]300个领域和赛道喂饭级deepseek指令

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

2024第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组

记录刷题的过程、感悟、题解。 希望能帮到&#xff0c;那些与我一同前行的&#xff0c;来自远方的朋友&#x1f609; 大纲&#xff1a; 1、握手问题-&#xff08;解析&#xff09;-简单组合问题&#xff08;别人叫她 鸽巢定理&#xff09;&#x1f607;&#xff0c;感觉叫高级了…

C++ | C++11知识点

前言&#xff1a; 本篇内容讲述了C11中比较重要的内容为&#xff1a;右值引用、可变参数模板、lambda表达式和包装器。 ps&#xff1a;包装器博主在另一篇文章讲述的&#xff0c;本篇文章包装器板块为原文链接。 C11知识点目录 花括号初始化自定义类型的花括号初始化内…

LeetCode 1123.最深叶节点的最近公共祖先 题解

昨天写了三题&#xff0c;今天目前为止写了一题&#xff0c;玩了会游戏稍微休息了下 先来理解一下今天的题目&#xff0c;今天的题目类型是递归遍历找最深位置&#xff0c;先通过几个样例了解一下 输入&#xff1a;root [3,5,1,6,2,0,8,null,null,7,4] 输出&#xff1a;[2,7,…

工具介绍 | SafeLLMDeploy教程来了 保护本地LLM安全部署

SafeLLMDeploy&#xff1a;保护本地大语言模型安全部署的“守护者” 在AI技术飞速发展的今天&#xff0c;大语言模型&#xff08;LLM&#xff09;如GPT、DeepSeek等正以前所未有的方式改变着我们的工作和生活。然而&#xff0c;本地部署这些强大的AI系统在带来便利的同时&…

机器学习-04-分类算法-03KNN算法案例

实验名称 K近邻算法实现葡萄酒分类 实验目的 通过未知品种的拥有13种成分的葡萄酒&#xff0c;应用KNN分类算法&#xff0c;完成葡萄酒分类&#xff1b; 熟悉K近邻算法应用的一般过程&#xff1b; 通过合理选择K值从而提高分类得到正确率&#xff1b; 实验背景 本例实验…