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()
相关推荐
丁学文武4 分钟前
如何把ChatGPT嵌入到自己的应用中?
人工智能·chatgpt·编码·大模型应用·ai替代
dalalajjl13 分钟前
爱派(AiPy):一个让大语言模型直接操作Python完成任务
python
深圳南柯电子18 分钟前
纯电汽车EMC整改:预防性设计节省47%预算|深圳南柯电子
网络·人工智能·汽车·互联网·实验室·emc
说私域20 分钟前
定制开发开源AI智能名片S2B2C商城系统:新零售革命下云零售模式的创新实践
人工智能·开源·零售
zzZ656522 分钟前
U-net 系列算法总结
人工智能·深度学习·机器学习
景彡先生22 分钟前
Python matplotlib详解:从入门到精通,数据可视化利器
python·信息可视化·matplotlib
AI科技星25 分钟前
基于空间螺旋运动假设的水星近日点进动理论推导与验证
数据结构·人工智能·经验分享·算法·计算机视觉
程序员大雄学编程28 分钟前
用Python来学微积分22-费马定理
人工智能·python·数学·微积分
deephub39 分钟前
sklearn 特征选择实战:用 RFE 找到最优特征组合
人工智能·python·机器学习·sklearn·特征选择