- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我得到了一些养牛场的图像。每个图像假设只覆盖两笔(小牛房)。但是,相机也会覆盖相邻的笔。我需要摆脱邻近笔的区域。
输入图像 -
输出图像 -
我已经尝试了以下命令并且它完成了工作。但是,它缩小了图像的大小,并使第 2 行中生成的边界框大小的输出。输出变得比原始图像小。在这种情况下,原始图像为 2560x1440,但输出为 2536x1406。
import cv2
import numpy as np
import matplotlib.pyplot as plt
frame = cv2.imread("input.jpg")
# pts - location of the 4 corners of the roi
pts = np.array([[6, 1425],[953, 20 ],[1934, 40 ], [2541,1340]])
rect = cv2.boundingRect(pts)
x, y, w, h = rect
croped = frame[y:y + h, x:x + w].copy()
pts = pts - pts.min(axis=0)
mask = np.zeros(croped.shape[:2], np.uint8)
cv2.drawContours(mask, [pts], -1, (255, 255, 255), -1, cv2.LINE_AA)
frame_roi = cv2.bitwise_and(croped, croped, mask=mask)
cv2.imwrite("output.jpg", frame_roi)
但是,我需要输出图像与输入图像大小相同,并且 ROI 之外的任何内容都是黑/白的(如下所示,虽然它是不同的图片)。白色或黑色蒙版区域都可以使用(上面的输出是黑色的,下面的手工编辑图像是白色的)。有没有办法用 opencv 或任何其他库来做到这一点?
最佳答案
错误在这一行
mask = np.zeros(croped.shape[:2], np.uint8)
这应该与您的原始/输入图像的大小完全相同。因此,将其更改为原始形状应该会给出正确的输出图像。
mask = np.zeros(original_image.shape, np.uint8)
这是输出图像的形状
(1440L, 2560L, 3L)
import cv2
import numpy as np
original_frame = cv2.imread("1.jpg")
frame = original_frame.copy()
# pts - location of the 4 corners of the roi
pts = np.array([[6, 1425],[953, 20],[1934, 40], [2541,1340]])
(x,y,w,h) = cv2.boundingRect(pts)
pts = pts - pts.min(axis=0)
mask = np.zeros(original_frame.shape, np.uint8)
cv2.drawContours(mask, [pts], -1, (255, 255, 255), -1, cv2.LINE_AA)
result = cv2.bitwise_and(original_frame, mask)
cv2.imshow('mask', mask)
cv2.imshow('result', result)
cv2.imwrite('result.png', result)
print(result.shape)
cv2.waitKey(0)
关于python - 在不改变图像大小的情况下屏蔽 ROI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56486024/
我正在从事中间阶段的视频处理项目,需要用另一幅图像的 ROI(相同维度)替换某些图像的 ROI。有内置函数吗?? 最佳答案 您可以使用 Mat::copyTo 在 Mat 实例之间传输内容: cv::
我过去曾这样做过并且运行良好,但我的功能很奇怪。我正在尝试提取图像的投资返回率。这是我的代码: cv::Rect roi(x - 1, y - 1, 3, 3); cv::Mat patch_t(cu
我有真菌图像数据集,每个图像都有其 ROI 掩码。我想使用给定的掩码并从真菌图像中提取 ROI。 以下是我想使用一些机器学习技术提取 ROI 的掩码。 提前致谢。 最佳答案 您需要做的是,使用掩码作为
我有一个非矩形 ROI 的图像,由二值掩码图像定义。 在 OpenCV 中,如何将 ROI 外的像素设置为 ROI 内最接近的像素值?类似于 cv::BORDER_REPLICATE 中的内容,或类似
晚上好! 我的问题如下: 1.roi的形状只应该是200,200。这里显示 313,313,我不确定为什么。 2.当我将 roi 的 frame 切换为 imshow() 的参数时,结果也不是正确的
我对图像 ROI 的特征提取很感兴趣,这些特征将用作支持 vector 机的特征向量输入。要提取的特征包括纹理(颜色共现/haralick 特征)和颜色(rgb-直方图,4 bins 和均值 r,g,
我目前正在尝试运行EfficientPS(https://github.com/vincrichard/EfficientPS)。当我开始训练时,网络的初始化由于属于Detectron2的关键错误而崩
After applying mask original image import cv2 import dlib import numpy as np img = cv2.imread("Aayus
我试过在不同的网站上搜索解释,但我没有得到一个完整解释的答案。 import cv2 import numpy as np img1 = cv2.imread('3D-Matplotlib.png')
我的问题是关于如何仅将 Mat 的 roi 的 header 复制到 Mat 的另一个 roi 以避免复制整个 Mat 的数据以节省计算时间。 例如,我的源 Mat 的 roi 为 Mat src(c
我组织(开发API的中间件)中的软件开发团队正在准备一次采用至少一种最佳实践。列表中有以下内容: 单元测试(实际意义上), 自动化的单元测试 测试驱动设计与开发, 静态代码分析 持续集成能力等。 有人
我有一个视频序列,其中一帧如下所示。我试图使用角点检测来找到纸张上矩形的边缘。 我正在使用 Shi-Tomasi 角点检测器。然而,它从图像的背景中检测到许多我不需要的其他东西。我怎样才能将我的投资返
我正在尝试使用 opencv C++ 检测图像中固定重复模式的 ROI。 我试图找到的投资返回率 - 如图所示用红色边界显示: 我在模糊后尝试了精明的边缘检测,但它检测到垂直/水平黑白线的边缘。这不是
我目前正在使用足迹识别项目进行动物识别。我的主要任务是处理取自天然基质的动物足迹,并识别足迹所属的动物。第一步是预处理图像并提取 ROI。这是我遇到困难的地方,因为处理后的图像包含很多噪音。 我已经执
我正在寻找一种方法来找到感兴趣的非正方形区域。我在这里看到了所有基于矩形的示例。例如here they find the tilted rectangle .我看过像 this SO page 这样的
OpenCV 如何处理感兴趣区域 (ROI)? 假设我使用 cvSetImageROI() 设置了一个感兴趣区域。该 ROI 是否存储在 IplImage 结构中? 如果是这样,当我将图像传递给 cv
我得到了一些养牛场的图像。每个图像假设只覆盖两笔(小牛房)。但是,相机也会覆盖相邻的笔。我需要摆脱邻近笔的区域。 输入图像 - 输出图像 - 我已经尝试了以下命令并且它完成了工作。但是,它缩小了图像的
在我的项目中,我想裁剪图像的 ROI。为此,我创建了一个包含感兴趣区域的 map 。现在我想裁剪具有最重要像素的区域(黑色不重要,白色很重要)。 有人知道如何实现它吗?我认为这是一个最大化问题 下图中
我有一个电影文件,我感兴趣的是记录一个点的运动;圆形特征的中心是特定的。我正在尝试使用 Matlab 中的边缘检测和角点检测技术来执行此操作。 要执行此操作,我该如何指定视频中的感兴趣区域?子图是个好
我在提取非直线 ROI 时遇到了问题。到目前为止,我有以下内容: cv::RotatedRect face_rotated_roi(rotated_center, face_roi.size(), r
我是一名优秀的程序员,十分优秀!