import time import gradio as gr from generate import generate # base font stacks mono_fonts = ["monospace"] sans_fonts = [ "sans-serif", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", ] def read_file(path: str) -> str: with open(path, "r", encoding="utf-8") as file: return file.read() # don't request a GPU if input is bad def generate_btn_click(*args, **kwargs): start = time.perf_counter() if "prompt" in kwargs: prompt = kwargs.get("prompt") elif len(args) > 0: prompt = args[0] else: prompt = None if prompt is None or prompt.strip() == "": raise gr.Error("You must enter a prompt") images = generate(*args, **kwargs) end = time.perf_counter() diff = end - start gr.Info(f"Generated {len(images)} images in {diff:.2f}s") return images with gr.Blocks( css="./demo.css", js="./demo.js", theme=gr.themes.Default( # colors primary_hue=gr.themes.colors.orange, secondary_hue=gr.themes.colors.blue, neutral_hue=gr.themes.colors.gray, # sizing text_size=gr.themes.sizes.text_md, spacing_size=gr.themes.sizes.spacing_md, radius_size=gr.themes.sizes.radius_sm, # fonts font=[gr.themes.GoogleFont("Inter"), *sans_fonts], font_mono=[gr.themes.GoogleFont("Ubuntu Mono"), *mono_fonts], ).set( block_background_fill=gr.themes.colors.gray.c50, block_background_fill_dark=gr.themes.colors.gray.c900, block_border_width="0px", block_border_width_dark="0px", block_shadow="0 0 #0000", block_shadow_dark="0 0 #0000", block_title_text_weight=500, form_gap_width="0px", section_header_text_weight=500, ), ) as demo: gr.HTML(read_file("header.html")) output_images = gr.Gallery( height=320, label="Output", show_label=False, columns=4, interactive=False, elem_id="gallery", ) with gr.Group(): prompt = gr.Textbox( label="Prompt", show_label=False, lines=2, placeholder="corgi, at the beach, cute", value=None, elem_id="prompt", ) generate_btn = gr.Button("Generate", variant="primary", elem_classes=[]) with gr.Accordion( label="Menu", open=True, elem_id="menu", elem_classes=["accordion"], ): with gr.Tabs(elem_id="menu-tabs"): with gr.TabItem("⚙ī¸ Settings"): with gr.Group(): negative_prompt = gr.Textbox( label="Negative Prompt", lines=1, placeholder="ugly", value="", ) with gr.Row(): num_images = gr.Dropdown( label="Images", choices=[1, 2, 3, 4], value=1, filterable=False, ) aspect_ratio = gr.Dropdown( label="Aspect Ratio", choices=["1:1", "4:3", "3:4", "16:9", "9:16"], value="1:1", filterable=False, ) with gr.Row(): guidance_scale = gr.Slider( label="Guidance Scale", minimum=1.0, maximum=15.0, step=0.1, value=7, ) inference_steps = gr.Slider( label="Inference Steps", minimum=1, maximum=50, step=1, value=30, ) with gr.Column(): seed = gr.Number(label="Seed", value=0) with gr.Row(): random_seed_btn = gr.Button( "🎲 Random", variant="secondary", size="sm", scale=1, ) increment_seed = gr.Checkbox( label="Autoincrement", value=True, scale=8, elem_classes=["checkbox"], elem_id="increment-seed", ) with gr.TabItem("🧠 Model"): model = gr.Dropdown( label="Model", choices=[ "fluently/Fluently-v4", "Lykon/dreamshaper-8", "prompthero/openjourney-v4", "runwayml/stable-diffusion-v1-5", "SG161222/Realistic_Vision_V5.1_Novae", ], value="Lykon/dreamshaper-8", ) scheduler = gr.Dropdown( label="Scheduler", choices=[ "DEIS 2M", "DPM++ 2M", "DPM2 a", "Euler a", "Heun", "LMS", "PNDM", ], value="DEIS 2M", elem_id="scheduler", ) use_karras = gr.Checkbox( label="Karras Īƒ", value=True, elem_classes=["checkbox"], ) with gr.TabItem("ℹī¸ About", elem_id="about"): gr.Markdown(read_file("about.md")) # update the random seed using JavaScript random_seed_btn.click(None, outputs=[seed], js="() => Math.floor(Math.random() * 2**32)") generate_btn.click( generate_btn_click, api_name="generate", outputs=[output_images], inputs=[ prompt, negative_prompt, seed, model, scheduler, aspect_ratio, guidance_scale, inference_steps, use_karras, num_images, increment_seed, ], ) # https://www.gradio.app/docs/gradio/interface#interface-queue demo.queue().launch( { "server_name": "0.0.0.0", "server_port": 7860, } )