From e6c54d4b56ce0ad8abbbb9998bd0eb964f1e6638 Mon Sep 17 00:00:00 2001 From: tim h Date: Sat, 4 Feb 2023 14:28:01 -0600 Subject: [PATCH 1/2] initial changes for instruct-pix2pix img2img i'd still like the new slider to disappear if not using an iP2P model ergo not in main yet but also not "new" enough of a feature to deserve its own branch, literally just a new field to pass along with POSTs and an associated slider input --- index.html | 6 +++--- js/index.js | 26 ++++++++++++++++++++++++++ js/ui/tool/dream.js | 17 +++++++++++++++++ 3 files changed, 46 insertions(+), 3 deletions(-) diff --git a/index.html b/index.html index d1a69eb..0b38969 100644 --- a/index.html +++ b/index.html @@ -250,7 +250,7 @@
- Alpha release v0.0.14 + Alpha release v0.0.14.1
- + - + diff --git a/js/index.js b/js/index.js index 90485d9..651bbdd 100644 --- a/js/index.js +++ b/js/index.js @@ -604,6 +604,13 @@ let modelAutoComplete = createAutoComplete( "refreshable" ); modelAutoComplete.onchange.on(({value}) => { + /** + * TODO implement optional API call to check model unet channel count + * extension users guaranteed to have it as of + * https://github.com/zero01101/openOutpaint-webUI-extension/commit/1f22f5ea5b860c6e91f77edfb47743a124596dec + * but still need a fallback check like below + */ + if (value.toLowerCase().includes("inpainting")) document.querySelector( "#models-ac-select input.autocomplete-text" @@ -1357,3 +1364,22 @@ function checkFocus() { focused = true; } } + +function togglePix2PixImgCfg(value) { + // super hacky + // actually doesn't work at all yet so i'm leaving it here to taunt and remind me of my failures + + try { + if (value.toLowerCase().includes("pix2pix")) { + document + .querySelector(".instruct-pix2pix-img-cfg") + .classList.remove("invisible"); + } else { + document + .querySelector(".instruct-pix2pix-img-cfg") + .classList.add("invisible"); + } + } catch (e) { + // highly likely not currently using img2img tool, do nothing + } +} diff --git a/js/ui/tool/dream.js b/js/ui/tool/dream.js index 154193c..457d7f2 100644 --- a/js/ui/tool/dream.js +++ b/js/ui/tool/dream.js @@ -2306,6 +2306,22 @@ const img2imgTool = () => textStep: 1, } ).slider; + + // img cfg scale slider for instruct-pix2pix + state.ctxmenu.instructPix2PixImgCfgLabel = _toolbar_input.slider( + state, + "image_cfg_scale", + "iP2P Image CFG Scale", + { + min: 0, + max: 30, + step: 1, + textStep: 0.1, + } + ).slider; + state.ctxmenu.instructPix2PixImgCfgLabel.classList.add( + "instruct-pix2pix-img-cfg" + ); } menu.appendChild(state.ctxmenu.cursorSizeSlider); @@ -2320,6 +2336,7 @@ const img2imgTool = () => // menu.appendChild(state.ctxmenu.keepUnmaskedBlurSliderLinebreak); menu.appendChild(state.ctxmenu.inpaintTypeSelect); menu.appendChild(state.ctxmenu.denoisingStrengthSlider); + menu.appendChild(state.ctxmenu.instructPix2PixImgCfgLabel); const btnArray2 = document.createElement("div"); btnArray2.classList.add("checkbox-array"); btnArray2.appendChild(state.ctxmenu.fullResolutionLabel); From 6148bf8e109aedd1a95ab7d61d15b8246ad0ad61 Mon Sep 17 00:00:00 2001 From: tim h Date: Sat, 4 Feb 2023 15:25:53 -0600 Subject: [PATCH 2/2] ...is this even working? --- index.html | 2 +- js/ui/tool/dream.js | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/index.html b/index.html index 0b38969..aa345dc 100644 --- a/index.html +++ b/index.html @@ -433,7 +433,7 @@ src="js/ui/tool/generic.js?v=3e678e0" type="text/javascript"> - + diff --git a/js/ui/tool/dream.js b/js/ui/tool/dream.js index 457d7f2..3f6055d 100644 --- a/js/ui/tool/dream.js +++ b/js/ui/tool/dream.js @@ -1049,6 +1049,7 @@ const dream_generate_callback = async (bb, resolution, state) => { ); request.mask = maskCanvas.toDataURL(); request.inpainting_fill = stableDiffusionData.outpainting_fill; + request.image_cfg_scale = stableDiffusionData.image_cfg_scale; // Dream _generate("img2img", request, bb, { @@ -1129,6 +1130,7 @@ const dream_img2img_callback = (bb, resolution, state) => { request.denoising_strength = state.denoisingStrength; request.inpainting_fill = state.inpainting_fill ?? 1; //let's see how this works //1; // For img2img use original + request.image_cfg_scale = state.image_cfg_scale ?? 0.5; // what am i even doing // Load prompt (maybe we should add some events so we don't have to do this) request.prompt = document.getElementById("prompt").value;