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()
相关推荐
sali-tec2 天前
C# 基于OpenCv的视觉工作流-章27-图像分割
图像处理·人工智能·opencv·算法·计算机视觉
saoys2 天前
Opencv 学习笔记:腐蚀操作 + 轮廓标记 + 分水岭分割
笔记·opencv·学习
saoys2 天前
Opencv 学习笔记:距离变换(DIST_L1 算法实战 + 归一化)
笔记·opencv·学习
guygg883 天前
图像匹配技术:相关匹配、Hausdorff距离匹配与基于距离变换的Hausdorff距离匹配
图像处理·opencv·计算机视觉
AI科技星3 天前
物理世界的几何建构:论统一场论的本体论革命与概念生成
人工智能·opencv·线性代数·算法·矩阵
fie88893 天前
基于Matlab实现的指纹识别系统流程
opencv·计算机视觉·matlab
sali-tec3 天前
C# 基于OpenCv的视觉工作流-章26-图像拼接
图像处理·人工智能·opencv·算法·计算机视觉
智驱力人工智能3 天前
机场鸟类活动智能监测 守护航空安全的精准工程实践 飞鸟检测 机场鸟击预防AI预警系统方案 机场停机坪鸟类干扰实时监测机场航站楼鸟击预警
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
Σίσυφος19004 天前
OpenCV 之双线性插值
人工智能·opencv·计算机视觉
格林威4 天前
Baumer相机金属粉末铺粉均匀性评估:用于增材制造过程监控的 7 个实用技巧,附 OpenCV+Halcon 实战代码!
人工智能·opencv·视觉检测·制造·工业相机·智能相机·堡盟相机