OpenCV 学习3 - 裁剪图像

裁剪是为了从图像中删除不需要的对象或区域,或为了突出图像的特定特征。

1、数组切片

图像本质是多维数组(NumPy数组),OpenCV图像裁剪的原理是基于数组切片操作。

  • 裁剪坐标说明

(0,0) ──────────→ x (width)

│ (x1,y1)──────┐

│ │ │

│ └─────────(x2,y2)

y (height)

python 复制代码
cropped_img = image[y_start:y_end, x_start:x_end]

2、代码示例:显示和保存裁剪区域的图像

python 复制代码
import cv2
import numpy as np
import os


img_path = "img/dog.jpg"
if not os.path.exists(img_path):
    raise FileNotFoundError(f"未找到图像文件{img_path}")

img = cv2.imread(img_path, cv2.IMREAD_COLOR)

# 显示裁剪的图像
cropped_image = img[100:500, 50:450]
cv2.imshow("cropped_image", cropped_image)

# 保存裁剪后的图像
cv2.imwrite("img/cropped_dog.jpg", cropped_image)

cv2.waitKey(0)
cv2.destroyAllWindows()

3、代码示例:给图像画九宫格

python 复制代码
import cv2
import numpy as np
import os

img_path = "img/dog.jpg"
if not os.path.exists(img_path):
    raise FileNotFoundError(f"未找到图像文件{img_path}")

img = cv2.imread(img_path, cv2.IMREAD_COLOR)

img_height = img.shape[0]
img_width = img.shape[1]

w_sum = 0
h_sum = 0

patche_w = 230
patche_h = 306

for h in range(0, img_height, patche_h):
    for w in range(0, img_width, patche_w):
        
        if (img_height - h) < patche_h or (img_width - w) < patche_w:
            break
        
        h_sum = h + patche_h
        w_sum = w + patche_w

        if w_sum >= img_width and h_sum >= img_height: # 超过图像宽度和高度
            w_sum = img_width - 1
            h_sum = img_height - 1
            cv2.rectangle(img, (w, h), (w_sum, h_sum), (255, 255, 255), 2)
        elif h_sum >= img_height: # 超过图像高度
            h_sum = img_height - 1
            cv2.rectangle(img, (w, h), (w_sum, h_sum), (255, 255, 255), 2)
        elif w_sum >= img_width: # 超过图像宽度
            w_sum = img_width - 1
            cv2.rectangle(img, (w, h), (w_sum, h_sum), (255, 255, 255), 2)
        else:
            cv2.rectangle(img, (w, h), (w_sum, h_sum), (255, 255, 255), 2)

cv2.imshow("img", img)
cv2.waitKey(0)
cv2.destroyAllWindows()
相关推荐
大佬,救命!!!2 小时前
C++本地配置OpenCV
开发语言·c++·opencv·学习笔记·环境配置
Mrliu__3 小时前
Opencv(十八) : 图像凸包检测
人工智能·opencv·计算机视觉
sponge'5 小时前
opencv学习笔记12:GAN网络
笔记·opencv·学习
南极星10055 小时前
OPENCV(python)--初学之路(十二)霍夫线/圆变换
人工智能·opencv·计算机视觉
AndrewHZ6 小时前
【图像处理基石】如何用OpenCV入门计算机视觉?
图像处理·深度学习·opencv·算法·计算机视觉·机器视觉·cv
社会零时工16 小时前
NVIDIA Jetson开发板使用记录——开发环境搭建
qt·opencv·nvidia
吃肉夹馍不要夹馍1 天前
【opencv图片倾斜矫正】
人工智能·opencv·计算机视觉
azoo1 天前
cv::Mat 取元素引起的报错
c++·opencv·计算机视觉
java1234_小锋1 天前
[免费]基于Python的车辆车牌识别系统(PyTorch2卷积神经网络CNN+OpenCV实现)【论文+源码+SQL脚本】
python·opencv·cnn·车牌识别