import cv2 

# EDGES = [([8, 10], [255, 0, 0]),  # l_ankle -> l_knee
#          ([6, 8],  [155, 85, 0]),  # l_knee -> l_hip
#          ([11, 5], [155, 85, 0]),  # l_hip -> l_shoulder
#          ([7, 9],  [0, 0, 255]),  # r_hip -> r_knee
#          ([9, 11], [17, 25, 10]),  # r_knee -> r_ankle
#          ([12, 6], [0, 0, 255]),  # r_hip  -> r_shoulder
#          ([3, 1],  [0, 255, 0]),  # l_ear -> l_eye
#          ([1, 2],  [0, 255, 5]),  # l_eye -> r_eye
#          ([1, 0],  [0, 255, 170]),  # l_eye -> nose
#          ([0, 2],  [0, 255, 25]),  # nose -> r_eye
#          ([2, 4],  [0, 17, 255]),  # r_eye -> r_ear
#          ([2, 4],  [0, 220, 0]),  # l_wrist -> l_elbow
#          ([0, 2],  [0, 220, 0]),  # l_elbow -> l_shoulder
#          ([5, 6],  [125, 125, 155]), # l_shoulder -> r_shoulder
#          ([1, 3],  [25, 0, 55]),  # r_shoulder -> r_elbow
#          ([3, 5],  [25, 0, 255]),  # r_elbow -> r_wrist
#          ([12, 13],[155, 85, 0]), # head -> neck
#          ([13, 0], [0, 0, 255]),   # neck -> l_shoulder 
#          ([13, 1], [0, 255, 0]),  # neck -> r_shoulder
#          ([13, 7], [0, 255, 170]), # neck -> r_hip
#          ([13, 6], [0, 255, 25]), # neck -> l_hip
#          ]  

EDGES = [([15, 13], [255, 0, 0]),  # l_ankle -> l_knee
         ([13, 11],  [155, 85, 0]),  # l_knee -> l_hip
         ([11, 5], [155, 85, 0]),  # l_hip -> l_shoulder
         ([12, 14],  [0, 0, 255]),  # r_hip -> r_knee
         ([14, 16], [125, 25, 10]),  # r_knee -> r_ankle
         ([12, 6], [0, 0, 255]),  # r_hip  -> r_shoulder
         ([3, 1],  [0, 255, 0]),  # l_ear -> l_eye
         ([1, 2],  [0, 255, 5]),  # l_eye -> r_eye
         ([1, 0],  [0, 255, 170]),  # l_eye -> nose
         ([0, 2],  [0, 255, 25]),  # nose -> r_eye
         ([2, 4],  [0, 17, 255]),  # r_eye -> r_ear
         ([9, 7],  [0, 220, 0]),  # l_wrist -> l_elbow
         ([7, 5],  [0, 220, 0]),  # l_elbow -> l_shoulder
         ([5, 6],  [125, 125, 155]), # l_shoulder -> r_shoulder
         ([6, 8],  [25, 125, 55]),  # r_shoulder -> r_elbow
         ([8, 10], [25, 0, 255]),  # r_elbow -> r_wrist
         ([11,12], [0, 220, 0]) # r_hip -> l_hip
         ]  

def color_map(idx):
    h = colors_all[idx % len(colors_all)]
    return tuple(int(h[i:i+2], 16) for i in (4, 2, 0))

colors_all = ['ffccff', 
              '95fd8a', 'ff7276',
              '74fafd', '74fafd',
              'feb4c9', 'feb4c9',
              'fea03f', '59b3ff',
              'ffff00', 'ffff00',
              'bdaeff', 'bdaeff']


connections = [[12, 13],            #  head -> neck
               [13, 0], [13, 1],    #  neck -> l_shoulder, neck -> r_shoulder
               [0, 2], [2, 4],      #  l_elbow -> l_shoulder, l_wrist -> l_elbow
               [1, 3], [3, 5],      #  r_shoulder -> r_elow, r_elbow -> r_wrist
               [13, 7], [13, 6],    #  neck -> r_hip, neck -> l_hip
               [7, 9], [9, 11],     #  r_hip -> r_knee, r_knee -> r_ankle  
               [6, 8], [8, 10]]     #  l_knee -> l_hip, l_ankle -> l_knee

def draw_skeleton_coco(img, pts):
    for i in range(len(pts)):
        for j in range(len(EDGES)):
            pt1 = (int(pts[i, EDGES[j][0][0], 0]), int(pts[i, EDGES[j][0][0], 1]))
            pt2 = (int(pts[i, EDGES[j][0][1], 0]), int(pts[i, EDGES[j][0][1], 1]))
            vis1 = pts[i, EDGES[j][0][0], 2]
            vis2 = pts[i, EDGES[j][0][1], 2]

            if vis1 > 0 and vis2 > 0:
               #cv2.line(img, pt1, pt2, EDGES[j][1], 2, lineType=cv2.LINE_AA)
               cv2.line(img, pt1, pt2, (255, 255, 255), 2, lineType=cv2.LINE_AA)
               cv2.circle(img, pt1, radius=2, color=(0, 0, 0), thickness=1, lineType=cv2.LINE_AA)
               cv2.circle(img, pt2, radius=2, color=(0, 0, 0), thickness=1, lineType=cv2.LINE_AA)
            elif vis1 > 0:
                 cv2.circle(img, pt1, radius=2, color=(0,0,0), thickness=1, lineType=cv2.LINE_AA)
            elif vis2 > 0:
                 cv2.circle(img, pt2, radius=2, color=(0,0,0), thickness=1, lineType=cv2.LINE_AA)
    return img

def draw_skeleton_crowdpose(img, pts):
    for i in range(len(pts)):
        for j in range(len(connections)):
            pt1 = (int(pts[i, connections[j][0], 0]), int(pts[i, connections[j][0], 1]))
            pt2 = (int(pts[i, connections[j][1], 0]), int(pts[i, connections[j][1], 1]))
            vis1 = pts[i, connections[j][0], 2]
            vis2 = pts[i, connections[j][1], 2]

            if vis1 > 0 and vis2 > 0:
               cv2.line(img, pt1, pt2, color_map(j), 2, lineType=cv2.LINE_AA)
               cv2.circle(img, pt1, radius=2, color=(0, 0, 0), thickness=1, lineType=cv2.LINE_AA)
               cv2.circle(img, pt2, radius=2, color=(0, 0, 0), thickness=1, lineType=cv2.LINE_AA)
            elif vis1 > 0:
                 cv2.circle(img, pt1, radius=2, color=(0,0,0), thickness=1, lineType=cv2.LINE_AA)
            elif vis2 > 0:
                 cv2.circle(img, pt2, radius=2, color=(0,0,0), thickness=1, lineType=cv2.LINE_AA)
    return img

def draw_skeleton_exlpose(img, pts):
    for i in range(len(pts)):
        for j in range(len(connections)):
            pt1 = (int(pts[i, connections[j][0], 0]), int(pts[i, connections[j][0], 1]))
            pt2 = (int(pts[i, connections[j][1], 0]), int(pts[i, connections[j][1], 1]))
            vis1 = pts[i, connections[j][0], 2]
            vis2 = pts[i, connections[j][1], 2]

            if vis1 > 0 and vis2 > 0:
               cv2.line(img, pt1, pt2, color_map(j), 10, lineType=cv2.LINE_AA)
               cv2.circle(img, pt1, radius=10, color=(0, 0, 0), thickness=5, lineType=cv2.LINE_AA)
               cv2.circle(img, pt2, radius=10, color=(0, 0, 0), thickness=5, lineType=cv2.LINE_AA)
            elif vis1 > 0:
                 cv2.circle(img, pt1, radius=10, color=(0,0,0), thickness=5, lineType=cv2.LINE_AA)
            elif vis2 > 0:
                 cv2.circle(img, pt2, radius=10, color=(0,0,0), thickness=5, lineType=cv2.LINE_AA)
    return img


