facefusioniter2 / app.py
AdityA36912355's picture
Update app.py
461df35 verified
import gradio as gr
from PIL import Image
import sys
import tempfile
from facefusion import core
from moviepy.editor import VideoFileClip
def run_cli(cli_args):
old_argv = sys.argv
try:
sys.argv = ['run.py', *cli_args]
core.cli()
finally:
sys.argv = old_argv
def get_video_duration(video_path):
video = VideoFileClip(video_path)
duration = video.duration # duration in seconds
return duration
def swap_faces(source_image_path, target_image_path, enhance_face=True, enhance_frame=True):
provider = 'cuda'
target_ext = target_image_path.split('.')[-1]
output_image_file = tempfile.NamedTemporaryFile(suffix=f'.{target_ext}')
output_image_path = output_image_file.name
duration = int(get_video_duration(target_image_path))
print(source_image_path)
print(target_image_path)
print(output_image_path)
cli_args = [
'--headless',
'-s', source_image_path,
'-t', target_image_path,
'-o', output_image_path,
'--execution-providers', provider,
# '--face-detector-model', 'yunet',
'--face-analyser-order', 'large-small',
]
cli_args += [ '--frame-processors', 'face_swapper' ]
cli_args += ['--trim-frame-end',str(duration)]
if enhance_face:
cli_args += [
'face_enhancer',
]
if enhance_frame:
cli_args += [
'frame_enhancer',
]
from facefusion.processors.frame.core import clear_frame_processors_modules
clear_frame_processors_modules()
run_cli(cli_args)
return output_image_path
demo = gr.Interface(
fn=swap_faces,
inputs=[
gr.Image(type="filepath"),
gr.Video(),
gr.Checkbox(label="Enhance Face", value=True),
gr.Checkbox(label="Enhance Frame", value=True),
],
outputs=[
gr.Video()
],
title="Swap Faces",
allow_flagging="never"
)
if __name__ == "__main__":
demo.queue(api_open=True)
demo.launch(show_error=True, show_api=True)