Thekingbalxd
commited on
Commit
•
8cd1ef6
1
Parent(s):
775610f
Upload webui (3) (1).py
Browse files- webui (3) (1).py +783 -0
webui (3) (1).py
ADDED
@@ -0,0 +1,783 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import gradio as gr
|
2 |
+
import random
|
3 |
+
import os
|
4 |
+
import json
|
5 |
+
import time
|
6 |
+
import shared
|
7 |
+
import modules.config
|
8 |
+
import fooocus_version
|
9 |
+
import modules.html
|
10 |
+
import modules.async_worker as worker
|
11 |
+
import modules.constants as constants
|
12 |
+
import modules.flags as flags
|
13 |
+
import modules.gradio_hijack as grh
|
14 |
+
import modules.style_sorter as style_sorter
|
15 |
+
import modules.meta_parser
|
16 |
+
import args_manager
|
17 |
+
import copy
|
18 |
+
import launch
|
19 |
+
|
20 |
+
from modules.sdxl_styles import legal_style_names
|
21 |
+
from modules.private_logger import get_current_html_path
|
22 |
+
from modules.ui_gradio_extensions import reload_javascript
|
23 |
+
from modules.auth import auth_enabled, check_auth
|
24 |
+
from modules.util import is_json
|
25 |
+
|
26 |
+
def get_task(*args):
|
27 |
+
args = list(args)
|
28 |
+
args.pop(0)
|
29 |
+
|
30 |
+
return worker.AsyncTask(args=args)
|
31 |
+
|
32 |
+
def generate_clicked(task: worker.AsyncTask):
|
33 |
+
import ldm_patched.modules.model_management as model_management
|
34 |
+
|
35 |
+
with model_management.interrupt_processing_mutex:
|
36 |
+
model_management.interrupt_processing = False
|
37 |
+
# outputs=[progress_html, progress_window, progress_gallery, gallery]
|
38 |
+
|
39 |
+
if len(task.args) == 0:
|
40 |
+
return
|
41 |
+
|
42 |
+
execution_start_time = time.perf_counter()
|
43 |
+
finished = False
|
44 |
+
|
45 |
+
yield gr.update(visible=True, value=modules.html.make_progress_html(1, 'Waiting for task to start ...')), \
|
46 |
+
gr.update(visible=True, value=None), \
|
47 |
+
gr.update(visible=False, value=None), \
|
48 |
+
gr.update(visible=False)
|
49 |
+
|
50 |
+
worker.async_tasks.append(task)
|
51 |
+
|
52 |
+
while not finished:
|
53 |
+
time.sleep(0.01)
|
54 |
+
if len(task.yields) > 0:
|
55 |
+
flag, product = task.yields.pop(0)
|
56 |
+
if flag == 'preview':
|
57 |
+
|
58 |
+
# help bad internet connection by skipping duplicated preview
|
59 |
+
if len(task.yields) > 0: # if we have the next item
|
60 |
+
if task.yields[0][0] == 'preview': # if the next item is also a preview
|
61 |
+
# print('Skipped one preview for better internet connection.')
|
62 |
+
continue
|
63 |
+
|
64 |
+
percentage, title, image = product
|
65 |
+
yield gr.update(visible=True, value=modules.html.make_progress_html(percentage, title)), \
|
66 |
+
gr.update(visible=True, value=image) if image is not None else gr.update(), \
|
67 |
+
gr.update(), \
|
68 |
+
gr.update(visible=False)
|
69 |
+
if flag == 'results':
|
70 |
+
yield gr.update(visible=True), \
|
71 |
+
gr.update(visible=True), \
|
72 |
+
gr.update(visible=True, value=product), \
|
73 |
+
gr.update(visible=False)
|
74 |
+
if flag == 'finish':
|
75 |
+
yield gr.update(visible=False), \
|
76 |
+
gr.update(visible=False), \
|
77 |
+
gr.update(visible=False), \
|
78 |
+
gr.update(visible=True, value=product)
|
79 |
+
finished = True
|
80 |
+
|
81 |
+
# delete Fooocus temp images, only keep gradio temp images
|
82 |
+
if args_manager.args.disable_image_log:
|
83 |
+
for filepath in product:
|
84 |
+
if isinstance(filepath, str) and os.path.exists(filepath):
|
85 |
+
os.remove(filepath)
|
86 |
+
|
87 |
+
execution_time = time.perf_counter() - execution_start_time
|
88 |
+
print(f'Total time: {execution_time:.2f} seconds')
|
89 |
+
return
|
90 |
+
|
91 |
+
|
92 |
+
reload_javascript()
|
93 |
+
|
94 |
+
title = f'Fooocus {fooocus_version.version}'
|
95 |
+
|
96 |
+
if isinstance(args_manager.args.preset, str):
|
97 |
+
title += ' ' + args_manager.args.preset
|
98 |
+
|
99 |
+
shared.gradio_root = gr.Blocks(title=title).queue()
|
100 |
+
|
101 |
+
with shared.gradio_root:
|
102 |
+
currentTask = gr.State(worker.AsyncTask(args=[]))
|
103 |
+
with gr.Row():
|
104 |
+
with gr.Column(scale=2):
|
105 |
+
with gr.Row():
|
106 |
+
progress_window = grh.Image(label='Preview', show_label=True, visible=False, height=768,
|
107 |
+
elem_classes=['main_view'])
|
108 |
+
progress_gallery = gr.Gallery(label='Finished Images', show_label=True, object_fit='contain',
|
109 |
+
height=768, visible=False, elem_classes=['main_view', 'image_gallery'])
|
110 |
+
progress_html = gr.HTML(value=modules.html.make_progress_html(32, 'Progress 32%'), visible=False,
|
111 |
+
elem_id='progress-bar', elem_classes='progress-bar')
|
112 |
+
gallery = gr.Gallery(label='Gallery', show_label=False, object_fit='contain', visible=True, height=768,
|
113 |
+
elem_classes=['resizable_area', 'main_view', 'final_gallery', 'image_gallery'],
|
114 |
+
elem_id='final_gallery')
|
115 |
+
with gr.Row(elem_classes='type_row'):
|
116 |
+
with gr.Column(scale=17):
|
117 |
+
prompt = gr.Textbox(show_label=False, placeholder="Type prompt here or paste parameters.", elem_id='positive_prompt',
|
118 |
+
container=False, autofocus=True, elem_classes='type_row', lines=1024)
|
119 |
+
|
120 |
+
default_prompt = modules.config.default_prompt
|
121 |
+
if isinstance(default_prompt, str) and default_prompt != '':
|
122 |
+
shared.gradio_root.load(lambda: default_prompt, outputs=prompt)
|
123 |
+
|
124 |
+
with gr.Column(scale=3, min_width=0):
|
125 |
+
generate_button = gr.Button(label="Generate", value="Generate", elem_classes='type_row', elem_id='generate_button', visible=True)
|
126 |
+
reset_button = gr.Button(label="Reconnect", value="Reconnect", elem_classes='type_row', elem_id='reset_button', visible=False)
|
127 |
+
load_parameter_button = gr.Button(label="Load Parameters", value="Load Parameters", elem_classes='type_row', elem_id='load_parameter_button', visible=False)
|
128 |
+
skip_button = gr.Button(label="Skip", value="Skip", elem_classes='type_row_half', elem_id='skip_button', visible=False)
|
129 |
+
stop_button = gr.Button(label="Stop", value="Stop", elem_classes='type_row_half', elem_id='stop_button', visible=False)
|
130 |
+
|
131 |
+
def stop_clicked(currentTask):
|
132 |
+
import ldm_patched.modules.model_management as model_management
|
133 |
+
currentTask.last_stop = 'stop'
|
134 |
+
if (currentTask.processing):
|
135 |
+
model_management.interrupt_current_processing()
|
136 |
+
return currentTask
|
137 |
+
|
138 |
+
def skip_clicked(currentTask):
|
139 |
+
import ldm_patched.modules.model_management as model_management
|
140 |
+
currentTask.last_stop = 'skip'
|
141 |
+
if (currentTask.processing):
|
142 |
+
model_management.interrupt_current_processing()
|
143 |
+
return currentTask
|
144 |
+
|
145 |
+
stop_button.click(stop_clicked, inputs=currentTask, outputs=currentTask, queue=False, show_progress=False, _js='cancelGenerateForever')
|
146 |
+
skip_button.click(skip_clicked, inputs=currentTask, outputs=currentTask, queue=False, show_progress=False)
|
147 |
+
with gr.Row(elem_classes='advanced_check_row'):
|
148 |
+
input_image_checkbox = gr.Checkbox(label='Input Image', value=False, container=False, elem_classes='min_check')
|
149 |
+
advanced_checkbox = gr.Checkbox(label='Advanced', value=modules.config.default_advanced_checkbox, container=False, elem_classes='min_check')
|
150 |
+
with gr.Row(visible=False) as image_input_panel:
|
151 |
+
with gr.Tabs():
|
152 |
+
with gr.TabItem(label='Upscale or Variation') as uov_tab:
|
153 |
+
with gr.Row():
|
154 |
+
with gr.Column():
|
155 |
+
uov_input_image = grh.Image(label='Image', source='upload', type='numpy', show_label=False)
|
156 |
+
with gr.Column():
|
157 |
+
uov_method = gr.Radio(label='Upscale or Variation:', choices=flags.uov_list, value=flags.disabled)
|
158 |
+
gr.HTML('<a href="https://github.com/lllyasviel/Fooocus/discussions/390" target="_blank">\U0001F4D4 Document</a>')
|
159 |
+
with gr.TabItem(label='Image Prompt') as ip_tab:
|
160 |
+
with gr.Row():
|
161 |
+
ip_images = []
|
162 |
+
ip_types = []
|
163 |
+
ip_stops = []
|
164 |
+
ip_weights = []
|
165 |
+
ip_ctrls = []
|
166 |
+
ip_ad_cols = []
|
167 |
+
for _ in range(flags.controlnet_image_count):
|
168 |
+
with gr.Column():
|
169 |
+
ip_image = grh.Image(label='Image', source='upload', type='numpy', show_label=False, height=300)
|
170 |
+
ip_images.append(ip_image)
|
171 |
+
ip_ctrls.append(ip_image)
|
172 |
+
with gr.Column(visible=False) as ad_col:
|
173 |
+
with gr.Row():
|
174 |
+
default_end, default_weight = flags.default_parameters[flags.default_ip]
|
175 |
+
|
176 |
+
ip_stop = gr.Slider(label='Stop At', minimum=0.0, maximum=1.0, step=0.001, value=default_end)
|
177 |
+
ip_stops.append(ip_stop)
|
178 |
+
ip_ctrls.append(ip_stop)
|
179 |
+
|
180 |
+
ip_weight = gr.Slider(label='Weight', minimum=0.0, maximum=2.0, step=0.001, value=default_weight)
|
181 |
+
ip_weights.append(ip_weight)
|
182 |
+
ip_ctrls.append(ip_weight)
|
183 |
+
|
184 |
+
ip_type = gr.Radio(label='Type', choices=flags.ip_list, value=flags.default_ip, container=False)
|
185 |
+
ip_types.append(ip_type)
|
186 |
+
ip_ctrls.append(ip_type)
|
187 |
+
|
188 |
+
ip_type.change(lambda x: flags.default_parameters[x], inputs=[ip_type], outputs=[ip_stop, ip_weight], queue=False, show_progress=False)
|
189 |
+
ip_ad_cols.append(ad_col)
|
190 |
+
ip_advanced = gr.Checkbox(label='Advanced', value=False, container=False)
|
191 |
+
gr.HTML('* \"Image Prompt\" is powered by Fooocus Image Mixture Engine (v1.0.1). <a href="https://github.com/lllyasviel/Fooocus/discussions/557" target="_blank">\U0001F4D4 Document</a>')
|
192 |
+
|
193 |
+
def ip_advance_checked(x):
|
194 |
+
return [gr.update(visible=x)] * len(ip_ad_cols) + \
|
195 |
+
[flags.default_ip] * len(ip_types) + \
|
196 |
+
[flags.default_parameters[flags.default_ip][0]] * len(ip_stops) + \
|
197 |
+
[flags.default_parameters[flags.default_ip][1]] * len(ip_weights)
|
198 |
+
|
199 |
+
ip_advanced.change(ip_advance_checked, inputs=ip_advanced,
|
200 |
+
outputs=ip_ad_cols + ip_types + ip_stops + ip_weights,
|
201 |
+
queue=False, show_progress=False)
|
202 |
+
with gr.TabItem(label='Inpaint or Outpaint') as inpaint_tab:
|
203 |
+
with gr.Row():
|
204 |
+
inpaint_input_image = grh.Image(label='Image', source='upload', type='numpy', tool='sketch', height=500, brush_color="#FFFFFF", elem_id='inpaint_canvas', show_label=False)
|
205 |
+
inpaint_mask_image = grh.Image(label='Mask Upload', source='upload', type='numpy', height=500, visible=False)
|
206 |
+
|
207 |
+
with gr.Row():
|
208 |
+
inpaint_additional_prompt = gr.Textbox(placeholder="Describe what you want to inpaint.", elem_id='inpaint_additional_prompt', label='Inpaint Additional Prompt', visible=False)
|
209 |
+
outpaint_selections = gr.CheckboxGroup(choices=['Left', 'Right', 'Top', 'Bottom'], value=[], label='Outpaint Direction')
|
210 |
+
inpaint_mode = gr.Dropdown(choices=modules.flags.inpaint_options, value=modules.flags.inpaint_option_default, label='Method')
|
211 |
+
example_inpaint_prompts = gr.Dataset(samples=modules.config.example_inpaint_prompts, label='Additional Prompt Quick List', components=[inpaint_additional_prompt], visible=False)
|
212 |
+
gr.HTML('* Powered by Fooocus Inpaint Engine <a href="https://github.com/lllyasviel/Fooocus/discussions/414" target="_blank">\U0001F4D4 Document</a>')
|
213 |
+
example_inpaint_prompts.click(lambda x: x[0], inputs=example_inpaint_prompts, outputs=inpaint_additional_prompt, show_progress=False, queue=False)
|
214 |
+
with gr.TabItem(label='Describe') as desc_tab:
|
215 |
+
with gr.Row():
|
216 |
+
with gr.Column():
|
217 |
+
desc_input_image = grh.Image(label='Image', source='upload', type='numpy', show_label=False)
|
218 |
+
with gr.Column():
|
219 |
+
desc_method = gr.Radio(
|
220 |
+
label='Content Type',
|
221 |
+
choices=[flags.desc_type_photo, flags.desc_type_anime],
|
222 |
+
value=flags.desc_type_photo)
|
223 |
+
desc_btn = gr.Button(value='Describe this Image into Prompt')
|
224 |
+
desc_image_size = gr.Textbox(label='Image Size and Recommended Size', elem_id='desc_image_size', visible=False)
|
225 |
+
gr.HTML('<a href="https://github.com/lllyasviel/Fooocus/discussions/1363" target="_blank">\U0001F4D4 Document</a>')
|
226 |
+
|
227 |
+
def trigger_show_image_properties(image):
|
228 |
+
value = modules.util.get_image_size_info(image, modules.flags.sdxl_aspect_ratios)
|
229 |
+
return gr.update(value=value, visible=True)
|
230 |
+
|
231 |
+
desc_input_image.upload(trigger_show_image_properties, inputs=desc_input_image,
|
232 |
+
outputs=desc_image_size, show_progress=False, queue=False)
|
233 |
+
|
234 |
+
with gr.TabItem(label='Metadata') as metadata_tab:
|
235 |
+
with gr.Column():
|
236 |
+
metadata_input_image = grh.Image(label='For images created by Fooocus', source='upload', type='filepath')
|
237 |
+
metadata_json = gr.JSON(label='Metadata')
|
238 |
+
metadata_import_button = gr.Button(value='Apply Metadata')
|
239 |
+
|
240 |
+
def trigger_metadata_preview(filepath):
|
241 |
+
parameters, metadata_scheme = modules.meta_parser.read_info_from_image(filepath)
|
242 |
+
|
243 |
+
results = {}
|
244 |
+
if parameters is not None:
|
245 |
+
results['parameters'] = parameters
|
246 |
+
|
247 |
+
if isinstance(metadata_scheme, flags.MetadataScheme):
|
248 |
+
results['metadata_scheme'] = metadata_scheme.value
|
249 |
+
|
250 |
+
return results
|
251 |
+
|
252 |
+
metadata_input_image.upload(trigger_metadata_preview, inputs=metadata_input_image,
|
253 |
+
outputs=metadata_json, queue=False, show_progress=True)
|
254 |
+
|
255 |
+
switch_js = "(x) => {if(x){viewer_to_bottom(100);viewer_to_bottom(500);}else{viewer_to_top();} return x;}"
|
256 |
+
down_js = "() => {viewer_to_bottom();}"
|
257 |
+
|
258 |
+
input_image_checkbox.change(lambda x: gr.update(visible=x), inputs=input_image_checkbox,
|
259 |
+
outputs=image_input_panel, queue=False, show_progress=False, _js=switch_js)
|
260 |
+
ip_advanced.change(lambda: None, queue=False, show_progress=False, _js=down_js)
|
261 |
+
|
262 |
+
current_tab = gr.Textbox(value='uov', visible=False)
|
263 |
+
uov_tab.select(lambda: 'uov', outputs=current_tab, queue=False, _js=down_js, show_progress=False)
|
264 |
+
inpaint_tab.select(lambda: 'inpaint', outputs=current_tab, queue=False, _js=down_js, show_progress=False)
|
265 |
+
ip_tab.select(lambda: 'ip', outputs=current_tab, queue=False, _js=down_js, show_progress=False)
|
266 |
+
desc_tab.select(lambda: 'desc', outputs=current_tab, queue=False, _js=down_js, show_progress=False)
|
267 |
+
metadata_tab.select(lambda: 'metadata', outputs=current_tab, queue=False, _js=down_js, show_progress=False)
|
268 |
+
|
269 |
+
with gr.Column(scale=1, visible=modules.config.default_advanced_checkbox) as advanced_column:
|
270 |
+
with gr.Tab(label='Setting'):
|
271 |
+
if not args_manager.args.disable_preset_selection:
|
272 |
+
preset_selection = gr.Dropdown(label='Preset',
|
273 |
+
choices=modules.config.available_presets,
|
274 |
+
value=args_manager.args.preset if args_manager.args.preset else "initial",
|
275 |
+
interactive=True)
|
276 |
+
performance_selection = gr.Radio(label='Performance',
|
277 |
+
choices=flags.Performance.list(),
|
278 |
+
value=modules.config.default_performance,
|
279 |
+
elem_classes=['performance_selection'])
|
280 |
+
with gr.Accordion(label='Aspect Ratios', open=False, elem_id='aspect_ratios_accordion') as aspect_ratios_accordion:
|
281 |
+
aspect_ratios_selection = gr.Radio(label='Aspect Ratios', show_label=False,
|
282 |
+
choices=modules.config.available_aspect_ratios_labels,
|
283 |
+
value=modules.config.default_aspect_ratio,
|
284 |
+
info='width × height',
|
285 |
+
elem_classes='aspect_ratios')
|
286 |
+
|
287 |
+
aspect_ratios_selection.change(lambda x: None, inputs=aspect_ratios_selection, queue=False, show_progress=False, _js='(x)=>{refresh_aspect_ratios_label(x);}')
|
288 |
+
shared.gradio_root.load(lambda x: None, inputs=aspect_ratios_selection, queue=False, show_progress=False, _js='(x)=>{refresh_aspect_ratios_label(x);}')
|
289 |
+
|
290 |
+
image_number = gr.Slider(label='Image Number', minimum=1, maximum=modules.config.default_max_image_number, step=1, value=modules.config.default_image_number)
|
291 |
+
|
292 |
+
output_format = gr.Radio(label='Output Format',
|
293 |
+
choices=flags.OutputFormat.list(),
|
294 |
+
value=modules.config.default_output_format)
|
295 |
+
|
296 |
+
negative_prompt = gr.Textbox(label='Negative Prompt', show_label=True, placeholder="Type prompt here.",
|
297 |
+
info='Describing what you do not want to see.', lines=2,
|
298 |
+
elem_id='negative_prompt',
|
299 |
+
value=modules.config.default_prompt_negative)
|
300 |
+
seed_random = gr.Checkbox(label='Random', value=True)
|
301 |
+
image_seed = gr.Textbox(label='Seed', value=0, max_lines=1, visible=False) # workaround for https://github.com/gradio-app/gradio/issues/5354
|
302 |
+
|
303 |
+
def random_checked(r):
|
304 |
+
return gr.update(visible=not r)
|
305 |
+
|
306 |
+
def refresh_seed(r, seed_string):
|
307 |
+
if r:
|
308 |
+
return random.randint(constants.MIN_SEED, constants.MAX_SEED)
|
309 |
+
else:
|
310 |
+
try:
|
311 |
+
seed_value = int(seed_string)
|
312 |
+
if constants.MIN_SEED <= seed_value <= constants.MAX_SEED:
|
313 |
+
return seed_value
|
314 |
+
except ValueError:
|
315 |
+
pass
|
316 |
+
return random.randint(constants.MIN_SEED, constants.MAX_SEED)
|
317 |
+
|
318 |
+
seed_random.change(random_checked, inputs=[seed_random], outputs=[image_seed],
|
319 |
+
queue=False, show_progress=False)
|
320 |
+
|
321 |
+
def update_history_link():
|
322 |
+
if args_manager.args.disable_image_log:
|
323 |
+
return gr.update(value='')
|
324 |
+
|
325 |
+
return gr.update(value=f'<a href="file={get_current_html_path(output_format)}" target="_blank">\U0001F4DA History Log</a>')
|
326 |
+
|
327 |
+
history_link = gr.HTML()
|
328 |
+
shared.gradio_root.load(update_history_link, outputs=history_link, queue=False, show_progress=False)
|
329 |
+
|
330 |
+
with gr.Tab(label='Style', elem_classes=['style_selections_tab']):
|
331 |
+
style_sorter.try_load_sorted_styles(
|
332 |
+
style_names=legal_style_names,
|
333 |
+
default_selected=modules.config.default_styles)
|
334 |
+
|
335 |
+
style_search_bar = gr.Textbox(show_label=False, container=False,
|
336 |
+
placeholder="\U0001F50E Type here to search styles ...",
|
337 |
+
value="",
|
338 |
+
label='Search Styles')
|
339 |
+
style_selections = gr.CheckboxGroup(show_label=False, container=False,
|
340 |
+
choices=copy.deepcopy(style_sorter.all_styles),
|
341 |
+
value=copy.deepcopy(modules.config.default_styles),
|
342 |
+
label='Selected Styles',
|
343 |
+
elem_classes=['style_selections'])
|
344 |
+
gradio_receiver_style_selections = gr.Textbox(elem_id='gradio_receiver_style_selections', visible=False)
|
345 |
+
|
346 |
+
shared.gradio_root.load(lambda: gr.update(choices=copy.deepcopy(style_sorter.all_styles)),
|
347 |
+
outputs=style_selections)
|
348 |
+
|
349 |
+
style_search_bar.change(style_sorter.search_styles,
|
350 |
+
inputs=[style_selections, style_search_bar],
|
351 |
+
outputs=style_selections,
|
352 |
+
queue=False,
|
353 |
+
show_progress=False).then(
|
354 |
+
lambda: None, _js='()=>{refresh_style_localization();}')
|
355 |
+
|
356 |
+
gradio_receiver_style_selections.input(style_sorter.sort_styles,
|
357 |
+
inputs=style_selections,
|
358 |
+
outputs=style_selections,
|
359 |
+
queue=False,
|
360 |
+
show_progress=False).then(
|
361 |
+
lambda: None, _js='()=>{refresh_style_localization();}')
|
362 |
+
|
363 |
+
with gr.Tab(label='Model'):
|
364 |
+
with gr.Group():
|
365 |
+
with gr.Row():
|
366 |
+
base_model = gr.Dropdown(label='Base Model (SDXL only)', choices=modules.config.model_filenames, value=modules.config.default_base_model_name, show_label=True)
|
367 |
+
refiner_model = gr.Dropdown(label='Refiner (SDXL or SD 1.5)', choices=['None'] + modules.config.model_filenames, value=modules.config.default_refiner_model_name, show_label=True)
|
368 |
+
|
369 |
+
refiner_switch = gr.Slider(label='Refiner Switch At', minimum=0.1, maximum=1.0, step=0.0001,
|
370 |
+
info='Use 0.4 for SD1.5 realistic models; '
|
371 |
+
'or 0.667 for SD1.5 anime models; '
|
372 |
+
'or 0.8 for XL-refiners; '
|
373 |
+
'or any value for switching two SDXL models.',
|
374 |
+
value=modules.config.default_refiner_switch,
|
375 |
+
visible=modules.config.default_refiner_model_name != 'None')
|
376 |
+
|
377 |
+
refiner_model.change(lambda x: gr.update(visible=x != 'None'),
|
378 |
+
inputs=refiner_model, outputs=refiner_switch, show_progress=False, queue=False)
|
379 |
+
|
380 |
+
with gr.Group():
|
381 |
+
lora_ctrls = []
|
382 |
+
|
383 |
+
for i, (enabled, filename, weight) in enumerate(modules.config.default_loras):
|
384 |
+
with gr.Row():
|
385 |
+
lora_enabled = gr.Checkbox(label='Enable', value=enabled,
|
386 |
+
elem_classes=['lora_enable', 'min_check'], scale=1)
|
387 |
+
lora_model = gr.Dropdown(label=f'LoRA {i + 1}',
|
388 |
+
choices=['None'] + modules.config.lora_filenames, value=filename,
|
389 |
+
elem_classes='lora_model', scale=5)
|
390 |
+
lora_weight = gr.Slider(label='Weight', minimum=modules.config.default_loras_min_weight,
|
391 |
+
maximum=modules.config.default_loras_max_weight, step=0.01, value=weight,
|
392 |
+
elem_classes='lora_weight', scale=5)
|
393 |
+
lora_ctrls += [lora_enabled, lora_model, lora_weight]
|
394 |
+
|
395 |
+
with gr.Row():
|
396 |
+
refresh_files = gr.Button(label='Refresh', value='\U0001f504 Refresh All Files', variant='secondary', elem_classes='refresh_button')
|
397 |
+
with gr.Tab(label='Advanced'):
|
398 |
+
guidance_scale = gr.Slider(label='Guidance Scale', minimum=1.0, maximum=30.0, step=0.01,
|
399 |
+
value=modules.config.default_cfg_scale,
|
400 |
+
info='Higher value means style is cleaner, vivider, and more artistic.')
|
401 |
+
sharpness = gr.Slider(label='Image Sharpness', minimum=0.0, maximum=30.0, step=0.001,
|
402 |
+
value=modules.config.default_sample_sharpness,
|
403 |
+
info='Higher value means image and texture are sharper.')
|
404 |
+
gr.HTML('<a href="https://github.com/lllyasviel/Fooocus/discussions/117" target="_blank">\U0001F4D4 Document</a>')
|
405 |
+
dev_mode = gr.Checkbox(label='Developer Debug Mode', value=False, container=False)
|
406 |
+
|
407 |
+
with gr.Column(visible=False) as dev_tools:
|
408 |
+
with gr.Tab(label='Debug Tools'):
|
409 |
+
adm_scaler_positive = gr.Slider(label='Positive ADM Guidance Scaler', minimum=0.1, maximum=3.0,
|
410 |
+
step=0.001, value=1.5, info='The scaler multiplied to positive ADM (use 1.0 to disable). ')
|
411 |
+
adm_scaler_negative = gr.Slider(label='Negative ADM Guidance Scaler', minimum=0.1, maximum=3.0,
|
412 |
+
step=0.001, value=0.8, info='The scaler multiplied to negative ADM (use 1.0 to disable). ')
|
413 |
+
adm_scaler_end = gr.Slider(label='ADM Guidance End At Step', minimum=0.0, maximum=1.0,
|
414 |
+
step=0.001, value=0.3,
|
415 |
+
info='When to end the guidance from positive/negative ADM. ')
|
416 |
+
|
417 |
+
refiner_swap_method = gr.Dropdown(label='Refiner swap method', value=flags.refiner_swap_method,
|
418 |
+
choices=['joint', 'separate', 'vae'])
|
419 |
+
|
420 |
+
adaptive_cfg = gr.Slider(label='CFG Mimicking from TSNR', minimum=1.0, maximum=30.0, step=0.01,
|
421 |
+
value=modules.config.default_cfg_tsnr,
|
422 |
+
info='Enabling Fooocus\'s implementation of CFG mimicking for TSNR '
|
423 |
+
'(effective when real CFG > mimicked CFG).')
|
424 |
+
clip_skip = gr.Slider(label='CLIP Skip', minimum=1, maximum=10, step=1,
|
425 |
+
value=modules.config.default_clip_skip,
|
426 |
+
info='Bypass CLIP layers to avoid overfitting (use 1 to disable).')
|
427 |
+
sampler_name = gr.Dropdown(label='Sampler', choices=flags.sampler_list,
|
428 |
+
value=modules.config.default_sampler)
|
429 |
+
scheduler_name = gr.Dropdown(label='Scheduler', choices=flags.scheduler_list,
|
430 |
+
value=modules.config.default_scheduler)
|
431 |
+
vae_name = gr.Dropdown(label='VAE', choices=[modules.flags.default_vae] + modules.config.vae_filenames,
|
432 |
+
value=modules.config.default_vae, show_label=True)
|
433 |
+
|
434 |
+
generate_image_grid = gr.Checkbox(label='Generate Image Grid for Each Batch',
|
435 |
+
info='(Experimental) This may cause performance problems on some computers and certain internet conditions.',
|
436 |
+
value=False)
|
437 |
+
|
438 |
+
overwrite_step = gr.Slider(label='Forced Overwrite of Sampling Step',
|
439 |
+
minimum=-1, maximum=200, step=1,
|
440 |
+
value=modules.config.default_overwrite_step,
|
441 |
+
info='Set as -1 to disable. For developer debugging.')
|
442 |
+
overwrite_switch = gr.Slider(label='Forced Overwrite of Refiner Switch Step',
|
443 |
+
minimum=-1, maximum=200, step=1,
|
444 |
+
value=modules.config.default_overwrite_switch,
|
445 |
+
info='Set as -1 to disable. For developer debugging.')
|
446 |
+
overwrite_width = gr.Slider(label='Forced Overwrite of Generating Width',
|
447 |
+
minimum=-1, maximum=2048, step=1, value=-1,
|
448 |
+
info='Set as -1 to disable. For developer debugging. '
|
449 |
+
'Results will be worse for non-standard numbers that SDXL is not trained on.')
|
450 |
+
overwrite_height = gr.Slider(label='Forced Overwrite of Generating Height',
|
451 |
+
minimum=-1, maximum=2048, step=1, value=-1,
|
452 |
+
info='Set as -1 to disable. For developer debugging. '
|
453 |
+
'Results will be worse for non-standard numbers that SDXL is not trained on.')
|
454 |
+
overwrite_vary_strength = gr.Slider(label='Forced Overwrite of Denoising Strength of "Vary"',
|
455 |
+
minimum=-1, maximum=1.0, step=0.001, value=-1,
|
456 |
+
info='Set as negative number to disable. For developer debugging.')
|
457 |
+
overwrite_upscale_strength = gr.Slider(label='Forced Overwrite of Denoising Strength of "Upscale"',
|
458 |
+
minimum=-1, maximum=1.0, step=0.001, value=-1,
|
459 |
+
info='Set as negative number to disable. For developer debugging.')
|
460 |
+
disable_preview = gr.Checkbox(label='Disable Preview', value=modules.config.default_black_out_nsfw,
|
461 |
+
interactive=not modules.config.default_black_out_nsfw,
|
462 |
+
info='Disable preview during generation.')
|
463 |
+
disable_intermediate_results = gr.Checkbox(label='Disable Intermediate Results',
|
464 |
+
value=modules.config.default_performance == flags.Performance.EXTREME_SPEED.value,
|
465 |
+
interactive=modules.config.default_performance != flags.Performance.EXTREME_SPEED.value,
|
466 |
+
info='Disable intermediate results during generation, only show final gallery.')
|
467 |
+
disable_seed_increment = gr.Checkbox(label='Disable seed increment',
|
468 |
+
info='Disable automatic seed increment when image number is > 1.',
|
469 |
+
value=False)
|
470 |
+
read_wildcards_in_order = gr.Checkbox(label="Read wildcards in order", value=False)
|
471 |
+
|
472 |
+
black_out_nsfw = gr.Checkbox(label='Black Out NSFW',
|
473 |
+
value=modules.config.default_black_out_nsfw,
|
474 |
+
interactive=not modules.config.default_black_out_nsfw,
|
475 |
+
info='Use black image if NSFW is detected.')
|
476 |
+
|
477 |
+
black_out_nsfw.change(lambda x: gr.update(value=x, interactive=not x),
|
478 |
+
inputs=black_out_nsfw, outputs=disable_preview, queue=False,
|
479 |
+
show_progress=False)
|
480 |
+
|
481 |
+
if not args_manager.args.disable_metadata:
|
482 |
+
save_metadata_to_images = gr.Checkbox(label='Save Metadata to Images', value=modules.config.default_save_metadata_to_images,
|
483 |
+
info='Adds parameters to generated images allowing manual regeneration.')
|
484 |
+
metadata_scheme = gr.Radio(label='Metadata Scheme', choices=flags.metadata_scheme, value=modules.config.default_metadata_scheme,
|
485 |
+
info='Image Prompt parameters are not included. Use png and a1111 for compatibility with Civitai.',
|
486 |
+
visible=modules.config.default_save_metadata_to_images)
|
487 |
+
|
488 |
+
save_metadata_to_images.change(lambda x: gr.update(visible=x), inputs=[save_metadata_to_images], outputs=[metadata_scheme],
|
489 |
+
queue=False, show_progress=False)
|
490 |
+
|
491 |
+
with gr.Tab(label='Control'):
|
492 |
+
debugging_cn_preprocessor = gr.Checkbox(label='Debug Preprocessors', value=False,
|
493 |
+
info='See the results from preprocessors.')
|
494 |
+
skipping_cn_preprocessor = gr.Checkbox(label='Skip Preprocessors', value=False,
|
495 |
+
info='Do not preprocess images. (Inputs are already canny/depth/cropped-face/etc.)')
|
496 |
+
|
497 |
+
mixing_image_prompt_and_vary_upscale = gr.Checkbox(label='Mixing Image Prompt and Vary/Upscale',
|
498 |
+
value=False)
|
499 |
+
mixing_image_prompt_and_inpaint = gr.Checkbox(label='Mixing Image Prompt and Inpaint',
|
500 |
+
value=False)
|
501 |
+
|
502 |
+
controlnet_softness = gr.Slider(label='Softness of ControlNet', minimum=0.0, maximum=1.0,
|
503 |
+
step=0.001, value=0.25,
|
504 |
+
info='Similar to the Control Mode in A1111 (use 0.0 to disable). ')
|
505 |
+
|
506 |
+
with gr.Tab(label='Canny'):
|
507 |
+
canny_low_threshold = gr.Slider(label='Canny Low Threshold', minimum=1, maximum=255,
|
508 |
+
step=1, value=64)
|
509 |
+
canny_high_threshold = gr.Slider(label='Canny High Threshold', minimum=1, maximum=255,
|
510 |
+
step=1, value=128)
|
511 |
+
|
512 |
+
with gr.Tab(label='Inpaint'):
|
513 |
+
debugging_inpaint_preprocessor = gr.Checkbox(label='Debug Inpaint Preprocessing', value=False)
|
514 |
+
inpaint_disable_initial_latent = gr.Checkbox(label='Disable initial latent in inpaint', value=False)
|
515 |
+
inpaint_engine = gr.Dropdown(label='Inpaint Engine',
|
516 |
+
value=modules.config.default_inpaint_engine_version,
|
517 |
+
choices=flags.inpaint_engine_versions,
|
518 |
+
info='Version of Fooocus inpaint model')
|
519 |
+
inpaint_strength = gr.Slider(label='Inpaint Denoising Strength',
|
520 |
+
minimum=0.0, maximum=1.0, step=0.001, value=1.0,
|
521 |
+
info='Same as the denoising strength in A1111 inpaint. '
|
522 |
+
'Only used in inpaint, not used in outpaint. '
|
523 |
+
'(Outpaint always use 1.0)')
|
524 |
+
inpaint_respective_field = gr.Slider(label='Inpaint Respective Field',
|
525 |
+
minimum=0.0, maximum=1.0, step=0.001, value=0.618,
|
526 |
+
info='The area to inpaint. '
|
527 |
+
'Value 0 is same as "Only Masked" in A1111. '
|
528 |
+
'Value 1 is same as "Whole Image" in A1111. '
|
529 |
+
'Only used in inpaint, not used in outpaint. '
|
530 |
+
'(Outpaint always use 1.0)')
|
531 |
+
inpaint_erode_or_dilate = gr.Slider(label='Mask Erode or Dilate',
|
532 |
+
minimum=-64, maximum=64, step=1, value=0,
|
533 |
+
info='Positive value will make white area in the mask larger, '
|
534 |
+
'negative value will make white area smaller.'
|
535 |
+
'(default is 0, always process before any mask invert)')
|
536 |
+
inpaint_mask_upload_checkbox = gr.Checkbox(label='Enable Mask Upload', value=False)
|
537 |
+
invert_mask_checkbox = gr.Checkbox(label='Invert Mask', value=False)
|
538 |
+
|
539 |
+
inpaint_mask_color = gr.ColorPicker(label='Inpaint brush color', value='#FFFFFF', elem_id='inpaint_brush_color')
|
540 |
+
|
541 |
+
inpaint_ctrls = [debugging_inpaint_preprocessor, inpaint_disable_initial_latent, inpaint_engine,
|
542 |
+
inpaint_strength, inpaint_respective_field,
|
543 |
+
inpaint_mask_upload_checkbox, invert_mask_checkbox, inpaint_erode_or_dilate]
|
544 |
+
|
545 |
+
inpaint_mask_upload_checkbox.change(lambda x: gr.update(visible=x),
|
546 |
+
inputs=inpaint_mask_upload_checkbox,
|
547 |
+
outputs=inpaint_mask_image, queue=False,
|
548 |
+
show_progress=False)
|
549 |
+
|
550 |
+
inpaint_mask_color.change(lambda x: gr.update(brush_color=x), inputs=inpaint_mask_color,
|
551 |
+
outputs=inpaint_input_image,
|
552 |
+
queue=False, show_progress=False)
|
553 |
+
|
554 |
+
with gr.Tab(label='FreeU'):
|
555 |
+
freeu_enabled = gr.Checkbox(label='Enabled', value=False)
|
556 |
+
freeu_b1 = gr.Slider(label='B1', minimum=0, maximum=2, step=0.01, value=1.01)
|
557 |
+
freeu_b2 = gr.Slider(label='B2', minimum=0, maximum=2, step=0.01, value=1.02)
|
558 |
+
freeu_s1 = gr.Slider(label='S1', minimum=0, maximum=4, step=0.01, value=0.99)
|
559 |
+
freeu_s2 = gr.Slider(label='S2', minimum=0, maximum=4, step=0.01, value=0.95)
|
560 |
+
freeu_ctrls = [freeu_enabled, freeu_b1, freeu_b2, freeu_s1, freeu_s2]
|
561 |
+
|
562 |
+
def dev_mode_checked(r):
|
563 |
+
return gr.update(visible=r)
|
564 |
+
|
565 |
+
dev_mode.change(dev_mode_checked, inputs=[dev_mode], outputs=[dev_tools],
|
566 |
+
queue=False, show_progress=False)
|
567 |
+
|
568 |
+
def refresh_files_clicked():
|
569 |
+
modules.config.update_files()
|
570 |
+
results = [gr.update(choices=modules.config.model_filenames)]
|
571 |
+
results += [gr.update(choices=['None'] + modules.config.model_filenames)]
|
572 |
+
results += [gr.update(choices=['None'] + modules.config.vae_filenames)]
|
573 |
+
if not args_manager.args.disable_preset_selection:
|
574 |
+
results += [gr.update(choices=modules.config.available_presets)]
|
575 |
+
for i in range(modules.config.default_max_lora_number):
|
576 |
+
results += [gr.update(interactive=True),
|
577 |
+
gr.update(choices=['None'] + modules.config.lora_filenames), gr.update()]
|
578 |
+
return results
|
579 |
+
|
580 |
+
refresh_files_output = [base_model, refiner_model, vae_name]
|
581 |
+
if not args_manager.args.disable_preset_selection:
|
582 |
+
refresh_files_output += [preset_selection]
|
583 |
+
refresh_files.click(refresh_files_clicked, [], refresh_files_output + lora_ctrls,
|
584 |
+
queue=False, show_progress=False)
|
585 |
+
|
586 |
+
state_is_generating = gr.State(False)
|
587 |
+
|
588 |
+
load_data_outputs = [advanced_checkbox, image_number, prompt, negative_prompt, style_selections,
|
589 |
+
performance_selection, overwrite_step, overwrite_switch, aspect_ratios_selection,
|
590 |
+
overwrite_width, overwrite_height, guidance_scale, sharpness, adm_scaler_positive,
|
591 |
+
adm_scaler_negative, adm_scaler_end, refiner_swap_method, adaptive_cfg, clip_skip,
|
592 |
+
base_model, refiner_model, refiner_switch, sampler_name, scheduler_name, vae_name,
|
593 |
+
seed_random, image_seed, generate_button, load_parameter_button] + freeu_ctrls + lora_ctrls
|
594 |
+
|
595 |
+
if not args_manager.args.disable_preset_selection:
|
596 |
+
def preset_selection_change(preset, is_generating):
|
597 |
+
preset_content = modules.config.try_get_preset_content(preset) if preset != 'initial' else {}
|
598 |
+
preset_prepared = modules.meta_parser.parse_meta_from_preset(preset_content)
|
599 |
+
|
600 |
+
default_model = preset_prepared.get('base_model')
|
601 |
+
previous_default_models = preset_prepared.get('previous_default_models', [])
|
602 |
+
checkpoint_downloads = preset_prepared.get('checkpoint_downloads', {})
|
603 |
+
embeddings_downloads = preset_prepared.get('embeddings_downloads', {})
|
604 |
+
lora_downloads = preset_prepared.get('lora_downloads', {})
|
605 |
+
|
606 |
+
preset_prepared['base_model'], preset_prepared['lora_downloads'] = launch.download_models(
|
607 |
+
default_model, previous_default_models, checkpoint_downloads, embeddings_downloads, lora_downloads)
|
608 |
+
|
609 |
+
if 'prompt' in preset_prepared and preset_prepared.get('prompt') == '':
|
610 |
+
del preset_prepared['prompt']
|
611 |
+
|
612 |
+
return modules.meta_parser.load_parameter_button_click(json.dumps(preset_prepared), is_generating)
|
613 |
+
|
614 |
+
preset_selection.change(preset_selection_change, inputs=[preset_selection, state_is_generating], outputs=load_data_outputs, queue=False, show_progress=True) \
|
615 |
+
.then(fn=style_sorter.sort_styles, inputs=style_selections, outputs=style_selections, queue=False, show_progress=False)
|
616 |
+
|
617 |
+
performance_selection.change(lambda x: [gr.update(interactive=not flags.Performance.has_restricted_features(x))] * 11 +
|
618 |
+
[gr.update(visible=not flags.Performance.has_restricted_features(x))] * 1 +
|
619 |
+
[gr.update(interactive=not flags.Performance.has_restricted_features(x), value=flags.Performance.has_restricted_features(x))] * 1,
|
620 |
+
inputs=performance_selection,
|
621 |
+
outputs=[
|
622 |
+
guidance_scale, sharpness, adm_scaler_end, adm_scaler_positive,
|
623 |
+
adm_scaler_negative, refiner_switch, refiner_model, sampler_name,
|
624 |
+
scheduler_name, adaptive_cfg, refiner_swap_method, negative_prompt, disable_intermediate_results
|
625 |
+
], queue=False, show_progress=False)
|
626 |
+
|
627 |
+
output_format.input(lambda x: gr.update(output_format=x), inputs=output_format)
|
628 |
+
|
629 |
+
advanced_checkbox.change(lambda x: gr.update(visible=x), advanced_checkbox, advanced_column,
|
630 |
+
queue=False, show_progress=False) \
|
631 |
+
.then(fn=lambda: None, _js='refresh_grid_delayed', queue=False, show_progress=False)
|
632 |
+
|
633 |
+
def inpaint_mode_change(mode):
|
634 |
+
assert mode in modules.flags.inpaint_options
|
635 |
+
|
636 |
+
# inpaint_additional_prompt, outpaint_selections, example_inpaint_prompts,
|
637 |
+
# inpaint_disable_initial_latent, inpaint_engine,
|
638 |
+
# inpaint_strength, inpaint_respective_field
|
639 |
+
|
640 |
+
if mode == modules.flags.inpaint_option_detail:
|
641 |
+
return [
|
642 |
+
gr.update(visible=True), gr.update(visible=False, value=[]),
|
643 |
+
gr.Dataset.update(visible=True, samples=modules.config.example_inpaint_prompts),
|
644 |
+
False, 'None', 0.5, 0.0
|
645 |
+
]
|
646 |
+
|
647 |
+
if mode == modules.flags.inpaint_option_modify:
|
648 |
+
return [
|
649 |
+
gr.update(visible=True), gr.update(visible=False, value=[]),
|
650 |
+
gr.Dataset.update(visible=False, samples=modules.config.example_inpaint_prompts),
|
651 |
+
True, modules.config.default_inpaint_engine_version, 1.0, 0.0
|
652 |
+
]
|
653 |
+
|
654 |
+
return [
|
655 |
+
gr.update(visible=False, value=''), gr.update(visible=True),
|
656 |
+
gr.Dataset.update(visible=False, samples=modules.config.example_inpaint_prompts),
|
657 |
+
False, modules.config.default_inpaint_engine_version, 1.0, 0.618
|
658 |
+
]
|
659 |
+
|
660 |
+
inpaint_mode.input(inpaint_mode_change, inputs=inpaint_mode, outputs=[
|
661 |
+
inpaint_additional_prompt, outpaint_selections, example_inpaint_prompts,
|
662 |
+
inpaint_disable_initial_latent, inpaint_engine,
|
663 |
+
inpaint_strength, inpaint_respective_field
|
664 |
+
], show_progress=False, queue=False)
|
665 |
+
|
666 |
+
ctrls = [currentTask, generate_image_grid]
|
667 |
+
ctrls += [
|
668 |
+
prompt, negative_prompt, style_selections,
|
669 |
+
performance_selection, aspect_ratios_selection, image_number, output_format, image_seed,
|
670 |
+
read_wildcards_in_order, sharpness, guidance_scale
|
671 |
+
]
|
672 |
+
|
673 |
+
ctrls += [base_model, refiner_model, refiner_switch] + lora_ctrls
|
674 |
+
ctrls += [input_image_checkbox, current_tab]
|
675 |
+
ctrls += [uov_method, uov_input_image]
|
676 |
+
ctrls += [outpaint_selections, inpaint_input_image, inpaint_additional_prompt, inpaint_mask_image]
|
677 |
+
ctrls += [disable_preview, disable_intermediate_results, disable_seed_increment, black_out_nsfw]
|
678 |
+
ctrls += [adm_scaler_positive, adm_scaler_negative, adm_scaler_end, adaptive_cfg, clip_skip]
|
679 |
+
ctrls += [sampler_name, scheduler_name, vae_name]
|
680 |
+
ctrls += [overwrite_step, overwrite_switch, overwrite_width, overwrite_height, overwrite_vary_strength]
|
681 |
+
ctrls += [overwrite_upscale_strength, mixing_image_prompt_and_vary_upscale, mixing_image_prompt_and_inpaint]
|
682 |
+
ctrls += [debugging_cn_preprocessor, skipping_cn_preprocessor, canny_low_threshold, canny_high_threshold]
|
683 |
+
ctrls += [refiner_swap_method, controlnet_softness]
|
684 |
+
ctrls += freeu_ctrls
|
685 |
+
ctrls += inpaint_ctrls
|
686 |
+
|
687 |
+
if not args_manager.args.disable_metadata:
|
688 |
+
ctrls += [save_metadata_to_images, metadata_scheme]
|
689 |
+
|
690 |
+
ctrls += ip_ctrls
|
691 |
+
|
692 |
+
def parse_meta(raw_prompt_txt, is_generating):
|
693 |
+
loaded_json = None
|
694 |
+
if is_json(raw_prompt_txt):
|
695 |
+
loaded_json = json.loads(raw_prompt_txt)
|
696 |
+
|
697 |
+
if loaded_json is None:
|
698 |
+
if is_generating:
|
699 |
+
return gr.update(), gr.update(), gr.update()
|
700 |
+
else:
|
701 |
+
return gr.update(), gr.update(visible=True), gr.update(visible=False)
|
702 |
+
|
703 |
+
return json.dumps(loaded_json), gr.update(visible=False), gr.update(visible=True)
|
704 |
+
|
705 |
+
prompt.input(parse_meta, inputs=[prompt, state_is_generating], outputs=[prompt, generate_button, load_parameter_button], queue=False, show_progress=False)
|
706 |
+
|
707 |
+
load_parameter_button.click(modules.meta_parser.load_parameter_button_click, inputs=[prompt, state_is_generating], outputs=load_data_outputs, queue=False, show_progress=False)
|
708 |
+
|
709 |
+
def trigger_metadata_import(filepath, state_is_generating):
|
710 |
+
parameters, metadata_scheme = modules.meta_parser.read_info_from_image(filepath)
|
711 |
+
if parameters is None:
|
712 |
+
print('Could not find metadata in the image!')
|
713 |
+
parsed_parameters = {}
|
714 |
+
else:
|
715 |
+
metadata_parser = modules.meta_parser.get_metadata_parser(metadata_scheme)
|
716 |
+
parsed_parameters = metadata_parser.parse_json(parameters)
|
717 |
+
|
718 |
+
return modules.meta_parser.load_parameter_button_click(parsed_parameters, state_is_generating)
|
719 |
+
|
720 |
+
metadata_import_button.click(trigger_metadata_import, inputs=[metadata_input_image, state_is_generating], outputs=load_data_outputs, queue=False, show_progress=True) \
|
721 |
+
.then(style_sorter.sort_styles, inputs=style_selections, outputs=style_selections, queue=False, show_progress=False)
|
722 |
+
|
723 |
+
generate_button.click(lambda: (gr.update(visible=True, interactive=True), gr.update(visible=True, interactive=True), gr.update(visible=False, interactive=False), [], True),
|
724 |
+
outputs=[stop_button, skip_button, generate_button, gallery, state_is_generating]) \
|
725 |
+
.then(fn=refresh_seed, inputs=[seed_random, image_seed], outputs=image_seed) \
|
726 |
+
.then(fn=get_task, inputs=ctrls, outputs=currentTask) \
|
727 |
+
.then(fn=generate_clicked, inputs=currentTask, outputs=[progress_html, progress_window, progress_gallery, gallery]) \
|
728 |
+
.then(lambda: (gr.update(visible=True, interactive=True), gr.update(visible=False, interactive=False), gr.update(visible=False, interactive=False), False),
|
729 |
+
outputs=[generate_button, stop_button, skip_button, state_is_generating]) \
|
730 |
+
.then(fn=update_history_link, outputs=history_link) \
|
731 |
+
.then(fn=lambda: None, _js='playNotification').then(fn=lambda: None, _js='refresh_grid_delayed')
|
732 |
+
|
733 |
+
reset_button.click(lambda: [worker.AsyncTask(args=[]), False, gr.update(visible=True, interactive=True)] +
|
734 |
+
[gr.update(visible=False)] * 6 +
|
735 |
+
[gr.update(visible=True, value=[])],
|
736 |
+
outputs=[currentTask, state_is_generating, generate_button,
|
737 |
+
reset_button, stop_button, skip_button,
|
738 |
+
progress_html, progress_window, progress_gallery, gallery],
|
739 |
+
queue=False)
|
740 |
+
|
741 |
+
for notification_file in ['notification.ogg', 'notification.mp3']:
|
742 |
+
if os.path.exists(notification_file):
|
743 |
+
gr.Audio(interactive=False, value=notification_file, elem_id='audio_notification', visible=False)
|
744 |
+
break
|
745 |
+
|
746 |
+
def trigger_describe(mode, img):
|
747 |
+
if mode == flags.desc_type_photo:
|
748 |
+
from extras.interrogate import default_interrogator as default_interrogator_photo
|
749 |
+
return default_interrogator_photo(img), ["Fooocus V2", "Fooocus Enhance", "Fooocus Sharp"]
|
750 |
+
if mode == flags.desc_type_anime:
|
751 |
+
from extras.wd14tagger import default_interrogator as default_interrogator_anime
|
752 |
+
return default_interrogator_anime(img), ["Fooocus V2", "Fooocus Masterpiece"]
|
753 |
+
return mode, ["Fooocus V2"]
|
754 |
+
|
755 |
+
desc_btn.click(trigger_describe, inputs=[desc_method, desc_input_image],
|
756 |
+
outputs=[prompt, style_selections], show_progress=True, queue=True)
|
757 |
+
|
758 |
+
if args_manager.args.enable_describe_uov_image:
|
759 |
+
def trigger_uov_describe(mode, img, prompt):
|
760 |
+
# keep prompt if not empty
|
761 |
+
if prompt == '':
|
762 |
+
return trigger_describe(mode, img)
|
763 |
+
return gr.update(), gr.update()
|
764 |
+
|
765 |
+
uov_input_image.upload(trigger_uov_describe, inputs=[desc_method, uov_input_image, prompt],
|
766 |
+
outputs=[prompt, style_selections], show_progress=True, queue=True)
|
767 |
+
|
768 |
+
def dump_default_english_config():
|
769 |
+
from modules.localization import dump_english_config
|
770 |
+
dump_english_config(grh.all_components)
|
771 |
+
|
772 |
+
|
773 |
+
# dump_default_english_config()
|
774 |
+
|
775 |
+
shared.gradio_root.launch(
|
776 |
+
inbrowser=args_manager.args.in_browser,
|
777 |
+
server_name=args_manager.args.listen,
|
778 |
+
server_port=args_manager.args.port,
|
779 |
+
share=args_manager.args.share,
|
780 |
+
auth=check_auth if (args_manager.args.share or args_manager.args.listen) and auth_enabled else None,
|
781 |
+
allowed_paths=[modules.config.path_outputs],
|
782 |
+
blocked_paths=[constants.AUTH_FILENAME]
|
783 |
+
)
|