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()
相关推荐
恋猫de小郭7 小时前
AI 正在造就你的「认知卸载」,但是时代如此
前端·人工智能·ai编程
飞哥数智坊14 小时前
我的“龙虾”罢工了!正好对比下GLM、MiniMax、Kimi 3家谁更香
人工智能
风象南15 小时前
很多人说,AI 让技术平权了,小白也能乱杀老师傅 ?
人工智能·后端
董董灿是个攻城狮16 小时前
大模型连载1:了解 Token
人工智能
花酒锄作田18 小时前
使用 pkgutil 实现动态插件系统
python
RoyLin19 小时前
沉睡三十年的标准:HTTP 402、生成式 UI 与智能体原生软件的时代
人工智能
needn21 小时前
TRAE为什么要发布SOLO版本?
人工智能·ai编程
毅航21 小时前
自然语言处理发展史:从规则、统计到深度学习
人工智能·后端
前端付豪1 天前
LangChain链 写一篇完美推文?用SequencialChain链接不同的组件
人工智能·python·langchain
ursazoo1 天前
写了一份 7000字指南,让 AI 帮我消化每天的信息流
人工智能·开源·github