import gradio as gr from random import randint from all_models import models def load_fn(models): global models_load models_load = {} for model in models: if model not in models_load.keys(): try: m = gr.load(f'models/{model}') except Exception as error: m = gr.Interface(lambda txt: None, ['text'], ['image']) models_load.update({model: m}) load_fn(models) num_models = 6 default_models = models[:num_models] def extend_choices(choices): return choices + (num_models - len(choices)) * ['NA'] def update_imgbox(choices): choices_plus = extend_choices(choices) return [gr.Image(None, label=m, visible=(m != 'NA')) for m in choices_plus] def gen_fn(model_str, prompt, negative_prompt=None, image_style="Default"): if model_str == 'NA': return None modified_prompt = prompt if image_style != "Default": modified_prompt += f", {image_style}" if negative_prompt: modified_prompt += f", not {negative_prompt}" return models_load[model_str](modified_prompt) with gr.Blocks() as demo: with gr.Tab('The Dream'): txt_input = gr.Textbox(label='Your prompt:', lines=4, value="beautiful sexy woman, big boobs at beach, relaxing, ethereal, dreamy, backlit, highly detailed, realistic lighting, sharp focus, rule of thirds, artgerm") with gr.Accordion("Advanced Settings", open=False) as advanced_settings: neg_prompt = gr.Textbox(label='Negative prompt (Optional):', placeholder='Enter undesirable attributes here', lines=2) image_style = gr.Dropdown(label='Select Style', choices=["Default", "Realistic", "Portrait", "Anime"], value="Default") gen_button = gr.Button('Generate up to 6 images in up to 2 minutes total') stop_button = gr.Button('Stop', variant='secondary', interactive=False) gen_button.click(lambda s: gr.update(interactive=True), None, stop_button, concurrency_limit=10) gr.HTML( """
Scroll down to see more images and select models.