2023-10-16 06:51:57 -05:00
|
|
|
import math
|
2023-10-19 06:22:05 -05:00
|
|
|
import time
|
2023-10-16 06:51:57 -05:00
|
|
|
import numpy as np
|
|
|
|
import cv2 #pip install opencv-python ||| pip3 install opencv-contrib-python==4.4.0.46
|
2023-10-15 05:17:13 -05:00
|
|
|
|
2023-10-19 08:36:07 -05:00
|
|
|
from escpos.printer import Serial
|
|
|
|
|
2023-10-16 06:51:57 -05:00
|
|
|
from PIL import Image
|
|
|
|
from PIL import ImageDraw
|
|
|
|
from PIL import ImageFont
|
|
|
|
|
|
|
|
from deepface import DeepFace #pip install deepface
|
|
|
|
|
2023-10-19 08:36:07 -05:00
|
|
|
cam = cv2.VideoCapture(1)
|
2023-10-16 06:51:57 -05:00
|
|
|
|
2023-10-19 08:36:07 -05:00
|
|
|
printer = Serial(devfile='/dev/serial0',baudrate=19200,bytesize=8,parity='N',stopbits=1.00,dsrdtr=True)
|
|
|
|
printer.set(density=10)
|
2023-10-19 06:22:05 -05:00
|
|
|
cameraMode = False
|
|
|
|
TIMER = 5
|
2023-10-16 06:51:57 -05:00
|
|
|
|
2023-10-19 06:22:05 -05:00
|
|
|
startScreen = cv2.imread("noFace.png")
|
2023-10-16 06:51:57 -05:00
|
|
|
|
2023-10-15 05:17:13 -05:00
|
|
|
if cam.isOpened():
|
|
|
|
while True:
|
|
|
|
ret, img = cam.read()
|
2023-10-19 06:22:05 -05:00
|
|
|
if cameraMode and ret:
|
|
|
|
prev = time.time()
|
|
|
|
while TIMER > 0:
|
|
|
|
ret, img = cam.read()
|
|
|
|
# cv2.putText(img, str(TIMER), (200, 250), cv2.FONT_HERSHEY_SIMPLEX, 7, (0, 255, 255), 4, cv2.LINE_AA)
|
|
|
|
img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
|
|
|
|
img = Image.fromarray(img)
|
|
|
|
draw = ImageDraw.Draw(img)
|
|
|
|
font_size = 350
|
|
|
|
font = ImageFont.truetype("HalloweenFont.ttf", font_size)
|
2023-10-19 06:29:16 -05:00
|
|
|
if TIMER>1:
|
|
|
|
draw.text((231, 50), str(TIMER), font=font,fill=(255,0,0,255))
|
2023-10-19 06:22:05 -05:00
|
|
|
img = cv2.cvtColor(np.array(img), cv2.COLOR_RGB2BGR)
|
|
|
|
cv2.imshow('webcam',img)
|
|
|
|
# print(str(TIMER))
|
|
|
|
cur = time.time() #current time
|
|
|
|
if cur-prev >= 1:
|
|
|
|
prev = cur
|
|
|
|
TIMER = TIMER-1
|
|
|
|
key = cv2.waitKey(5) & 0xFF
|
|
|
|
if ord('q') == key:
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
ret, img = cam.read()
|
|
|
|
predictions = DeepFace.analyze(img,actions=['emotion'])
|
2023-10-16 06:51:57 -05:00
|
|
|
fearPoint = predictions[0]["emotion"]["fear"]
|
|
|
|
print("FEAR:" + str(fearPoint))
|
2023-10-19 08:24:30 -05:00
|
|
|
if fearPoint>10:
|
2023-10-19 06:22:05 -05:00
|
|
|
cv2.imwrite('scared.jpg', img)
|
2023-10-19 08:24:30 -05:00
|
|
|
basewidth = 384
|
|
|
|
imgCrop = Image.open('scared.jpg')
|
|
|
|
wpercent = (basewidth/float(imgCrop.size[0]))
|
|
|
|
hsize = int((float(imgCrop.size[1])*float(wpercent)))
|
|
|
|
imgCrop = imgCrop.resize((basewidth,hsize), Image.ANTIALIAS)
|
|
|
|
imgCrop = imgCrop.save("cropScared.jpg")
|
2023-10-19 08:36:07 -05:00
|
|
|
printer.image(imgCrop)
|
|
|
|
printer.text("\n\n\n\n")
|
2023-10-16 08:16:38 -05:00
|
|
|
img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
|
|
|
|
img = Image.fromarray(img)
|
|
|
|
draw = ImageDraw.Draw(img)
|
|
|
|
font_size = 65
|
|
|
|
font = ImageFont.truetype("HalloweenFont.ttf", font_size)
|
|
|
|
text = "FEAR LEVEL"
|
|
|
|
draw.text((144, 308), str(text), font=font,fill=(255,0,0,255))
|
|
|
|
img = cv2.cvtColor(np.array(img), cv2.COLOR_RGB2BGR)
|
2023-10-16 06:51:57 -05:00
|
|
|
#print(30+math.floor(int(fearPoint)*580/100))
|
|
|
|
# ft.putText(img=img,text='TEST',org=(15, 70),fontHeight=60,color=(255, 255, 255),thickness=-1,line_type=cv2.LINE_AA,bottomLeftOrigin=True)
|
2023-10-16 08:16:38 -05:00
|
|
|
cv2.rectangle(img,(30,400),(610,450),(255,255,255), 5)
|
2023-10-19 06:22:05 -05:00
|
|
|
cv2.rectangle(img,(30,400),(30+math.floor(int(fearPoint)*580/100),450),(255,255,255), -1)
|
2023-10-16 06:51:57 -05:00
|
|
|
cv2.imshow('webcam',img)
|
2023-10-19 06:22:05 -05:00
|
|
|
cv2.waitKey(5000)
|
|
|
|
|
|
|
|
|
2023-10-15 05:17:13 -05:00
|
|
|
|
2023-10-19 06:22:05 -05:00
|
|
|
cameraMode = False
|
|
|
|
TIMER = 5
|
|
|
|
else:
|
|
|
|
cv2.imshow('webcam',startScreen)
|
|
|
|
|
2023-10-15 05:17:13 -05:00
|
|
|
key = cv2.waitKey(5) & 0xFF
|
2023-10-19 06:22:05 -05:00
|
|
|
if ord('t') == key:
|
|
|
|
cameraMode = True
|
2023-10-15 05:17:13 -05:00
|
|
|
if ord('q') == key:
|
|
|
|
break
|
2023-10-19 06:22:05 -05:00
|
|
|
|
2023-10-15 05:17:13 -05:00
|
|
|
cam.release()
|