Added timing function to each step of precomputing the animations.

Added ProotState class and functions to structure and abstract blinking logic.
This commit is contained in:
CiscoTheWolf 2023-05-23 19:45:50 +02:00
parent 3bf5083b99
commit a5246021f9

View file

@ -20,6 +20,26 @@ from PIL import Image
import numpy as np
from scipy.optimize import linear_sum_assignment
class ProotState:
def __init__(self):
self.current_blink_state = 0
self.desired_blink_state = 0
def startBlink(self):
self.desired_blink_state = 10
def next_blink_state(self) -> int:
if self.current_blink_state == self.desired_blink_state and self.current_blink_state == 10:
self.desired_blink_state = 0
return 10
if self.current_blink_state < self.desired_blink_state:
self.current_blink_state += 1
else:
self.current_blink_state -= 1
return self.current_blink_state
class Point2D:
x = 0
@ -140,14 +160,40 @@ def interpolate_point_pairs(pairs: list[tuple[Point2D, Point2D]], percentage: fl
return interpolated_points
print("start loading images")
startT = curr_time = round(time.time()*1000)
Image1 = Image.open("faces/eyeLeftOpen.png")
Image2 = Image.open("faces/eyeLeftClosed.png")
endT = curr_time = round(time.time()*1000)
print("loading images took: " + str(endT - startT))
print("start generating pixel array")
startT = curr_time = round(time.time()*1000)
pixelArray1 = generate_point_array_from_image(Image1)
pixelArray2 = generate_point_array_from_image(Image2)
endT = curr_time = round(time.time()*1000)
print("generating pixel array took: " + str(endT - startT))
print("start pairing points for one eye")
startT = curr_time = round(time.time()*1000)
LeftEyeBlinkPairs = pair_points(pixelArray1, pixelArray2)
endT = curr_time = round(time.time()*1000)
print("pairing points for one eye took: " + str(endT - startT))
DesiredBlinkState = 10
currentBlinkState = 0
@ -155,6 +201,9 @@ currentBlinkState = 0
blinkFrameCanvases = []
print("start populating matrices for each blink frame")
startT = curr_time = round(time.time()*1000)
for alpha in range(0,11):
offscreen_interpolated_canvas = matrix.CreateFrameCanvas()
leftEye = interpolate_point_pairs(LeftEyeBlinkPairs, alpha/10)
@ -163,9 +212,23 @@ for alpha in range(0,11):
interpolated_image = generate_image_from_point_array(face, 128, 32)
offscreen_interpolated_canvas.SetImage(interpolated_image, unsafe=False)
blinkFrameCanvases.append(offscreen_interpolated_canvas)
endT = curr_time = round(time.time()*1000)
print("populating matrices for each blink frame took: " + str(endT - startT))
def move_option(current_option: int, desired_option: int) -> int:
if current_option == desired_option:
return current_option
if current_option < desired_option:
current_option += 1
else:
current_option -= 1
return current_option
def update_screen():
global DesiredBlinkState, currentBlinkState, blinkFrameCanvases, matrix