File size: 1,916 Bytes
bd2f353 0fc70c3 bd2f353 40ce45f bd2f353 40ce45f bd2f353 40ce45f bd2f353 b24dca3 bd2f353 b24dca3 bd2f353 ab1abf8 b24dca3 bd2f353 0dc1c2d bd2f353 b24dca3 3d3ad4a efe3b0c |
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 |
import gradio as gr
import subprocess
from subprocess import call
with gr.Blocks() as ui:
with gr.Row():
video = gr.File(label="Video or Image")
audio = gr.File(label="Audio")
with gr.Column():
checkpoint = gr.Radio(["wav2lip", "wav2lip_gan"], label="Checkpoint")
no_smooth = gr.Checkbox(label="No Smooth")
resize_factor = gr.Slider(minimum=1, maximum=4, step=1, label="Resize Factor")
with gr.Row():
with gr.Column():
pad_top = gr.Slider(minimum=0, maximum=50, step=1, value=0, label="Pad Top")
pad_bottom = gr.Slider(minimum=0, maximum=50, step=1, value=10, label="Pad Bottom (Often increasing this to 20 allows chin to be included)")
pad_left = gr.Slider(minimum=0, maximum=50, step=1, value=0, label="Pad Left")
pad_right = gr.Slider(minimum=0, maximum=50, step=1, value=0, label="Pad Right")
generate_btn = gr.Button("Generate")
with gr.Column():
result = gr.Video()
def generate(video, audio, checkpoint, no_smooth, resize_factor, pad_top, pad_bottom, pad_left, pad_right):
if video is None or audio is None or checkpoint is None:
return
smooth = "--nosmooth" if no_smooth else ""
cmd = [
"python",
"inference.py",
"--checkpoint_path", f"checkpoints/{checkpoint}.pth",
"--segmentation_path", "checkpoints/face_segmentation.pth",
"--enhance_face", "gfpgan",
"--face", video.name,
"--audio", audio.name,
"--outfile", "results/output.mp4",
]
call(cmd)
return "results/output.mp4"
generate_btn.click(
generate,
[video, audio, checkpoint, pad_top, pad_bottom, pad_left, pad_right, resize_factor],
result)
ui.queue().launch(debug=True) |