import os import torch import gradio as gr from video_watermark_remover import * from video_converter import * from image_converter import * from image_watermark_remover import * from typing import List from pydantic import BaseModel from lama_cleaner.server import main class FakeLamaArgs(BaseModel): host: str = "0.0.0.0" port: int = 5000 model: str = 'lama' hf_access_token: str = "" sd_disable_nsfw: bool = False sd_cpu_textencoder: bool = True sd_run_local: bool = False sd_enable_xformers: bool = False local_files_only: bool = False cpu_offload: bool = False device: str = "cuda" if torch.cuda.is_available() else "cpu" gui: bool = False gui_size: List[int] = [1000, 1000] input: str = '' disable_model_switch: bool = True debug: bool = False no_half: bool = False disable_nsfw: bool = False enable_xformers: bool = True if torch.cuda.is_available() else False model_dir: str = None output_dir: str = None css = """ #remove_btn { background: linear-gradient(#201d18, #2bbbc3); font-weight: bold; font-size: 18px; color:white; } #remove_btn:hover { background: linear-gradient(#2bbbc3, #201d18); } #convert_btn { background: linear-gradient(#201d18, #2bbbc3); font-weight: bold; font-size: 18px; color:white; } #convert_btn:hover { background: linear-gradient(#2bbbc3, #201d18); } footer { display: none !important; } """ demo = gr.Blocks(css=css, title="Video Watermark Remover") with demo: with gr.Tab("Image Converter"): gr.Markdown(""" #
🖼️ Image Converter
""") image_format = ['jpg', 'jpeg', 'png', 'bmp', 'tiff', 'gif', 'webp', 'ico', 'heic', 'heiv', 'heif'] with gr.Row(): with gr.Column(): input_image = gr.File(label="Upload an Image") with gr.Column(): with gr.Row(): image_format = gr.Radio(image_format, label="Select Format", interactive=False) with gr.Row(): image_convert_btn = gr.Button("Convert Image", interactive=False, elem_id="convert_btn") with gr.Row(): output_image = gr.File(label="Output File", interactive=False) image_status = gr.Textbox(label="Status", interactive=False) input_image.change(lambda x: gr.Radio.update(interactive=True), inputs=[input_image], outputs=[image_format]) image_format.change(lambda x: gr.Button.update(interactive=True), None, outputs=[image_convert_btn]) image_convert_btn.click(convert_image, inputs=[input_image, image_format], outputs=[output_image, image_status]) with gr.Tab("Image Watermark Remover"): gr.Markdown(""" #
🖼️ Image Watermark Remover
""") input_image_watermark = gr.Image(label="Upload an Image", tool="sketch", type="pil", interactive=True) image_remove_btn = gr.Button("Remove Watermark", interactive=True, elem_id="remove_btn") output_image_clean = gr.Image(label="Output Image", interactive=True) image_remove_btn.click(remove_image_watermark, inputs=[input_image_watermark], outputs=[output_image_clean]) with gr.Tab("Video Converter"): gr.Markdown(""" #
🎥 Video Converter
""") video_format = ['webm', 'wmv', 'mkv', 'mp4', 'avi', 'mpeg', 'vob', 'flv'] audio_format = ['mp3', 'wav', 'ogg', 'flac', 'aac'] with gr.Row(): with gr.Column(): input_video = gr.Video(label="Upload a Video") with gr.Column(): with gr.Row(): format_select = gr.Radio(["Video", "Audio"], label="Select Format", default="Video") with gr.Row(): format = gr.Radio(video_format, label="Select Format", interactive=False) with gr.Row(): with gr.Column(): pass with gr.Column(): convert_btn = gr.Button("Convert Video", interactive=False, elem_id="convert_btn") with gr.Column(): pass with gr.Row(): output = gr.File(label="Output File", interactive=False) status = gr.Textbox(label="Status", interactive=False) format_select.change(lambda x: gr.Radio.update(choices=video_format if x == "Video" else audio_format, interactive=True), inputs=[format_select], outputs=[format]) format.change(lambda x: gr.Button.update(interactive=True), None, outputs=[convert_btn]) convert_btn.click(convert_video, inputs=[input_video, format], outputs=[output, status]) with gr.Tab("Video Watermark Remover"): gr.Markdown(""" #
🎥 Video Watermark Remover (Slow)
""") with gr.Row(): with gr.Column(): input_video = gr.Video(label="Upload a Video") with gr.Column(): mask = gr.Image(label="Create a mask for the image", tool="sketch", type="pil", interactive=False) with gr.Row(): with gr.Column(): pass with gr.Column(): remove_btn = gr.Button("Remove Watermark", interactive=False, elem_id="remove_btn") with gr.Column(): pass with gr.Row(): output_video = gr.File(label="Output Video", interactive=False) input_video.change(convert_video_to_frames, inputs=[input_video], outputs=[mask, remove_btn]) remove_btn.click(remove_watermark, inputs=[mask], outputs=[output_video, remove_btn]) # Change the code according to the error import threading thread = threading.Thread(target=main, kwargs={'args': FakeLamaArgs()}) thread.daemon = True thread.start() demo.launch(show_api=False)