Spaces:
Running
Running
File size: 2,786 Bytes
879dd87 b97e00c f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 f8e131c 879dd87 4bb678a 879dd87 |
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 |
import numpy as np
import gradio as gr
import models_client.globals
from models_client.core import (
start,
decode_execution_providers,
suggest_max_memory,
suggest_execution_threads,
)
from models_client.processors.frame.core import get_frame_processors_modules
from models_client.utilities import normalize_output_path
import os
from PIL import Image
def swap_face(source_file, target_file, doFaceEnhancer):
source_path = "input.jpg"
target_path = "target.jpg"
source_image = Image.fromarray(source_file)
source_image.save(source_path)
target_image = Image.fromarray(target_file)
target_image.save(target_path)
print("source_path: ", source_path)
print("target_path: ", target_path)
models_client.globals.source_path = source_path
models_client.globals.target_path = target_path
output_path = "output.jpg"
models_client.globals.output_path = normalize_output_path(
models_client.globals.source_path, models_client.globals.target_path, output_path
)
if doFaceEnhancer:
models_client.globals.frame_processors = ["face_swapper", "face_enhancer"]
else:
models_client.globals.frame_processors = ["face_swapper"]
models_client.globals.headless = True
models_client.globals.keep_fps = True
models_client.globals.keep_audio = True
models_client.globals.keep_frames = False
models_client.globals.many_faces = False
models_client.globals.video_encoder = "libx264"
models_client.globals.video_quality = 18
models_client.globals.max_memory = suggest_max_memory()
models_client.globals.execution_providers = decode_execution_providers(["cuda"])
models_client.globals.execution_threads = suggest_execution_threads()
print(
"start process",
models_client.globals.source_path,
models_client.globals.target_path,
models_client.globals.output_path,
)
for frame_processor in get_frame_processors_modules(
models_client.globals.frame_processors
):
if not frame_processor.pre_check():
return
start()
return output_path
html_section_1 = "<div style='text:align:center'><h1>Ai Penganti Wajah</h1></div>"
html_section_2 = "<div style='text:align:center'><p>Unggah gambar sumber dan target Anda untuk bertukar wajah, Kemudian anda bisa meningkatkan kualitas wajah dengan cara mencentang opsi dibawah</p></div>"
app = gr.Blocks()
with app:
gr.HTML(html_section_1)
gr.HTML(html_section_2)
gr.Interface(
fn=swap_face,
inputs=[
gr.Image(label="Gambar Sumber"),
gr.Image(label="Gambar Target"),
gr.Checkbox(label="Tingkatkan", info="Tingkatkan kualitas wajah ?")
],
outputs="image"
)
app.launch() |