私はOpenCVを使用して画像を表示するだけの次のコードを持っています:
import numpy as np
import cv2
class LoadImage:
def loadImage(self):
self.img=cv2.imread('photo.png')
cv2.imshow('Test',self.img)
self.pressedkey=cv2.waitKey(0)
# Wait for ESC key to exit
if self.pressedkey==27:
cv2.destroyAllWindows()
# Start of the main program here
if __name__=="__main__":
LI=LoadImage()
LI.loadImage()
写真が入ったウィンドウが表示されたら、コンソール(ターミナル)に写真をクリックしたときのマウスの位置を表示したいと思います。これを実行する方法がわかりません。何か助けてください?
これは、左ボタンのダブルクリックをキャプチャするマウスコールバック関数の例です。
def draw_circle(event,x,y,flags,param):
global mouseX,mouseY
if event == cv2.EVENT_LBUTTONDBLCLK:
cv2.circle(img,(x,y),100,(255,0,0),-1)
mouseX,mouseY = x,y
次に、その関数を、マウスクリックをキャプチャするウィンドウにバインドする必要があります
img = np.zeros((512,512,3), np.uint8)
cv2.namedWindow('image')
cv2.setMouseCallback('image',draw_circle)
次に、無限の処理ループ(または必要なもの)で
while(1):
cv2.imshow('image',img)
k = cv2.waitKey(20) & 0xFF
if k == 27:
break
Elif k == ord('a'):
print mouseX,mouseY
このコードは何をしますか?
作成される黒いウィンドウ内をダブルクリックするたびに、マウスの位置がグローバル変数mouseX
&mouseY
に格納されます。
Elif k == ord('a'):
print mouseX,mouseY
ボタンを押すたびに、現在保存されているマウスクリック位置が出力されます。
ここから コード「借用」
以下は私の実装です:
クリック位置を保存する必要はありません。表示するだけです。
def onMouse(event, x, y, flags, param):
if event == cv2.EVENT_LBUTTONDOWN:
# draw circle here (etc...)
print('x = %d, y = %d'%(x, y))
setMouseCallback('WindowName', onMouse')
コードの他の場所の位置を使用する場合は、以下の方法を使用して座標を取得できます。
posList = []
def onMouse(event, x, y, flags, param):
global posList
if event == cv2.EVENT_LBUTTONDOWN:
posList.append((x, y))
cv2.setMouseCallback('WindowName', onMouse)
posNp = numpy.array(posList) # convert to numpy for other usages
import cv2
cv2.imshow("image", img)
cv2.namedWindow('image')
cv2.setMouseCallback('image', on_click)
def on_click(event, x, y, p1, p2):
if event == cv2.EVENT_LBUTTONDOWN:
cv2.circle(lastImage, (x, y), 3, (255, 0, 0), -1)
PyIgnitionライブラリをPygameからopencv2に移植しました。 https://github.com/bunkahle/particlescv2 でコードを見つけます。Python用のパーティクルエンジンの使用方法に関する例もいくつかあります。
さまざまなマウスクリックイベントを実行することで、画像上でのマウス位置のクリックを検出できます。
マウスクリックイベントを実行する際に覚えておくべきことの1つは、cv2.imshowまたはcv2.namedWindow
次のstackoverflowの投稿でpython 3.xとopencvを使用する作業コードを回答として与えました: https://stackoverflow.com/a/60445099/11493115 ==
より良い説明については、上記のリンクを参照してください。
コード:
import cv2
import numpy as np
#This will display all the available mouse click events
events = [i for i in dir(cv2) if 'EVENT' in i]
print(events)
#This variable we use to store the pixel location
refPt = []
#click event function
def click_event(event, x, y, flags, param):
if event == cv2.EVENT_LBUTTONDOWN:
print(x,",",y)
refPt.append([x,y])
font = cv2.FONT_HERSHEY_SIMPLEX
strXY = str(x)+", "+str(y)
cv2.putText(img, strXY, (x,y), font, 0.5, (255,255,0), 2)
cv2.imshow("image", img)
if event == cv2.EVENT_RBUTTONDOWN:
blue = img[y, x, 0]
green = img[y, x, 1]
red = img[y, x, 2]
font = cv2.FONT_HERSHEY_SIMPLEX
strBGR = str(blue)+", "+str(green)+","+str(red)
cv2.putText(img, strBGR, (x,y), font, 0.5, (0,255,255), 2)
cv2.imshow("image", img)
#Here, you need to change the image name and it's path according to your directory
img = cv2.imread("D:/pictures/abc.jpg")
cv2.imshow("image", img)
#calling the mouse click event
cv2.setMouseCallback("image", click_event)
cv2.waitKey(0)
cv2.destroyAllWindows()