2023-01-21 16:22:16 +01:00
|
|
|
import streamlit as st
|
2023-01-30 14:19:57 +01:00
|
|
|
from process_video import segment_video, classify
|
|
|
|
from io import StringIO
|
|
|
|
import cv2 as cv
|
|
|
|
import tempfile
|
|
|
|
import numpy as np
|
|
|
|
import tensorflow as tf
|
2023-01-30 16:28:34 +01:00
|
|
|
from crop_hand_skeleton import crop_hand
|
|
|
|
from cvzone.HandTrackingModule import HandDetector
|
2023-01-21 16:22:16 +01:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2023-01-30 16:28:34 +01:00
|
|
|
detector = HandDetector(maxHands=1, mode=True, detectionCon=0.7, minTrackCon=0.8)
|
2023-01-30 14:19:57 +01:00
|
|
|
model = tf.keras.models.load_model('model_pred/VGG16_sign_char_detection_model')
|
2023-01-30 16:28:34 +01:00
|
|
|
|
2023-01-30 14:19:57 +01:00
|
|
|
st.set_page_config(
|
|
|
|
page_title="Projekt widzenie"
|
|
|
|
)
|
|
|
|
st.title("Projekt rozpoznawanie liter z alfabetu znaków migowych z wideo")
|
2023-01-21 16:22:16 +01:00
|
|
|
|
2023-01-30 14:19:57 +01:00
|
|
|
st.write('Załaduj film')
|
2023-01-29 17:03:38 +01:00
|
|
|
|
2023-01-30 14:19:57 +01:00
|
|
|
upload_movie = st.file_uploader("Wybierz film", type=["mp4"])
|
2023-01-29 17:03:38 +01:00
|
|
|
|
2023-01-30 14:19:57 +01:00
|
|
|
if upload_movie:
|
|
|
|
st.write("Film się ładuje.....")
|
|
|
|
tfile = tempfile.NamedTemporaryFile(delete=False)
|
|
|
|
tfile.write(upload_movie.read())
|
|
|
|
video_cap = cv.VideoCapture(tfile.name)
|
2023-01-30 16:28:34 +01:00
|
|
|
result, num = segment_video(video_cap, fps=10)
|
2023-01-30 14:19:57 +01:00
|
|
|
st.write(f"Załadowano {num} klatek")
|
|
|
|
for img in result:
|
2023-01-30 16:28:34 +01:00
|
|
|
img_skeleton = crop_hand(img, detector)
|
|
|
|
img2= cv.resize(img_skeleton,dsize=(224,224))
|
|
|
|
#breakpoint()
|
2023-01-30 14:19:57 +01:00
|
|
|
img_np = np.asarray(img2)
|
|
|
|
classification = classify(img_np[:,:,::-1], model)
|
2023-01-30 16:28:34 +01:00
|
|
|
st.image(img_skeleton[:,:,::-1])
|
2023-01-30 14:19:57 +01:00
|
|
|
st.write(classification)
|
|
|
|
|
|
|
|
|