Commit
·
41b1d8d
1
Parent(s):
35f1465
more responsive UX
Browse files
webui.py
CHANGED
|
@@ -19,10 +19,8 @@ EXAMPLE_GREETINGS = [
|
|
| 19 |
]
|
| 20 |
|
| 21 |
def generate(*args):
|
| 22 |
-
yield gr.update(
|
| 23 |
-
gr.update(
|
| 24 |
-
gr.update(visible=True), \
|
| 25 |
-
gr.update(visible=False)
|
| 26 |
|
| 27 |
while worker.is_working:
|
| 28 |
time.sleep(0.1)
|
|
@@ -37,16 +35,12 @@ def generate(*args):
|
|
| 37 |
flag, product = worker.outputs.pop(0)
|
| 38 |
if flag == 'preview':
|
| 39 |
percentage, title, image = product
|
| 40 |
-
yield gr.update(), \
|
| 41 |
-
gr.update(value=
|
| 42 |
-
gr.update(value=image) if image is not None else gr.update(), \
|
| 43 |
-
gr.update()
|
| 44 |
if flag == 'results':
|
| 45 |
image = product[0]
|
| 46 |
-
yield gr.update(
|
| 47 |
-
gr.update(value=
|
| 48 |
-
gr.update(visible=False, value=image), \
|
| 49 |
-
gr.update(visible=True, value=image)
|
| 50 |
finished = True
|
| 51 |
return
|
| 52 |
|
|
@@ -56,6 +50,15 @@ def translate_promt_example(prompt_de):
|
|
| 56 |
def toggle_greet_visibility(is_visible):
|
| 57 |
return gr.update(visible=is_visible)
|
| 58 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 59 |
def debounce():
|
| 60 |
time.sleep(0.5)
|
| 61 |
return gr.update()
|
|
@@ -116,7 +119,7 @@ with shared.gradio_root:
|
|
| 116 |
style_selection = gr.Dropdown(choices=style_keys, value='Kinofilm', container=False, elem_id="style-selection")
|
| 117 |
with gr.Column(scale=1, min_width="80px"):
|
| 118 |
progress_html = gr.HTML(visible=True, elem_id='progress-bar', elem_classes='progress-bar')
|
| 119 |
-
run_button = gr.Button(value="Weihnachtskarte\nerstellen", variant='primary', elem_id='generate-button')
|
| 120 |
with gr.Row():
|
| 121 |
promt_example_de = gr.Textbox(visible=False)
|
| 122 |
gr.Examples(elem_id="prompt-examples", examples=PROMPT_EXAMPLES, inputs=[promt_example_de], cache_examples=False)
|
|
@@ -137,12 +140,14 @@ with shared.gradio_root:
|
|
| 137 |
value=pil_image_with_overlay(Image.open("resources/init.png"), toggle_greet.value, greet.value))
|
| 138 |
|
| 139 |
promt_example_de.change(fn=translate_promt_example, inputs=[promt_example_de], outputs=[prompt], queue=False)
|
| 140 |
-
toggle_greet.change(fn=toggle_greet_visibility, inputs=[toggle_greet], outputs=[greeting_row], queue=False)\
|
| 141 |
-
.then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)
|
| 142 |
-
greet.change(fn=debounce, outputs=[generated_image_overlayed], queue=False)\
|
| 143 |
-
.then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)
|
| 144 |
-
run_button.click(fn=
|
| 145 |
-
.then(fn=
|
|
|
|
|
|
|
| 146 |
|
| 147 |
shared.gradio_root.queue(concurrency_count=1, api_open=False)
|
| 148 |
shared.gradio_root.launch(server_name="0.0.0.0", show_api=False)
|
|
|
|
| 19 |
]
|
| 20 |
|
| 21 |
def generate(*args):
|
| 22 |
+
yield gr.update(value=modules.html.make_progress_html(1, "0/30")), \
|
| 23 |
+
gr.update()
|
|
|
|
|
|
|
| 24 |
|
| 25 |
while worker.is_working:
|
| 26 |
time.sleep(0.1)
|
|
|
|
| 35 |
flag, product = worker.outputs.pop(0)
|
| 36 |
if flag == 'preview':
|
| 37 |
percentage, title, image = product
|
| 38 |
+
yield gr.update(value=modules.html.make_progress_html(percentage, title)), \
|
| 39 |
+
gr.update(value=image) if image is not None else gr.update()
|
|
|
|
|
|
|
| 40 |
if flag == 'results':
|
| 41 |
image = product[0]
|
| 42 |
+
yield gr.update(value=""), \
|
| 43 |
+
gr.update(value=image)
|
|
|
|
|
|
|
| 44 |
finished = True
|
| 45 |
return
|
| 46 |
|
|
|
|
| 50 |
def toggle_greet_visibility(is_visible):
|
| 51 |
return gr.update(visible=is_visible)
|
| 52 |
|
| 53 |
+
def __toggle_generate_state(is_preview):
|
| 54 |
+
return gr.update(visible=is_preview), gr.update(visible=not is_preview), gr.update(interactive=not is_preview)
|
| 55 |
+
|
| 56 |
+
def prepare_generate():
|
| 57 |
+
return __toggle_generate_state(True)
|
| 58 |
+
|
| 59 |
+
def finish_generate():
|
| 60 |
+
return __toggle_generate_state(False)
|
| 61 |
+
|
| 62 |
def debounce():
|
| 63 |
time.sleep(0.5)
|
| 64 |
return gr.update()
|
|
|
|
| 119 |
style_selection = gr.Dropdown(choices=style_keys, value='Kinofilm', container=False, elem_id="style-selection")
|
| 120 |
with gr.Column(scale=1, min_width="80px"):
|
| 121 |
progress_html = gr.HTML(visible=True, elem_id='progress-bar', elem_classes='progress-bar')
|
| 122 |
+
run_button = gr.Button(value="Weihnachtskarte\nerstellen", variant='primary', elem_id='generate-button', )
|
| 123 |
with gr.Row():
|
| 124 |
promt_example_de = gr.Textbox(visible=False)
|
| 125 |
gr.Examples(elem_id="prompt-examples", examples=PROMPT_EXAMPLES, inputs=[promt_example_de], cache_examples=False)
|
|
|
|
| 140 |
value=pil_image_with_overlay(Image.open("resources/init.png"), toggle_greet.value, greet.value))
|
| 141 |
|
| 142 |
promt_example_de.change(fn=translate_promt_example, inputs=[promt_example_de], outputs=[prompt], queue=False)
|
| 143 |
+
toggle_greet.change(fn=toggle_greet_visibility, inputs=[toggle_greet], outputs=[greeting_row], queue=False, show_progress=False)\
|
| 144 |
+
.then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], show_progress=False, queue=False)
|
| 145 |
+
greet.change(fn=debounce, outputs=[generated_image_overlayed], queue=False, show_progress=False)\
|
| 146 |
+
.then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False, show_progress=False)
|
| 147 |
+
run_button.click(fn=prepare_generate, outputs=[generated_image_raw, generated_image_overlayed, run_button], queue=False)\
|
| 148 |
+
.then(fn=generate, inputs=[prompt, style_selection], outputs=[progress_html, generated_image_raw], queue=True)\
|
| 149 |
+
.then(fn=make_overlay, inputs=[generated_image_raw, toggle_greet, greet], outputs=[generated_image_overlayed], queue=False)\
|
| 150 |
+
.then(fn=finish_generate, outputs=[generated_image_raw, generated_image_overlayed, run_button], queue=False)
|
| 151 |
|
| 152 |
shared.gradio_root.queue(concurrency_count=1, api_open=False)
|
| 153 |
shared.gradio_root.launch(server_name="0.0.0.0", show_api=False)
|