根据ROI将numpy数组裁剪并调整为新形状

如何解决根据ROI将numpy数组裁剪并调整为新形状

我有一个numpy数组,我需要根据像(x1,y1)(x2,y2)之类的ROI对其进行切割。 numpy数组的背景颜色为零。

我需要从第一个numpy数组中裁剪该部分,然后将裁剪后的数组调整为(640,480)像素。

我是numpy的新手,我不知道如何执行此操作。

#numpy1: the first numpy array
roi=[(1,2),(3,4)]

解决方法

听起来像您想要进行一些图像处理。因此,我建议您看一下OpenCV库。在其Python实现中,图像基本上是NumPy数组。因此,裁剪和调整大小变得非常容易:

import cv2
import numpy as np

# OpenCV images are NumPy arrays
img = cv2.imread('path/to/your/image.png')        # Just use your NumPy array 
                                                  # instead of loading some image

# Set up ROI [(x1,y1),(x2,y2)]
roi = [(40,40),(120,150)]

# ROI cutout of image
cutout = img[roi[0][1]:roi[1][1],roi[0][0]:roi[1][0],:]

# Generate new image from cutout with desired size
new_img = cv2.resize(cutout,(640,480))

# Just some output for visualization
img = cv2.rectangle(img,roi[0],roi[1],(0,255,0),2)
cv2.imshow('Original image with marked ROI',img)
cv2.imshow('Resized cutout of image',new_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

Original image with marked ROI

Resized cutout of image

----------------------------------------
System information
----------------------------------------
Platform:    Windows-10-10.0.16299-SP0
Python:      3.8.5
NumPy:       1.19.1
OpenCV:      4.4.0
----------------------------------------
,

您可以像这样裁剪数组

array = array[start_x:stop_x,start_y:stop_y]

或者您的情况

array = array[roi[0][0]:roi[0][1],roi[1][0]:roi[1][1]]

或其中之一

array = array[slice(*roi[0]),slice(*roi[1])]
array = array[tuple(slice(*r) for r in roi)]

取决于所需的抽象和过度设计的数量。

,

我建议使用切片和skimage。 skimage.transform.resize是您所需要的。

import matplotlib.pyplot as plt
from skimage import data
from skimage.transform import resize
image = data.camera()

crop = image[10:100,10:100]

crop = resize(crop,480))
plt.imshow(crop)

有关slicing的更多信息,请参见here。 有关skimage的详细信息,请参见here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?