python-opencv创建空白图

使用 python-opencv 创建背景图片,进行边缘提取出。

创建空白图片

单通道

import cv2
import numpy as np

img = np.zeros((10, 10), np.uint8)
# 浅灰色背景
img.fill(200)
cv2.imshow('img', img)
cv2.waitKey(0)

三通道彩色图

import cv2
import numpy as np

img = np.zeros((10, 10, 3), np.uint8)
# 浅灰色背景
img.fill(200)
cv2.imshow('img', img)
cv2.waitKey(0)

使用背景图参与运算

import cv2
import numpy as np

img = cv2.imread('./test.jpg')
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
Y_min=np.array([20,120,110])
Y_max=np.array([30,255,180])  
img_bin = np.inRange(hsv, Ymin, Y_max)
model = np.zeros((img.shape[0], img.shape[1]))
contours, hierarchy = cv2.findContours(img_bin.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

报错:

cv2.error: OpenCV(4.2.0) /io/opencv/modules/imgproc/src/contours.cpp:197: error: (-210:Unsupported format or combination of formats) [Start]FindContours supports only CV_8UC1 images when mode != CV_RETR_FLOODFILL otherwise supports CV_32SC1 images only in function 'cvStartFindContours_Impl

修改:

import cv2
import numpy as np

img = cv2.imread('./test.jpg')
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
Y_min=np.array([20,120,110])
Y_max=np.array([30,255,180])  
img_bin = np.inRange(hsv, Ymin, Y_max)
- model = np.zeros((img.shape[0], img.shape[1]))
+ model = np.zeros((img.shape[0], img.shape[1]), np.uint8)
contours, hierarchy = cv2.findContours(img_bin.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
  • 10
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Python中,可以使用OpenCV库来实现将多张小图片组合成一张大的功能。具体实现步骤如下: 首先,我们需要导入OpenCV库和NumPy库: import cv2 import numpy as np 然后,我们需要定义一个函数来组合多张小图片为一张大: def combine_images(image_list, rows=1, cols=1): # 计算大的宽度和高度 width = image_list[0].shape[1] height = image_list[0].shape[0] combined_width = width * cols combined_height = height * rows # 创建一张空白的大 combined_image = np.zeros((combined_height, combined_width, 3), np.uint8) # 将小图片复制到大中的对应位置 current_row = 0 current_col = 0 for image in image_list: combined_image[current_row*height:(current_row+1)*height, current_col*width:(current_col+1)*width] = image current_col += 1 if current_col == cols: current_col = 0 current_row += 1 return combined_image 接下来,我们可以准备一些需要合并的小图片,然后调用combine_images函数进行合并: # 读取小图片 image1 = cv2.imread('image1.jpg') image2 = cv2.imread('image2.jpg') image3 = cv2.imread('image3.jpg') # 将小图片放入列表中 image_list = [image1, image2, image3] # 合并小图片为一张大 combined_image = combine_images(image_list, rows=2, cols=2) 最后,我们可以通过cv2.imshow函数来显示合并后的大,并通过cv2.imwrite函数将大保存到本地: # 显示大 cv2.imshow('Combined Image', combined_image) cv2.waitKey(0) # 保存大 cv2.imwrite('combined_image.jpg', combined_image) 这样,我们就成功地将多张小图片组合成了一张大。 ### 回答2: Python-opencv库可以很方便地将多张图片组合成一张大。首先,我们需要导入cv2和numpy库。然后,创建一个空白的大,大小要足够容纳所有小的组合。然后,用cv2.imread()函数读取所有小,并使用cv2.resize()调整它们的大小以适应大的要求。接下来,我们需要计算每个小的位置,并将它们放置在大上。最后,使用cv2.imshow()函数显示大。 具体的步骤如下: 1. 导入cv2和numpy库。 ```python import cv2 import numpy as np ``` 2. 创建一个空白的大。 ```python big_image = np.zeros((height, width, 3), dtype=np.uint8) ``` 3. 使用cv2.imread()函数读取小,并用cv2.resize()函数调整大小。 ```python image1 = cv2.imread('image1.jpg') image1 = cv2.resize(image1, (img_width, img_height)) image2 = cv2.imread('image2.jpg') image2 = cv2.resize(image2, (img_width, img_height)) # 其他小的读取和调整大小同理 ``` 4. 计算每个小在大中的位置,并放置在大上。 ```python big_image[x1:x2, y1:y2] = image1 big_image[x3:x4, y3:y4] = image2 # 其他小的位置计算和放置同理 ``` 5. 使用cv2.imshow()函数显示大。 ```python cv2.imshow('Big Image', big_image) cv2.waitKey(0) ``` 通过以上步骤,我们就可以将多张小组合成一张大了。 ### 回答3: Python-opencv是一个强大的像处理库,它提供了多种功能和方法来处理和操作像。为了将多张图片组成一张大,我们可以使用python-opencv中的一些方法实现。 首先,我们需要导入opencv库并读取所有要组合的图片。可以使用cv2模块的imread方法来读取图片。读取的图片可以保存在一个列表中。 接下来,我们需要确定大的大小,以便容纳所有的小图片。可以使用cv2模块的resize方法来调整小图片的大小,使其具有相同的尺寸。 然后,我们可以创建一个空白的大,使用cv2模块的numpy.zeros方法创建一个具有足够大小的全黑矩阵。大的大小应该是小图片的大小乘以小的数量,可以根据需要进行调整。 在将小图片放置到大中之前,我们需要选择一个合适的算法来确定每个小图片的位置。这取决于你想要的布局方式。例如,如果你想要将小图片平均分布在大中,可以使用一个嵌套的循环来确定每个小图片的位置。 最后,我们可以使用cv2模块的numpy的数组操作方法来将小图片复制到大中的相应位置。你可以使用numpy的切片操作来选择和复制小图片。 完成以上步骤后,我们可以将大保存到本地或显示在屏幕上,以供进一步使用或查看。 以上就是使用python-opencv将多张图片组成一张大的简单方法。当然,如果需要更复杂的布局和像处理操作,还可以使用更多的opencv方法和技巧。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值