opencv 圆形roi
时间: 2023-09-14 07:07:33 浏览: 95
要提取圆形的ROI区域,可以通过使用掩膜的方法来实现。首先,根据你提供的代码,找到感兴趣的圆形区域。然后,创建一个与原图像尺寸相同的掩膜,将掩膜上的圆形区域填充为白色,其他区域填充为黑色。最后,将原图像和掩膜进行融合,即可得到提取的ROI图像。
以下是一个示例代码,可以实现提取圆形ROI和融合实验:
```python
import cv2
import numpy as np
# 读取图片
img = cv2.imread("test.jpg", cv2.IMREAD_UNCHANGED)
# 定义感兴趣区域矩阵
face = np.ones((200, 200, 3))
# 显示原始图像
cv2.imshow("Demo", img)
# 提取圆形ROI
x, y, len = 150, 100, 100
mask = np.zeros(img.shape[:2], dtype=np.uint8)
cv2.circle(mask, (x, y), len, (255), -1)
roi = cv2.bitwise_and(img, img, mask=mask)
# 在原图像上融合ROI
img = roi
# 显示融合结果
cv2.imshow("face", img)
# 等待显示
cv2.waitKey(0)
cv2.destroyAllWindows()
```
这段代码中,我们首先读取了原始图像,并定义了一个200x200的矩阵作为感兴趣区域。然后,根据提供的圆心坐标和半径,创建了一个掩膜mask,并将圆形区域填充为白色。接下来,使用`cv2.bitwise_and`函数将原图像与掩膜进行按位与操作,提取出圆形ROI。最后,将提取的ROI融合到原图像中的相应位置上,并显示融合结果。
请注意,这只是一个示例代码,具体的圆心坐标和半径需要根据实际情况进行调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [跟我学Python图像处理丨获取图像属性、兴趣ROI区域及通道处理](https://blog.csdn.net/m0_59485658/article/details/124595867)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* [opencv-之圆形ROI的提取](https://blog.csdn.net/weixin_52646021/article/details/115433237)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文