проблемы с H264 и OpenCV для Python - PullRequest
0 голосов
/ 07 мая 2018

Здравствуйте. Я пытаюсь выполнить потоковую передачу из gopro с помощью 3DR соло, используя telnet, h264 и opencv в python.

Сначала я запускаю в одном терминале: телнет 10.1.1.1 5502

, который запускает sololink.sdp, который содержит:

c=IN IP4 10.1.1.1
m=video 5600 RTP/AVP 96
a=rtpmap:96 H264/90000
t=0 0

тогда, когда я запускаю в другом терминале: python colortracking.py Я получил эти ошибки:

[h264 @ 0x2206440] negative number of zero coeffs at 35 30
[h264 @ 0x2206440] error while decoding MB 35 30
[h264 @ 0x2231920] out of range intra chroma pred mode at 24 30
[h264 @ 0x2231920] error while decoding MB 24 30
[h264 @ 0x2206440] out of range intra chroma pred mode at 29 32
[h264 @ 0x2206440] error while decoding MB 29 32

вот мой код:

import cv2
import numpy as np

def getthresholdedimg1(hsv):#Amarillo
    threshImg = cv2.inRange(hsv,(25,100,20),(30,255,255))
    return threshImg

def getthresholdedimg2(hsv):#Rosa
    threshImg = cv2.inRange(hsv,(145,100,20),(155,255,255))
    return threshImg    

def getthresholdedimg3(hsv):#Rojo
    threshImg = cv2.inRange(hsv,(170,100,20),(180,255,255))
    return threshImg  

def getthresholdedimg4(hsv):#Verde
    threshImg = cv2.inRange(hsv,(50,100,20),(70,255,255))
    return threshImg 

def getthresholdedimg5(hsv):#Naranja
    threshImg = cv2.inRange(hsv,(5,100,20),(15,255,255))
    return threshImg    



#c = cv2.VideoCapture(0)
c = cv2.VideoCapture("./sololink.sdp")
#c = cv2.VideoCapture(10.1.1.1)
width,height = c.get(3),c.get(4)




#Declarar ventanas
cv2.namedWindow('Output', cv2.WINDOW_NORMAL)


print'''..::Presione La Letra ESC Para Salir::..
 >Presiona 1 para seguir el  Color Amarillo
 >Presiona 2 para seguir el  Color Rosa
 >Presiona 3 para seguir el  Color Rojo
 >Presiona 4 para seguir el  Color Verde
 >Presiona 5 para seguir el  Color Naranja\n\n'''

color = input(" Presione el color que desea seguir: \n")
while(1):



    k =cv2.waitKey(10)
    if k== 27: #ESC for exit
    #if cv2.waitKey(10) & 0xFF == ord('q'):
        break
    _,f = c.read()
    f = cv2.flip(f,1)
    blur = cv2.medianBlur(f,5)
    hsv = cv2.cvtColor(f,cv2.COLOR_BGR2HSV)

    #Leyendo color de input
    if color==1:
        thrImg = getthresholdedimg1(hsv)
    elif color ==2:
        thrImg = getthresholdedimg2(hsv)
    elif color ==3:
        thrImg = getthresholdedimg3(hsv)
    elif color ==4:
        thrImg = getthresholdedimg4(hsv)
    elif color ==5:
        thrImg = getthresholdedimg5(hsv)

    if k== 49: #1
        print "Siguiendo Color Amarillo"
        color=1  
    if k==50: #2
        print "Siguiendo Color Rosa"
        color=2
    if k==51:
        print "Siguiendo Color Rojo"
        color=3
    if k==52:
        print "Siguiendo Color Verde"
        color=4
    if k==53:
        print "Siguiendo Color Naranja"
        color=5

    erode = cv2.erode(thrImg,None,iterations = 3)
    dilate = cv2.dilate(erode,None,iterations = 10)

    image,contours,hierarchy = cv2.findContours(dilate,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)

    for cnt in contours:
        x,y,w,h = cv2.boundingRect(cnt)
        cx,cy = x+w/2, y+h/2
        cv2.rectangle(f,(x,y),(x+w,y+h),[0,0,255],2)

    cv2.imshow('Output',f)




cv2.destroyAllWindows()
c.release()

Вы знаете, что я делаю неправильно?

...