python实现图片的ROI(region of interest)和泛洪填充
目录:
(一)ROI操作
(1)获取感兴趣区域
(2)还原操作
(二)泛洪填充floodFill
正文:
(一)ROI操作
感兴趣区(Region of Interest,ROIs) 是图像的一部分,
它通过在图像上选择或使用诸如设定阈值(thresholding) 或者从其他文件(如矢量> 转换获得等方法生成。
感趣区可以是点、线、面不规则的形状,通常用来作为图像分类的样本、掩膜、裁剪区或及其他操作。
原理通过操作图像矩阵来获取或合并指定位置的图像,
(1)获取感兴趣区域
1 src = cv.imread("./1.png") #读取图片
2 cv.namedWindow("input image",cv.WINDOW_AUTOSIZE) #创建GUI窗口,形式为自适应
3 cv.imshow("input image",src) #通过名字将图像和窗口联系
4 print(src.shape)
5 flower = src[200:400,100:250]
6 cv.imshow("flower",flower)
(2)还原操作
1 src = cv.imread("./1.png") #读取图片
2 cv.namedWindow("input image",cv.WINDOW_AUTOSIZE) #创建GUI窗口,形式为自适应
3 cv.imshow("input image",src) #通过名字将图像和窗口联系
4 print(src.shape)
5 flower = src[200:400,100:250]
6 cv.imshow("flower",flower)
7 gray = cv.cvtColor(flower,cv.COLOR_BGR2GRAY) #获取一张灰度图像,单一通道
8 backface = cv.cvtColor(gray,cv.COLOR_GRAY2BGR) #单一通道转3通道
9 src[200:400,100:250] = backface
10 cv.imshow("new image",src)
11 cv.waitKey(0) #等待用户操作,里面等待参数是毫秒,我们填写0,代表是永远,等待用户操作
12 cv.destroyAllWindows() #销毁所有窗口
此时图片会失真,再如:
1 # -*- coding=GBK -*-
2 import cv2 as cv
3 import numpy as np
4
5
6 #截取图片中的指定区域或在指定区域添加某一图片
7 def jie_image(src1):
8 src2 = src1[5:89, 500:630]#截取第5行到89行的第500列到630列的区域
9 cv.imshow("截取", src2)
10 src1[105:189, 300:430] = src2#指定位置填充,大小要一样才能填充
11 cv.imshow("合成", src1)
12
13 src = cv.imread("C://1.jpg")
14 cv.imshow("原来", src)
15 jie_image(src)
16 cv.waitKey(0)
17 cv.destroyAllWindows()
(二)泛洪填充floodFill
1 def floodFill(image, mask, seedPoint, newVal, loDiff=None, upDiff=None, flags=None): # real signature unknown; restored from __doc__
通俗解释:floodFill( 1.操作的图像, 2.掩模, 3.起始像素值,4.填充的颜色, 5.填充颜色的低值, 6.填充颜色的高值 ,7.填充的方法)
所谓的floodFill 漫水填充就是在一张图片中,和种子点像素相差在[-loDiff,+upDiff]的时候就用newVal来填充这个点。
1 1.操作的图像,
2 2.掩码,
3 3.起始像素值, #我们指定的第一个点的三个通道值
4 4.填充的颜色,
5 5.填充颜色的低值, #低值三通道
6 6.填充颜色的高值 , #高值三通道
7 7.填充的方法
1 参数5.填充颜色的低值就是:参数3的三通道值 减去 参数5
2 参数6.填充颜色的高值就是:参数3的三通道值 加上 参数6
1 7.填充的方法
2 彩色图像一般是FLOODFILL_FIXED_RANGE 指定颜色填充
4 还有一种是FLOODFILL_MASK_ONLY,mask的指定的位置为零时才填充,不为零不填充
(1)彩色图片
1 def fill_color_demo(image):
2 copyImg = image.copy()
3 h, w = image.shape[:2]
4 mask = np.zeros([h+2, w+2], np.uint8)
5 cv.floodFill(copyImg, mask, (30, 30), (0, 255, 255), (100, 100, 100), (50, 50, 50), cv.FLOODFILL_FIXED_RANGE)
6 cv.imshow("fill_color_demo", copyImg)
(2)二进制图片
FLOODFILL_MASK_ONLY我们可以自定义填充图像,掩码为1不填充,为0进行填充
1 def fill_binary():
2 image = np.zeros([400,400,3],np.uint8)
3 image[100:300,100:300,:]=255
4 cv.imshow("fill_banary",image)
5
6 mask = np.ones([402,402,1],np.uint8)
7 mask[101:301,101:301] = 0 #这里设置需要加1--->101:301 这是我们填充的图像掩码为0
8 cv.floodFill(image,mask,(200,200),(0,255,0),cv.FLOODFILL_MASK_ONLY) #最好写到我们填充的图像中间
9 cv.imshow("fill_banary2",image)
1.操作的图像,
2.掩码, 为1不填充,为0才进行填充
3.填充图像的中央部分
4.填充的颜色,
5.填充的方法


参考:
https://www.cnblogs.com/ssyfj/p/9261056.html
python实现图片的ROI(region of interest)和泛洪填充的更多相关文章
- [python+opencv] ROI(Range Of Interest)与泛洪填充
python+opencv3.3视频教学 基础入门笔记(贾志刚老师) https://www.bilibili.com/video/av24998616/?p=8 ROI(Range Of Inter ...
- Python提取图片的ROI
图像处理经常需要提取图片的ROI,本文使用Python提取图片的ROI. 使用的Module是PIL (Pillow),一个图像处理库,用到的函数为类 Image 中的 crop 方法. 函数原型为: ...
- [zt] ROI (Region of Interest) 感兴趣区域 OpenCV
在以前介绍IplImage结构的时候,有一个重要的参数——ROI.ROI全称是”Region Of Interest”,即感兴趣的区域.实际上,它是IPL/IPP(这两个是Inter的库)结构IplR ...
- 八 ROI(region of interest)和泛洪填充
一.ROI 感兴趣区(Region of Interest,ROIs) 是图像的一部分,它通过在图像上选择或使用诸如设定阈值(thresholding) 或者从其他文件(如矢量> 转换获得等方法 ...
- Python+OpenCV图像处理(六)—— ROI与泛洪填充
一.ROI ROI(region of interest),感兴趣区域.机器视觉.图像处理中,从被处理的图像以方框.圆.椭圆.不规则多边形等方式勾勒出需要处理的区域,称为感兴趣区域,ROI. 代码如下 ...
- OpenCV---ROI(region of interest)和泛洪填充
一:ROI 感兴趣区(Region of Interest,ROIs) 是图像的一部分,它通过在图像上选择或使用诸如设定阈值(thresholding) 或者从其他文件(如矢量> 转换获得等方法 ...
- python 读取图片的尺寸、分辨率
#需要安装PIL模块 #encoding=gbk#--------------------------------------------------------------------------- ...
- ROI(Region of Interesting)
ROI(region of interest),感兴趣区域.机器视觉.图像处理中,从被处理的图像以方框.圆.椭圆.不规则多边形等方式勾勒出需要处理的区域,称为感兴趣区域,ROI.在Halcon.Ope ...
- 如何用python裁剪图片
如何使用python裁剪图片 如上图所示,这是一张包含了各类象棋棋子的图片.我们需要将其中每一个棋子都裁剪出来,此时可以利用python的 PIL库 实现. 一. 安装PIL库 如果此前没有安装过PI ...
随机推荐
- ubuntu Nginx+tomcat 部署web项目
最近学习了一下java web方面的知识,最后终于把项目部署到了阿里云服务器上,还是遇到了一些难点,记录总结一下 首先就是网上资料中,jdk都比较老了,最新的jdk14,没有了jre,这样导致了tom ...
- dev分支和release是什么
master(主分支) 存在一条主分支(master).所有用户可见的正式版本,都从master发布(也是用于部署生产环境的分支,确保master分支稳定性).主分支作为稳定的唯一代码库,不做任何开发 ...
- 洛谷3648 [APIO2014]序列分割(斜率优化+dp)
首先对于这个题目. qwq 存在一个性质就是,最终的答案只跟你的分割的位置有关,而和顺序无关. 举一个小栗子 \(a\ b\ c\) 将这个东西分成两块. 如果我们先分割\(ab\)之间的话,\(an ...
- 架构师必备:MySQL主从延迟解决办法
上一篇文章介绍了MySQL主从同步的原理和应用,本文总结了MySQL主从延迟的原因和解决办法.如果主从延迟过大,会影响到业务,应当采用合适的解决方案. MySQL主从延迟的表现 先insert或upd ...
- Salesforce 生命周期管理(一)应用生命周期浅谈
本篇参考: https://trailhead.salesforce.com/en/content/learn/trails/determine-which-application-lifecycle ...
- Pytorch 实现简单线性回归
Pytorch 实现简单线性回归 问题描述: 使用 pytorch 实现一个简单的线性回归. 受教育年薪与收入数据集 单变量线性回归 单变量线性回归算法(比如,$x$ 代表学历,$f(x)$ 代表收入 ...
- PG集群(PostgreSql环境)搭建
centos PG集群搭建 一.安装PG 1.安装之前首先查看软件是否已经安装 rpm -qa | grep postgresql #若存在,需要卸载使用 yum remove postgresql ...
- 用C++实现的数独解题程序 SudokuSolver 2.4 及实例分析
SudokuSolver 2.4 程序实现 本次版本实现了 用C++实现的数独解题程序 SudokuSolver 2.3 及实例分析 里发现的第三个不完全收缩 grp 算法 thirdGreenWor ...
- Noip模拟41 2021.8.16
T1 你相信引力吗 对于区间的大小关系问题,往往使用单调栈来解决 这道题的优弧和劣弧很烦,考虑将其等价的转化 由于所有的合法情况绕过的弧都不会经过最高的冰锥, 又因为环可以任意亲定起点,这样可以直接把 ...
- 关于qmake的install
在pro的构建系统中可以设置INSTALLS变量,在make命令之后,执行make install命令触发,将想要的资源拷贝到相应的目录,参考qwt的构建体系,在qwt.pro末尾有这么几句 qwts ...