将图像分割成多个网格

5 python opencv cv2

我使用以下代码将图像分成 20 个相等的网格部分

import cv2

im =  cv2.imread("apple.jpg")
im = cv2.resize(im,(1000,500))
imgwidth=im.shape[0]
imgheight=im.shape[1]


y1 = 0
M = imgwidth//20
N = imgheight//20

for x in range(0,imgwidth,M):
    for y in range(0, imgheight, N):
        x1 = x + M
        y1 = y + N
        tiles = im[x:x+M,y:y+N]

        print(y1)
        cv2.rectangle(im, (x, y), (x1, y1), (0, 255, 0))
        cv2.imwrite("save/" + str(y)+".png",tiles)

cv2.imwrite("asas.png",im)
Run Code Online (Sandbox Code Playgroud)

但是我有两个问题,

  1. 保存的图像大小不统一
  2. 它只在图像的一半而不是全部上绘制网格。

我怎样才能解决这个问题?

sga*_*zvi 8

有一些混乱,我猜是由如何numpy使用(row, column)约定处理图像尺寸和坐标以及 OpenCV 如何使用(x, y)约定处理它们引起的。

数组的shape成员numpy包含第一个索引处的图像高度和第二个索引处的宽度。

用于命名约定的通常约定是M图像的行数或高度,而图像N的列数或宽度。

另一个问题是,并非所有子图像都被保存,因为名称仅使用y变量分配,最终由于重复y. 保存所有子图像需要唯一名称。一种可能的方法是同时使用两者xy生成唯一名称。

以下是修复了所有上述问题的工作代码。

import cv2

im =  cv2.imread("apple.jpg")
im = cv2.resize(im,(1000,500))

imgheight=im.shape[0]
imgwidth=im.shape[1]

y1 = 0
M = imgheight//20
N = imgwidth//20

for y in range(0,imgheight,M):
    for x in range(0, imgwidth, N):
        y1 = y + M
        x1 = x + N
        tiles = im[y:y+M,x:x+N]

        cv2.rectangle(im, (x, y), (x1, y1), (0, 255, 0))
        cv2.imwrite("save/" + str(x) + '_' + str(y)+".png",tiles)

cv2.imwrite("asas.png",im)
Run Code Online (Sandbox Code Playgroud)