2015-09-15 3 views
7

Я возиться с OpenCV креплениями для питона некоторого времени теперь, и я хотел бы попробовать согласование шаблона, я получаю эту ошибку, и я понятия не имею, почемуPython OpenCV Template Matching ошибка

C:\builds\master_PackSlaveAddon-win64-vc12-static\opencv\modules\imgproc\src\templmatch.cpp:910: error: (-215) (depth == CV_8U || depth == CV_32F) && type == _templ.type() && _img.dims() <= 2 in function cv::matchTemplate 

Любого человека есть ли какие-либо подсказки относительно того, почему это может произойти?

Исходный код:

import win32gui 
from PIL import ImageGrab 
import win32api, win32con 
import numpy 
deckVar = "deck.png" # Temporary 

def click(x,y): 
    win32api.SetCursorPos((x,y)) 
    win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,x,y,0,0) 
    win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,x,y,0,0) 

margin = 10 

def OOO(): # Order Of Operations 
    print None 

def main(): 
    deck = "test" 

    img = ImageGrab.grab() 

    HWNDHandle = win32gui.FindWindow(None, "Hearthstone"); 
    x,y,x2,y2 = win32gui.GetWindowRect(HWNDHandle) 
    print x,y,x2,y2 
    l = x2-x 
    h = y2-y 
    print l,h 

    img_recog(img,"imgs/my_collection.png") 

def img_recog(img,templ): 
    import cv2 
    import numpy as np 
    from matplotlib import pyplot as plt 


    img2 = numpy.array(img.getdata()).reshape(img.size[0], img.size[1], 3) 
    template = cv2.imread(templ,0) 
    w, h = template.shape[::-1] 

    # All the 6 methods for comparison in a list 
    methods = ['cv2.TM_CCOEFF', 'cv2.TM_CCOEFF_NORMED', 'cv2.TM_CCORR', 
       'cv2.TM_CCORR_NORMED', 'cv2.TM_SQDIFF', 'cv2.TM_SQDIFF_NORMED'] 


    img = img2.copy() 
    method = eval(methods[1]) 

    # Apply template Matching 
    try: 
     res = cv2.matchTemplate(img,template,method) 
    except Exception as e: 
     print str(e) 
     raw_input() 
    min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res) 


    # If the method is TM_SQDIFF or TM_SQDIFF_NORMED, take minimum 
    if method in [cv2.TM_SQDIFF, cv2.TM_SQDIFF_NORMED]: 
     top_left = min_loc 
    else: 
     top_left = max_loc 
    bottom_right = (top_left[0] + w, top_left[1] + h) 

    return cv2.rectangle(img,top_left, bottom_right, 255, 2) 


main() 
+0

Я отредактировал исходный код вопроса (ссылки могут сломаться в будущем). Если вы не хотите отображать полный код, отредактируйте вопрос, оставляя [mcve] (http://stackoverflow.com/help/mcve) – Miki

+0

Не следует ли применять 'matchTemplate' к' img2' вместо ' img'? Вы создаете бота для heartstone? : D – Miki

+0

@Miki. Возможно, вам будет плохо, если это будет работать, и написать и написать мои выводы позже: D, нет, я не делаю бота. Следуйте репозиторию github, если хотите, вы можете найти конечный продукт интересным. – Frederikxyz

ответ

10

Обратите внимание на сообщение об ошибке:

error: (-215) (depth == CV_8U || depth == CV_32F) && type == _templ.type() && _img.dims() <= 2 in function cv::matchTemplate

Это означает, что тип данных изображения должен быть CV_8U или CV_32F, и он должен иметь 3 или меньше каналов ,

Если вы не знаете, что CV_8U, значит, CV_32F, см. this list.

Возможно, вы передаете несколько объектов, отличных от np.uint8 или np.float32. вы можете легко конвертировать Numpy DTYPE в 8-битные или 32-бит с помощью:

img.astype(np.float32) 
img.astype(np.uint8) 

Просто обратите внимание, что OpenCV ожидают CV_8U 8-битные данные, чтобы быть в диапазоне 0..255 и CV_32F может быть в любой ассортимент.

Смежные вопросы