File size: 2,548 Bytes
58665c8 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
from PIL import Image,ImageDraw
def create_color_image(width, height, color=(255,255,255)):
img = Image.new('RGB', (width, height), color)
return img
def fill_points(image,points,color=(255,255,255)):
draw = ImageDraw.Draw(image)
int_points = [(int(x), int(y)) for x, y in points]
draw.polygon(int_points, fill=color)
return image
def minus_point(pt1,pt2):
return [pt1[0]-pt2[0],pt1[1]-pt2[1]]
def lerp_point(pt1,pt2,pt2_ratio):
return [int(pt1[0]*(1.0-pt2_ratio)+pt2[0]*pt2_ratio),pt1[1]*(1.0-pt2_ratio)+pt2[1]*pt2_ratio]
def mean_point(points):
xs = 0
ys = 0
for pt in points:
xs +=pt[0]
ys +=pt[1]
return [int(xs/len(points)),int(ys/len(points))]
def get_face_points(face_landmarks_list):
contour_points=get_landmark_points(face_landmarks_list,PARTS_CONTOUR)
left_eyebrow_points=get_landmark_points(face_landmarks_list,PARTS_LEFT_EYEBROW)
right_eyebrow_points=get_landmark_points(face_landmarks_list,PARTS_RIGHT_EYEBROW)
nose_points=get_landmark_points(face_landmarks_list,PARTS_NOSE_BRIDGE)
diff_right = minus_point(contour_points[1],contour_points[0])
right_minus_corner = minus_point(contour_points[0] , diff_right)
right_contour = lerp_point(right_minus_corner,left_eyebrow_points[0],0.3)
diff_left = minus_point(contour_points[15],contour_points[16])
left_minus_corner = minus_point(contour_points[16] , diff_left)
left_contour = lerp_point(left_minus_corner,right_eyebrow_points[-1],0.3)
middle_face = mean_point([nose_points[0],right_eyebrow_points[0],left_eyebrow_points[-1]])
return [right_contour]+list(contour_points)+[left_contour,middle_face]
def get_innner_mouth_points(face_landmarks_list):
top_points=get_landmark_points(face_landmarks_list,PARTS_UPPER_LIP)
bottom_points=get_landmark_points(face_landmarks_list,PARTS_LOWER_LIP)
return top_points[7:]+bottom_points[7:]#[::-1]
PARTS_UPPER_LIP = "top_lip"
PARTS_LOWER_LIP = "bottom_lip"
PARTS_CONTOUR ="chin"
PARTS_LEFT_EYEBROW ="left_eyebrow"
PARTS_RIGHT_EYEBROW ="right_eyebrow"
PARTS_LEFT_EYE ="left_eye"
PARTS_RIGHT_EYE ="right_eye"
PARTS_NOSE_TIP ="nose_tip"
PARTS_NOSE_BRIDGE ="nose_bridge"
def get_landmark_points(face_landmarks_list,key):
matching_landmark_points = []
for face_landmarks in face_landmarks_list:
for landmark_name, landmark_points in face_landmarks.items():
matching_landmark_points = landmark_points.copy()
if landmark_name ==key:
return tuple(matching_landmark_points) |