opencv-如何获取图像区域特定像素区域大小

需求

通过鼠标框选某个区域,返回这个区域的像素大小。

源码

复制代码
# e:path\to\cal_rectangle_area.py
import cv2  
import numpy as np  

# 初始化变量
image = cv2.imread('./vlcsnap-2024-09-25-10h51m27s007.png')  
if image is None:  
    print("Error: Image could not be read.")  
    exit()  

# 窗口和缩放参数
scale = 1.0
pan_x, pan_y = 0, 0
rectangles = []  # 存储所有矩形框
refPt = []

def draw_rectangle(event, x, y, flags, param):  
    global refPt  
    if event == cv2.EVENT_LBUTTONDOWN:  
        # 计算真实坐标
        real_x = int((x + pan_x) / scale)
        real_y = int((y + pan_y) / scale)
        print(f"Mouse Position (Real): ({real_x}, {real_y})")
        refPt = [[x, y]]  
    elif event == cv2.EVENT_LBUTTONUP and len(refPt) == 1:  
        refPt.append([x, y])  
        rectangles.append(refPt)  # 保存矩形框
        cv2.rectangle(image, tuple(refPt[0]), tuple(refPt[1]), (0, 255, 0), 2)  
        cv2.imshow('image', image)  
        print(f"Width: {abs(refPt[1][0] - refPt[0][0])}, Height: {abs(refPt[1][1] - refPt[0][1])}")  
        refPt = []  

def update_image():
    # 应用缩放和平移
    h, w = image.shape[:2]
    new_image = cv2.resize(image, (int(w * scale), int(h * scale)))
    new_image = new_image[pan_y:pan_y + int(h * scale), pan_x:pan_x + int(w * scale)]
    
    # 绘制所有矩形框
    for rect in rectangles:
        cv2.rectangle(new_image, tuple(rect[0]), tuple(rect[1]), (0, 255, 0), 2)
    
    cv2.imshow('image', new_image)

def crop_and_save_image(x, y):
    # 裁剪图像
    h, w = image.shape[:2]
    x1 = max(x - 320, 0)  # 640/2
    y1 = max(y - 320, 0)  # 640/2
    x2 = min(x + 320, w)  # 640/2
    y2 = min(y + 320, h)  # 640/2

    cropped_image = image[y1:y2, x1:x2]
    cv2.imwrite('cropped_image.png', cropped_image)  # 保存裁剪后的图像
    print(f"Cropped image saved as 'cropped_image.png'.")

# 设置鼠标回调函数  
cv2.namedWindow('image')  
cv2.setMouseCallback('image', draw_rectangle)  

# 显示图像直到有键被按下  
while True:  
    update_image()  # 更新显示的图像
    key = cv2.waitKey(1) & 0xFF  
    if key == ord('q'):  
        break  
    elif key == ord('+'):  # 缩放放大
        scale *= 1.1
    elif key == ord('-'):  # 缩放缩小
        scale /= 1.1
    elif key == ord('w'):  # 向上移动
        pan_y -= 10
    elif key == ord('s'):  # 向下移动
        pan_y += 10
    elif key == ord('a'):  # 向左移动
        pan_x -= 10
    elif key == ord('d'):  # 向右移动
        pan_x += 10
    elif key == ord('c'):  # 输入坐标裁剪图像
        x = int(input("Enter x coordinate: "))
        y = int(input("Enter y coordinate: "))
        crop_and_save_image(x, y)

cv2.destroyAllWindows()
相关推荐
我送炭你添花18 分钟前
Pelco KBD300A 模拟器:03.Pelco-P 协议 8 字节完整拆解 + 与 Pelco-D 一一对应终极对照表
python·测试工具·运维开发
It's now21 分钟前
Spring AI 基础开发流程
java·人工智能·后端·spring
Glad_R28 分钟前
巧用AI流程图,让信息呈现更全面
人工智能·信息可视化·产品运营·流程图·产品经理
R.lin36 分钟前
Java 8日期时间API完全指南
java·开发语言·python
西南胶带の池上桜1 小时前
1.Pytorch模型应用(线性与非线性预测)
人工智能·pytorch·python
杀生丸学AI1 小时前
【无标题】VGGT4D:用于4D场景重建的视觉Transformer运动线索挖掘
人工智能·深度学习·3d·aigc·transformer·三维重建·视觉大模型
小和尚同志1 小时前
还在手动配置?这款开源软件让你一键配置 Claude Code 和 Codex
人工智能·aigc
阿正的梦工坊1 小时前
ProRL:延长强化学习训练,扩展大语言模型推理边界——NeurIPS 2025论文解读
人工智能·语言模型·自然语言处理
致Great2 小时前
Ollama 进阶指南
人工智能·gpt·chatgpt·agent·智能体