Spaces:
Paused
Paused
| import gradio as gr | |
| import numpy as np | |
| import PIL.Image as Image | |
| import random | |
| import time | |
| # Список моделей с отображаемыми названиями и внутренними именами | |
| models = { | |
| "FLUX.1-dev": "black-forest-labs/FLUX.1-dev", | |
| "flux-RealismLora": "XLabs-AI/flux-RealismLora", | |
| "Midjourney": "Jovie/Midjourney", | |
| "Stable Diffusion v1-5": "stable-diffusion-v1-5/stable-diffusion-v1-5", | |
| "Pixel Art XL": "nerijs/pixel-art-xl", | |
| "Knitted Character Flux LoRA": "prithivMLmods/Knitted-Character-Flux-LoRA", | |
| "Flux Ghibsky Illustration": "aleksa-codes/flux-ghibsky-illustration", | |
| "Flux Super Realism LoRA": "strangerzonehf/Flux-Super-Realism-LoRA", | |
| "Flux Game Assets LoRA v2": "gokaygokay/Flux-Game-Assets-LoRA-v2", | |
| "Flux Animex v2 LoRA": "strangerzonehf/Flux-Animex-v2-LoRA", | |
| "Flux Qwen Capybara": "cfahlgren1/flux-qwen-capybara", | |
| "Softserve Anime": "alvdansen/softserve_anime", | |
| "FLUX Aesthetic Anime": "dataautogpt3/FLUX-AestheticAnime", | |
| "FLUX Animeo v1 LoRA": "strangerzonehf/Flux-Animeo-v1-LoRA", | |
| "Fractured Line Flare": "prithivMLmods/Fractured-Line-Flare", | |
| "Castor 3D Portrait Flux LoRA": "prithivMLmods/Castor-3D-Portrait-Flux-LoRA" | |
| } | |
| # Очередь на генерации | |
| queue = [] | |
| def generate_image(prompt, model_name, width, height, seed, steps, guidance_scale, random_seed): | |
| # Проверка очереди | |
| if len(queue) >= 150: | |
| yield None, "Очередь переполнена. Пожалуйста, подождите.", None | |
| return | |
| # Добавляем задачу в очередь | |
| task_id = random.randint(100000, 999999) | |
| queue.append(task_id) | |
| # Генерация сида, если выбрана галочка "Случайный сид" | |
| if random_seed: | |
| seed = random.randint(0, 1000000) | |
| # Формирование текста параметров | |
| params_text = ( | |
| f"Промпт: {prompt}\n" | |
| f"Модель: {model_name}\n" | |
| f"Размер: {width}x{height}\n" | |
| f"Сид: {seed}\n" | |
| f"Шаги: {steps}\n" | |
| f"Гуидансе скейл: {guidance_scale}" | |
| ) | |
| # Отправляем текст параметров | |
| yield None, params_text, seed | |
| for step in range(steps): | |
| # Имитация генерации изображения | |
| time.sleep(random.uniform(0.1, 0.5)) # Таймаут до 0.5 секунды | |
| # Имитация изображения (шум) | |
| image_array = np.random.randint(0, 256, (height, width, 3), dtype=np.uint8) | |
| image = Image.fromarray(image_array) | |
| # Обновление изображения | |
| yield image, None, None | |
| # Удаляем задачу из очереди | |
| queue.remove(task_id) | |
| # Возвращаем финальное изображение и параметры | |
| yield image, params_text, seed | |
| # Создание интерфейса | |
| with gr.Blocks() as demo: | |
| gr.Markdown("# Генератор изображений") | |
| with gr.Row(): | |
| prompt_textbox = gr.Textbox(label="Промпт", placeholder="Введите ваш промпт здесь", lines=2) | |
| with gr.Row(): | |
| model_dropdown = gr.Dropdown(list(models.keys()), label="Модель", value="FLUX.1-dev") | |
| with gr.Row(): | |
| with gr.Column(): | |
| width_slider = gr.Slider(128, 1024, value=512, step=64, label="Ширина") | |
| with gr.Column(): | |
| height_slider = gr.Slider(128, 1024, value=512, step=64, label="Высота") | |
| with gr.Row(): | |
| seed_slider = gr.Slider(0, 1000000, value=random.randint(0, 1000000), step=1, label="Сид") | |
| random_seed_checkbox = gr.Checkbox(label="Случайный сид") | |
| with gr.Row(): | |
| steps_slider = gr.Slider(1, 100, value=50, step=1, label="Шаги") | |
| guidance_scale_slider = gr.Slider(0.1, 20.0, value=7.5, step=0.1, label="Гуидансе скейл") | |
| generate_button = gr.Button("Сгенерировать изображение") | |
| output_image = gr.Image(label="Сгенерированное изображение") | |
| params_textbox = gr.Textbox(label="Параметры генерации", interactive=False) | |
| generate_button.click( | |
| fn=generate_image, | |
| inputs=[ | |
| prompt_textbox, | |
| model_dropdown, | |
| width_slider, | |
| height_slider, | |
| seed_slider, | |
| steps_slider, | |
| guidance_scale_slider, | |
| random_seed_checkbox | |
| ], | |
| outputs=[output_image, params_textbox, seed_slider] | |
| ) | |
| demo.queue(max_size=150, api_open=False) | |
| demo.launch(share=False, server_port=7860) | |
| # Скрытие футера | |
| hide_footer = """ | |
| <style> | |
| .gradio-container .footer { | |
| display: none !important; | |
| } | |
| </style> | |
| """ | |
| demo = demo.add_css(hide_footer) | |
| # Установка таймаута | |
| demo.queue(api_name="/generate").set_config(max_size=150, api_open=False, max_threads=1, timeout=125) | |
| demo.launch() |