diff --git a/index.html b/index.html index 1cda974..dc222f3 100644 --- a/index.html +++ b/index.html @@ -101,6 +101,7 @@
+
@@ -340,7 +341,7 @@ - + - + diff --git a/js/index.js b/js/index.js index d9ac3a2..a2a7ae8 100644 --- a/js/index.js +++ b/js/index.js @@ -642,7 +642,7 @@ makeSlider( ); // 20230102 grumble grumble -makeSlider( +const hrFixScaleSlider = makeSlider( "HRfix Scale", document.getElementById("hrFixScale"), "hr_scale", @@ -664,6 +664,17 @@ makeSlider( 0.01 ); +const lockPxSlider = makeSlider( + "HRfix Autoscale Lock Px.", + document.getElementById("hrFixLockPx"), + "hr_fix_lock_px", + 0, + 1024, + 256, + 0, + 1 +); + function changeMaskBlur() { stableDiffusionData.mask_blur = parseInt( document.getElementById("maskBlur").value @@ -685,17 +696,20 @@ function changeHiResFix() { var hrfOpotions = document.getElementById("hrFixUpscaler"); var hrfLabel = document.getElementById("hrFixLabel"); var hrfDenoiseSlider = document.getElementById("hrDenoising"); + var hrfLockPxSlider = document.getElementById("hrFixLockPx"); if (stableDiffusionData.enable_hr) { hrfSlider.classList.remove("invisible"); hrfOpotions.classList.remove("invisible"); hrfLabel.classList.remove("invisible"); hrfDenoiseSlider.classList.remove("invisible"); + hrfLockPxSlider.classList.remove("invisible"); //state.ctxmenu.keepUnmaskedBlurSliderLinebreak.classList.add("invisible"); } else { hrfSlider.classList.add("invisible"); hrfOpotions.classList.add("invisible"); hrfLabel.classList.add("invisible"); hrfDenoiseSlider.classList.add("invisible"); + hrfLockPxSlider.classList.add("invisible"); //state.ctxmenu.keepUnmaskedBlurSliderLinebreak.classList.remove("invisible"); } } @@ -1150,6 +1164,11 @@ function loadSettings() { localStorage.getItem("openoutpaint/hr_denoising_strength") === null ? 0.7 : localStorage.getItem("openoutpaint/hr_denoising_strength"); + let _hrfix_lock_px = + localStorage.getItem("openoutpaint/hr_fix_lock_px") === null + ? 0 + : localStorage.getItem("openoutpaint/hr_fix_lock_px"); + // set the values into the UI document.getElementById("maskBlur").value = Number(_mask_blur); document.getElementById("seed").value = Number(_seed); @@ -1159,6 +1178,7 @@ function loadSettings() { Boolean(_sync_cursor_size); document.getElementById("hrFixScale").value = Number(_hrfix_scale); document.getElementById("hrDenoising").value = Number(_hrfix_denoising); + document.getElementById("hrFixLockPx").value = Number(_hrfix_lock_px); } imageCollection.element.addEventListener( diff --git a/js/ui/tool/dream.js b/js/ui/tool/dream.js index 505fb2c..9792b3e 100644 --- a/js/ui/tool/dream.js +++ b/js/ui/tool/dream.js @@ -141,6 +141,22 @@ const _dream = async (endpoint, request) => { * we cheekily lie to SD and tell it that the original dimensions are _divided_ * by the scale factor so it returns something about the same size as we wanted initially */ + + // ok so instead, only do that if stableDiffusionData.hr_fix_lock_px > 0 + if (stableDiffusionData.hr_fix_lock_px > 0) { + // find the appropriate scale factor for hrfix + var widthFactor = + request.width / stableDiffusionData.hr_fix_lock_px <= 4 + ? request.width / stableDiffusionData.hr_fix_lock_px + : 4; + var heightFactor = + request.height / stableDiffusionData.hr_fix_lock_px <= 4 + ? request.height / stableDiffusionData.hr_fix_lock_px + : 4; + var factor = heightFactor > widthFactor ? heightFactor : widthFactor; + request.hr_scale = hrFixScaleSlider.value = factor < 1 ? 1 : factor; + } + var newWidth = Math.floor(request.width / request.hr_scale); var newHeight = Math.floor(request.height / request.hr_scale); request.width = newWidth;