-
Notifications
You must be signed in to change notification settings - Fork 167
/
Copy pathfay_connect.py
161 lines (138 loc) · 4.85 KB
/
fay_connect.py
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
"""
郭泽斌于2023.04.29参照app.py创建,用于连接github开源项目 Fay 数字人
"""
import base64
import time
import json
import gevent
from gevent import pywsgi
from geventwebsocket.handler import WebSocketHandler
from tools import audio_pre_process, video_pre_process, generate_video, audio_process
import os
import re
import numpy as np
import threading
import websocket
from pydub import AudioSegment
from moviepy.editor import VideoFileClip, AudioFileClip, concatenate_videoclips
import cv2
import pygame
import hashlib
import video_stream
video_list = []
audio_paths = []
fay_ws = None
video_cache = {}
#增加MD5音频标记,避免重复生成视频
def hash_file_md5(filepath):
md5 = hashlib.md5()
with open(filepath, 'rb') as f:
while True:
data = f.read(65536) # Read in 64kb chunks
if not data:
break
md5.update(data)
return md5.hexdigest()
def connet_fay():
global video_list
global video_cache
global fay_ws
global audio_paths
def on_message(ws, message):
if "audio" in message:
message_dict = json.loads(message)
aud_dir = message_dict["Data"]["Value"]
aud_dir = aud_dir.replace("\\", "/")
print('message:', aud_dir, type(aud_dir))
basedir = ""
for i in aud_dir.split("/"):
basedir = os.path.join(basedir,i)
basedir = basedir.replace(":",":\\")
num = time.time()
new_path = r'./data/audio/aud_%d.wav'%num #新路径
old_path = basedir
convert_mp3_to_wav(old_path, new_path)
audio_hash = hash_file_md5(new_path)
audio_paths.append(new_path)
# if audio_hash in video_cache:
# video_list.append({"video": video_cache[audio_hash], "audio": new_path})
# ret, frame = cap.read()
# print("视频已存在,直接播放。")
# else:
audio_path = 'data/audio/aud_%d.wav' % num
audio_process(audio_path)
audio_path_eo = 'data/audio/aud_%d_eo.npy' % num
video_path = 'data/video/results/ngp_%d.mp4' % num
output_path = 'data/video/results/output_%d.mp4' % num
generate_video(audio_path, audio_path_eo, video_path, output_path)
video_list.append({"video" : output_path, "audio" : new_path})
video_cache[audio_hash] = output_path
def on_error(ws, error):
print(f"Fay Error: {error}")
reconnect()
def on_close(ws):
print("Fay Connection closed")
reconnect()
def on_open(ws):
print("Fay Connection opened")
def connect():
global fay_ws
ws_url = "ws://127.0.0.1:10002"
fay_ws = websocket.WebSocketApp(ws_url,
on_message=on_message,
on_error=on_error,
on_close=on_close)
fay_ws.on_open = on_open
fay_ws.run_forever()
def reconnect():
global fay_ws
fay_ws = None
time.sleep(5) # 等待一段时间后重连
connect()
connect()
def convert_mp3_to_wav(input_file, output_file):
audio = AudioSegment.from_mp3(input_file)
audio.export(output_file, format='wav')
def play_video():
global video_list
global audio_paths
audio_path = None
frame = None
_, frame = cv2.VideoCapture("data/pretrained/train.mp4").read()
while True:
if video_stream.get_idle() > int(video_stream.get_video_len() / 3):
if len(audio_paths)>0:
audio_path = audio_paths.pop(0)
print(audio_path)
threading.Thread(target=play_audio, args=[audio_path]).start() # play audio
i = video_stream.get_video_len()
video_stream.set_video_len(0)
#循环播放视频帧
while True:
imgs = video_stream.read()
if len(imgs) > 0:
frame = imgs[0]
frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR)
cv2.imshow('Fay-2d', frame)
# 等待 38 毫秒
cv2.waitKey(38)
i = i - 1
elif i == 0:
break
else:
cv2.imshow('Fay-2d', frame)
# 等待 38 毫秒
cv2.waitKey(38)
def play_audio(audio_file):
pygame.mixer.init()
pygame.mixer.music.load(audio_file)
pygame.mixer.music.play()
while pygame.mixer.music.get_busy():
pygame.time.Clock().tick(10)
pygame.mixer.music.stop()
if __name__ == '__main__':
audio_pre_process()
video_pre_process()
video_stream.start()
threading.Thread(target=connet_fay, args=[]).start()
play_video()