单击左键后如何在拖动鼠标的同时继续绘制矩形?

时间:2016-08-14 16:15:00

标签: image opencv events

我已经了解了如何捕获鼠标移动以绘制矩形,方法是先单击左键,然后拖动鼠标然后释放左键。我的代码如下。但是,我想要在单击左键后将鼠标移到图像上时继续绘制矩形。

不幸的是,现在,只有在我最后释放左按钮后才显示矩形。

# import the necessary packages
import argparse
import cv2

# initialize the list of reference points and boolean indicating
# whether cropping is being performed or not
refPt = []
cropping = False

def click_and_crop(event, x, y, flags, param):
    # grab references to the global variables
global refPt, cropping, image
drag = 0
# if the left mouse button was clicked, record the starting
# (x, y) coordinates and indicate that cropping is being
# performed
if event == cv2.EVENT_LBUTTONDOWN:
    refPt = [(x, y)]
        drag = 1
    cropping = True

# check to see if the left mouse button was released
elif event == cv2.EVENT_LBUTTONUP:
    # record the ending (x, y) coordinates and indicate that
    # the cropping operation is finished
    refPt.append((x, y))
    cropping = False

    # draw a rectangle around the region of interest
    cv2.rectangle(image, refPt[0], refPt[1], (0, 255, 0), 2)
    cv2.imshow("image", image)

elif event == cv2.EVENT_MOUSEMOVE and drag == 1:
    #image = clone.copy()
    cv2.rectangle(image, refPt[0], (x, y), (0, 255, 0), 2)

# load the image, clone it, and setup the mouse callback function
image = cv2.imread("image_00001.jpg")
clone = image.copy()
cv2.namedWindow("image")
cv2.setMouseCallback("image", click_and_crop)

# keep looping until the 'q' key is pressed
while True:
# display the image and wait for a keypress
    cv2.imshow("image", image)
    key = cv2.waitKey(1) & 0xFF

# if the 'r' key is pressed, reset the cropping region
if key == ord("r"):
    image = clone.copy()

# if the 'c' key is pressed, break from the loop
elif key == ord("c"):
    break

# if there are two reference points, then crop the region of interest
# from teh image and display it
if len(refPt) == 2:
    roi = clone[refPt[0][1]:refPt[1][1], refPt[0][0]:refPt[1][0]]
    cv2.imshow("ROI", roi)
    cv2.waitKey(0)

# close all open windows
cv2.destroyAllWindows()

1 个答案:

答案 0 :(得分:0)

尝试以下代码:


import cv2

refPt = []

final_boundaries = []
image = None


def click_and_crop(event, x, y, flags, param):
    global refPt, image
    if event == cv2.EVENT_LBUTTONDOWN:
        refPt = [(x, y)]
    elif event == cv2.EVENT_LBUTTONUP:
        refPt.append((x, y))
        final_boundaries.append((refPt[0],refPt[1]))
        cv2.rectangle(image, refPt[0], refPt[1], (0, 255, 0), 2)
        cv2.imshow("image", image)
    elif event == cv2.EVENT_MOUSEMOVE and flags == cv2.EVENT_FLAG_LBUTTON:
        clone = image.copy()
        cv2.rectangle(clone, refPt[0], (x, y), (0, 255, 0), 2)
        cv2.imshow("image", clone)


def main(image_name):
    global image
    image = cv2.imread("image.png") #convert to image boundary
    cv2.namedWindow("image")
    cv2.setMouseCallback("image", click_and_crop)
    cv2.imshow("image", image)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    return (final_boundaries)