python如何查找圖片按鈕的坐標(biāo)位置
python查找圖片按鈕的坐標(biāo)位置
因?yàn)闃I(yè)務(wù)需求,了解到一些python自動(dòng)化的內(nèi)容,其中有類似于airtest截圖點(diǎn)擊的東西。
本來是想使用pyautogui來實(shí)現(xiàn)獲取圖片坐標(biāo)的功能,但是pyautogui對(duì)于小尺寸的圖片識(shí)別不準(zhǔn)確,或者說是識(shí)別不到,一番查找之下,發(fā)現(xiàn)另一個(gè)工具,做了封裝如下。
1,使用pyaut
x, y=pyautogui.locateCenterOnScreen("img_path") # 如果查找到值,會(huì)返回坐標(biāo)的元組,找不到返回None。上面的寫法會(huì)報(bào)錯(cuò) print(x, y) pyautogui.click(x,y) # 點(diǎn)擊操作
2,使用aircv
def matchImg(imgobj,confidence=0.7): """ imgobj:待查找的圖片 confidence:最低相似度 """ # 截取桌面操作,寫入內(nèi)存中,不必每次都保存實(shí)體圖片 screenshotIm = screenshot(region=None) desktop = np.array(screenshotIm) imobj = ac.imread(imgobj) return ac.find_template(desktop ,imobj,confidence) if __name__ == "__main__": imgobj = 'img_path' print(matchImg(imgsrc,imgobj,confidencevalue))
返回值包含桌面大小,中心點(diǎn),和待查詢圖片的四角坐標(biāo)。否則為None
讀取圖片區(qū)域坐標(biāo)的方法記錄
首先是導(dǎo)入需要使用的庫:
import cv2 import time import win32gui, win32ui, win32con import os
1、然后是獲取需要的圖片或者無需獲取,已有圖片。(可通過直接截取圖片)
'''1、窗口截圖,直接獲取當(dāng)前最前面的全屏幕截圖''' def window_capture(filename,w=1920,h=1080): hwnd = 0 # 窗口的編號(hào),0號(hào)表示當(dāng)前活躍窗口 # 根據(jù)窗口句柄獲取窗口的設(shè)備上下文DC(Divice Context) hwndDC = win32gui.GetWindowDC(hwnd) # 根據(jù)窗口的DC獲取mfcDC mfcDC = win32ui.CreateDCFromHandle(hwndDC) # mfcDC創(chuàng)建可兼容的DC saveDC = mfcDC.CreateCompatibleDC() # 創(chuàng)建bigmap準(zhǔn)備保存圖片 saveBitMap = win32ui.CreateBitmap() # 為bitmap開辟空間 saveBitMap.CreateCompatibleBitmap(mfcDC, w, h) # 高度saveDC,將截圖保存到saveBitmap中 saveDC.SelectObject(saveBitMap) # 截取從左上角(0,0)長寬為(w,h)的圖片 saveDC.BitBlt((0, 0), (w, h), mfcDC, (0, 0), win32con.SRCCOPY) saveBitMap.SaveBitmapFile(saveDC, filename) return True
2、將獲取的圖片路徑,傳遞給識(shí)別圖片坐標(biāo)的函數(shù)。
g_rectangle = [0, 0, 0, 0] #設(shè)置初始值坐標(biāo) clicked = False g_startPoint = [0, 0] #設(shè)置初始值獲取的坐標(biāo) def startRoi(path): cv2.namedWindow("IMG_Show", 0) # 創(chuàng)建畫布 cv2.resizeWindow("IMG_Show", 1920, 1080) # 設(shè)置長和寬 cv2.setMouseCallback("IMG_Show", onMouse) # 連接鼠標(biāo) # 按"Esc"退出 print("如果想要退出窗口,點(diǎn)擊按鈕 ESC,退出窗口...") while cv2.waitKey(30) != 27: #監(jiān)聽事件 global frame frame = cv2.imread(path,cv2.IMREAD_COLOR) #讀取圖片數(shù)據(jù) # 畫矩形 ''' 由(x_min,x_max)組成,為繪制的邊框的左上角; (g_rectangle[0], g_rectangle[1]), (g_rectangle[2], g_rectangle[3]):設(shè)置為繪制的邊框的左上角和繪制的邊框的右下角 (0, 0, 255):指定邊框的顏色,由(B,G,R)組成,當(dāng)為(255,0,0)時(shí)為綠色,可以自由設(shè)定; 1:線條的粗細(xì)值,為正值時(shí)代表線條的粗細(xì)(以像素為單位) ''' cv2.rectangle(frame, (g_rectangle[0], g_rectangle[1]), (g_rectangle[2], g_rectangle[3]), (0, 0, 255), 2) cv2.imshow("IMG_Show", frame) # cv2.destroyWindow("IMG_Show") ''' event:當(dāng)前發(fā)生的鼠標(biāo)事件類型 x和y:發(fā)生鼠標(biāo)事件時(shí)鼠標(biāo)在圖像位置的x,y坐標(biāo) flags: cv2_EVENT_FLAG_* (MouseEventFlags)類型的變量 param: 自定義的傳遞給 setMouseCallback 函數(shù)調(diào)用的參數(shù) ''' # x和y: 發(fā)生鼠標(biāo)事件時(shí)鼠標(biāo)在圖像位置的x,y坐標(biāo) def onMouse(event, x, y, flags, param): global clicked global g_rectangle global g_startPoint if event == cv2.EVENT_MOUSEMOVE: # 滑動(dòng) if clicked == True: #當(dāng)鼠標(biāo)點(diǎn)擊時(shí),打印一下信息 g_rectangle[0] = g_startPoint[0] g_rectangle[1] = g_startPoint[1] #實(shí)時(shí)獲取,對(duì)應(yīng)變化后的x,y坐標(biāo) g_rectangle[2] = x g_rectangle[3] = y print("坐標(biāo):%s" % g_rectangle) # 左鍵按下事件 if event == cv2.EVENT_LBUTTONDOWN: # 左鍵點(diǎn)擊 #獲取鼠標(biāo)第一時(shí)間點(diǎn)擊的坐標(biāo) g_startPoint[0] = x g_startPoint[1] = y clicked = True # 左鍵彈起事件 if event == cv2.EVENT_LBUTTONUP: # 左鍵放開 print("====================選中框的坐標(biāo):===========================") print("矩形框左上角坐標(biāo):") print(g_rectangle[0], g_rectangle[1]) print("矩形框右下角坐標(biāo):") print(g_rectangle[2], g_rectangle[3]) print("矩形框?qū)挾龋?) print(g_rectangle[2]-g_rectangle[0]) print("矩形框高度:") print(g_rectangle[3]-g_rectangle[1]) clicked = False
3、通過畫布顯示,在上面可以進(jìn)行畫框 ,自動(dòng)識(shí)別出圖片區(qū)域的坐標(biāo)。(如下圖)
4、全部代碼展示:
''' 讀取圖片的坐標(biāo) ''' import cv2 import time import win32gui, win32ui, win32con import os '''1、窗口截圖''' def window_capture(filename,w=1920,h=1080): hwnd = 0 # 窗口的編號(hào),0號(hào)表示當(dāng)前活躍窗口 # 根據(jù)窗口句柄獲取窗口的設(shè)備上下文DC(Divice Context) hwndDC = win32gui.GetWindowDC(hwnd) # 根據(jù)窗口的DC獲取mfcDC mfcDC = win32ui.CreateDCFromHandle(hwndDC) # mfcDC創(chuàng)建可兼容的DC saveDC = mfcDC.CreateCompatibleDC() # 創(chuàng)建bigmap準(zhǔn)備保存圖片 saveBitMap = win32ui.CreateBitmap() # 為bitmap開辟空間 saveBitMap.CreateCompatibleBitmap(mfcDC, w, h) # 高度saveDC,將截圖保存到saveBitmap中 saveDC.SelectObject(saveBitMap) # 截取從左上角(0,0)長寬為(w,h)的圖片 saveDC.BitBlt((0, 0), (w, h), mfcDC, (0, 0), win32con.SRCCOPY) saveBitMap.SaveBitmapFile(saveDC, filename) return True g_rectangle = [0, 0, 0, 0] #設(shè)置初始值坐標(biāo) clicked = False g_startPoint = [0, 0] def startRoi(path): cv2.namedWindow("IMG_Show", 0) # 創(chuàng)建畫布 cv2.resizeWindow("IMG_Show", 1920, 1080) # 設(shè)置長和寬 cv2.setMouseCallback("IMG_Show", onMouse) # 連接鼠標(biāo) # 按"Esc"退出 print("如果想要退出窗口,點(diǎn)擊按鈕 ESC,退出窗口...") while cv2.waitKey(30) != 27: #監(jiān)聽事件 global frame frame = cv2.imread(path,cv2.IMREAD_COLOR) #讀取圖片數(shù)據(jù) # 畫矩形 ''' 由(x_min,x_max)組成,為繪制的邊框的左上角; (g_rectangle[0], g_rectangle[1]), (g_rectangle[2], g_rectangle[3]):設(shè)置為繪制的邊框的左上角和繪制的邊框的右下角 (0, 0, 255):指定邊框的顏色,由(B,G,R)組成,當(dāng)為(255,0,0)時(shí)為綠色,可以自由設(shè)定; 1:線條的粗細(xì)值,為正值時(shí)代表線條的粗細(xì)(以像素為單位) ''' cv2.rectangle(frame, (g_rectangle[0], g_rectangle[1]), (g_rectangle[2], g_rectangle[3]), (0, 0, 255), 2) cv2.imshow("IMG_Show", frame) # cv2.destroyWindow("IMG_Show") ''' event:當(dāng)前發(fā)生的鼠標(biāo)事件類型 x和y:發(fā)生鼠標(biāo)事件時(shí)鼠標(biāo)在圖像位置的x,y坐標(biāo) flags: cv2_EVENT_FLAG_* (MouseEventFlags)類型的變量 param: 自定義的傳遞給 setMouseCallback 函數(shù)調(diào)用的參數(shù) ''' # x和y: 發(fā)生鼠標(biāo)事件時(shí)鼠標(biāo)在圖像位置的x,y坐標(biāo) def onMouse(event, x, y, flags, param): global clicked global g_rectangle global g_startPoint if event == cv2.EVENT_MOUSEMOVE: # 滑動(dòng) if clicked == True: #當(dāng)鼠標(biāo)點(diǎn)擊時(shí),打印一下信息 g_rectangle[0] = g_startPoint[0] g_rectangle[1] = g_startPoint[1] #實(shí)時(shí)獲取,對(duì)應(yīng)變化后的x,y坐標(biāo) g_rectangle[2] = x g_rectangle[3] = y print("坐標(biāo):%s" % g_rectangle) # 左鍵按下事件 if event == cv2.EVENT_LBUTTONDOWN: # 左鍵點(diǎn)擊 #獲取鼠標(biāo)第一時(shí)間點(diǎn)擊的坐標(biāo) g_startPoint[0] = x g_startPoint[1] = y clicked = True # 左鍵彈起事件 if event == cv2.EVENT_LBUTTONUP: # 左鍵放開 print("====================選中框的坐標(biāo):===========================") print("矩形框左上角坐標(biāo):") print(g_rectangle[0], g_rectangle[1]) print("矩形框右下角坐標(biāo):") print(g_rectangle[2], g_rectangle[3]) print("矩形框?qū)挾龋?) print(g_rectangle[2]-g_rectangle[0]) print("矩形框高度:") print(g_rectangle[3]-g_rectangle[1]) clicked = False if __name__ == '__main__': path = r"./save_img/jietu.jpg" if not os.path.isdir: os.mkdir(path) ret = window_capture(filename=path) time.sleep(0.2) if ret == True: startRoi(path)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
從Pytorch模型pth文件中讀取參數(shù)成numpy矩陣的操作
這篇文章主要介紹了從Pytorch模型pth文件中讀取參數(shù)成numpy矩陣的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03Python中flatten( )函數(shù)及函數(shù)用法詳解
flatten是numpy.ndarray.flatten的一個(gè)函數(shù),即返回一個(gè)一維數(shù)組。這篇文章主要介紹了Python中flatten( )函數(shù),需要的朋友可以參考下2018-11-11python常用數(shù)據(jù)結(jié)構(gòu)集合詳解
這篇文章主要介紹了python常用數(shù)據(jù)結(jié)構(gòu)集合詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助2022-08-08淺談keras 的抽象后端(from keras import backend as K)
這篇文章主要介紹了淺談keras 的抽象后端(from keras import backend as K),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06