From a1219e84e2a00d1f75613e92e6b0a70ff94d03f2 Mon Sep 17 00:00:00 2001 From: w-e-w <40751091+w-e-w@users.noreply.github.com> Date: Mon, 19 Aug 2024 06:11:08 +0900 Subject: [PATCH] hires button, opt insert gallery add option to insert the resulting images into Gallery as opposed to replace original when using high button to perform upscale --- modules/shared_options.py | 1 + modules/txt2img.py | 10 +++++++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/modules/shared_options.py b/modules/shared_options.py index 9f4520274..c273bcd41 100644 --- a/modules/shared_options.py +++ b/modules/shared_options.py @@ -314,6 +314,7 @@ options_templates.update(options_section(('ui_gallery', "Gallery", "ui"), { "sd_webui_modal_lightbox_toolbar_opacity": OptionInfo(0.9, "Full page image viewer: tool bar opacity", gr.Slider, {"minimum": 0.0, "maximum": 1, "step": 0.01}, onchange=shared.reload_gradio_theme).info('for mouse only').needs_reload_ui(), "gallery_height": OptionInfo("", "Gallery height", gr.Textbox).info("can be any valid CSS value, for example 768px or 20em").needs_reload_ui(), "open_dir_button_choice": OptionInfo("Subdirectory", "What directory the [📂] button opens", gr.Radio, {"choices": ["Output Root", "Subdirectory", "Subdirectory (even temp dir)"]}), + "hires_button_gallery_inset": OptionInfo(False, "Insert [✨] hires button results to gallery").info("when False the original first pass image is replaced by the results"), })) options_templates.update(options_section(('ui_alternatives', "UI alternatives", "ui"), { diff --git a/modules/txt2img.py b/modules/txt2img.py index 6f20253ae..9c22d2f39 100644 --- a/modules/txt2img.py +++ b/modules/txt2img.py @@ -87,15 +87,19 @@ def txt2img_upscale(id_task: str, request: gr.Request, gallery, gallery_index, g new_gallery = [] for i, image in enumerate(gallery): if i == gallery_index: - geninfo["infotexts"][gallery_index: gallery_index+1] = processed.infotexts + if shared.opts.hires_button_gallery_inset: + fake_image = Image.new(mode="RGB", size=(1, 1)) + fake_image.already_saved_as = image["name"].rsplit('?', 1)[0] + new_gallery.append(fake_image) + geninfo["infotexts"][gallery_index+1: gallery_index+1] = processed.infotexts + else: + geninfo["infotexts"][gallery_index: gallery_index+1] = processed.infotexts new_gallery.extend(processed.images) else: fake_image = Image.new(mode="RGB", size=(1, 1)) fake_image.already_saved_as = image["name"].rsplit('?', 1)[0] new_gallery.append(fake_image) - geninfo["infotexts"][gallery_index] = processed.info - return new_gallery, json.dumps(geninfo), plaintext_to_html(processed.info), plaintext_to_html(processed.comments, classname="comments")