Merge branch 'pr/14' into main

This commit is contained in:
tim h 2022-11-19 22:40:57 -06:00
commit aa2c1956ee
3 changed files with 50 additions and 58 deletions

View file

@ -136,6 +136,7 @@ imported a transparent clip of a [relatively famous happy lil kitty](https://com
- 0.0.5 - import arbitrary image from user's machine, "auto" txt2img hires fix, Very Important "new image" button [3b7f4e3](https://github.com/zero01101/openOutpaint/commit/3b7f4e3759d0d1f3b38eba7249e5b58bc8162c75) - 0.0.5 - import arbitrary image from user's machine, "auto" txt2img hires fix, Very Important "new image" button [3b7f4e3](https://github.com/zero01101/openOutpaint/commit/3b7f4e3759d0d1f3b38eba7249e5b58bc8162c75)
- 0.0.5.1 - erase rendered imagery with right click, ensure webUI is running (thanks again [@Kalekki](https://github.com/Kalekki)! (https://github.com/zero01101/openOutpaint/pull/7)) [54577d4](https://github.com/zero01101/openOutpaint/commit/54577d4f15fd7d014aaf2471e0042b3c48735e9c) - 0.0.5.1 - erase rendered imagery with right click, ensure webUI is running (thanks again [@Kalekki](https://github.com/Kalekki)! (https://github.com/zero01101/openOutpaint/pull/7)) [54577d4](https://github.com/zero01101/openOutpaint/commit/54577d4f15fd7d014aaf2471e0042b3c48735e9c)
- 0.0.5.5 - highly attractive and functional floating control panel which will be extremely useful for infinite canvas, [@Kalekki](https://github.com/Kalekki) is literally the best ([11](https://github.com/zero01101/openOutpaint/pull/11)) [dac188d](https://github.com/zero01101/openOutpaint/commit/dac188dbfb086d3063f14b1a6a6a5b3add1aa5f5) - 0.0.5.5 - highly attractive and functional floating control panel which will be extremely useful for infinite canvas, [@Kalekki](https://github.com/Kalekki) is literally the best ([11](https://github.com/zero01101/openOutpaint/pull/11)) [dac188d](https://github.com/zero01101/openOutpaint/commit/dac188dbfb086d3063f14b1a6a6a5b3add1aa5f5)
- 0.0.5.6 - _FINALLY_ the sliders update their values in realtime, a nice overall start on cleaning up my mess (thanks [@seijihariki](https://github.com/seijihariki)!) [d9fb87a](https://github.com/zero01101/openOutpaint/commit/d9fb87acec6653f19a9dac7777bd866782303ebc)
## what's with the fish? ## what's with the fish?
deep aquatic life is _fascinating_ so i went with something underwater for a default prompt which led to making an _"illustration of a bright orange fish, plain blue solid background"_ favicon which led to "ok then, fish is mascot" deep aquatic life is _fascinating_ so i went with something underwater for a default prompt which led to making an _"illustration of a bright orange fish, plain blue solid background"_ favicon which led to "ok then, fish is mascot"

View file

@ -3,7 +3,7 @@
<head> <head>
<meta charset="utf-8" /> <meta charset="utf-8" />
<title>openOutpaint 🐠 0.0.5.5</title> <title>openOutpaint 🐠 0.0.5.6</title>
<link href="css/index.css" rel="stylesheet" /> <link href="css/index.css" rel="stylesheet" />
<link rel="icon" type="image/x-icon" href="favicon.ico"> <link rel="icon" type="image/x-icon" href="favicon.ico">
</head> </head>
@ -50,28 +50,19 @@
<option value="DPM++ 2S a Karras">DPM++2Sa Karras</option> <option value="DPM++ 2S a Karras">DPM++2Sa Karras</option>
<option value="DPM++ 2M Karras">DPM++2M Karras</option> <option value="DPM++ 2M Karras">DPM++2M Karras</option>
</select><br /> </select><br />
<label for="steps">Steps:</label> <label for="steps">Steps: <input type="number" id="stepsTxt"></label><br />
<span id="stepsTxt"></span><br /> <input type="range" id="steps" name="steps" min="1" max="50" /><br />
<input type="range" id="steps" name="steps" min="1" max="50" value="30" <label for="cfgScale">CFG scale: <input type="number" id="cfgScaleTxt"></label>
onchange="changeSteps()" /><br /> <br />
<label for="cfgScale">CFG scale:</label> <input type="range" id="cfgScale" name="cfgScale" min="-1" max="25" step="0.5" /><br />
<span id="cfgScaleTxt"></span><br /> <label for="batchSize">Batch size: <input type="number" id="batchSizeText"></label><br />
<input type="range" id="cfgScale" name="cfgScale" min="-1" max="25" value="7.5" step="0.5" <input type="range" id="batchSize" name="batchSize" min="1" max="8" step="1" /><br />
onchange="changeCfgScale()" /><br /> <label for="batchCount">Batch count: <input type="number" id="batchCountText"></label><br />
<label for="batchSize">Batch size:</label> <input type="range" id="batchCount" name="batchCount" min="1" max="8" step="1" /><br />
<span id="batchSizeText"></span><br />
<input type="range" id="batchSize" name="batchSize" min="1" max="8" value="2" step="1"
onchange="changeBatchSize()" /><br />
<label for="batchCount">Batch count:</label>
<span id="batchCountText"></span><br />
<input type="range" id="batchCount" name="batchCount" min="1" max="8" value="2" step="1"
onchange="changeBatchCount()" /><br />
<hr> <hr>
</div> </div>
<label for="scaleFactor">Scale factor:</label> <label for="scaleFactor">Scale factor: <input type="number" id="scaleFactorTxt"></label><br />
<span id="scaleFactorTxt"></span><br /> <input type="range" id="scaleFactor" name="scaleFactor" min="1" max="16" /><br />
<input type="range" id="scaleFactor" name="scaleFactor" min="1" max="16" value="8"
onchange="changeScaleFactor()" /><br />
<label for="cbxSnap">Snap to grid?</label> <label for="cbxSnap">Snap to grid?</label>
<input type="checkbox" id="cbxSnap" onchange="changeSnapMode()" checked="checked"><br /> <input type="checkbox" id="cbxSnap" onchange="changeSnapMode()" checked="checked"><br />
<label for="cbxEnableErasing">Right-click erase?</label> <label for="cbxEnableErasing">Right-click erase?</label>

View file

@ -7,15 +7,15 @@ var stableDiffusionData = { //includes img2img data but works for txt2img just f
prompt: "", prompt: "",
negative_prompt: "", negative_prompt: "",
seed: -1, seed: -1,
cfg_scale: 7, cfg_scale: null,
sampler_index: "DDIM", sampler_index: "DDIM",
steps: 30, steps: null,
denoising_strength: 1, denoising_strength: 1,
mask_blur: 0, mask_blur: 0,
batch_size: 2, batch_size: null,
width: 512, width: 512,
height: 512, height: 512,
n_iter: 2, // batch count n_iter: null, // batch count
mask: "", mask: "",
init_images: [], init_images: [],
inpaint_full_res: false, inpaint_full_res: false,
@ -47,6 +47,34 @@ var stableDiffusionData = { //includes img2img data but works for txt2img just f
} }
/**
* Some Utility Functions
*/
function sliderChangeHandlerFactory(sliderId, textBoxId, dataKey, defaultV) {
const sliderEl = document.getElementById(sliderId);
const textBoxEl = document.getElementById(textBoxId);
const savedValue = localStorage.getItem(dataKey);
if (savedValue) stableDiffusionData[dataKey] = savedValue || defaultV;
function changeHandler(evn) {
const eventSource = evn && evn.srcElement;
const value = eventSource && Number(eventSource.value);
if (value) stableDiffusionData[dataKey] = value;
if (!eventSource || eventSource.id === textBoxId) sliderEl.value = stableDiffusionData[dataKey];
textBoxEl.value = stableDiffusionData[dataKey] = Number(sliderEl.value);
localStorage.setItem(dataKey, stableDiffusionData[dataKey]);
}
textBoxEl.onchange = changeHandler
sliderEl.oninput = changeHandler
return changeHandler
}
// stuff things use // stuff things use
var blockNewImages = false; var blockNewImages = false;
var returnedImages; var returnedImages;
@ -708,15 +736,8 @@ function mouseUp(evt) {
} }
} }
function changeScaleFactor() { const changeScaleFactor = sliderChangeHandlerFactory("scaleFactor", "scaleFactorTxt", "scaleFactor", 8);
document.getElementById("scaleFactorTxt").innerText = scaleFactor = document.getElementById("scaleFactor").value; const changeSteps = sliderChangeHandlerFactory("steps", "stepsTxt", "steps", 30);
localStorage.setItem("scaleFactor", scaleFactor);
}
function changeSteps() {
document.getElementById("stepsTxt").innerText = stableDiffusionData.steps = document.getElementById("steps").value;
localStorage.setItem("steps", stableDiffusionData.steps);
}
function changePaintMode() { function changePaintMode() {
paintMode = document.getElementById("cbxPaint").checked; paintMode = document.getElementById("cbxPaint").checked;
@ -742,20 +763,9 @@ function changeSampler() {
localStorage.setItem("sampler", stableDiffusionData.sampler_index); localStorage.setItem("sampler", stableDiffusionData.sampler_index);
} }
function changeCfgScale() { const changeCfgScale = sliderChangeHandlerFactory("cfgScale", "cfgScaleTxt", "cfg_scale", 7.0);
document.getElementById("cfgScaleTxt").innerText = stableDiffusionData.cfg_scale = document.getElementById("cfgScale").value; const changeBatchSize = sliderChangeHandlerFactory("batchSize", "batchSizeText", "batch_size", 2);
localStorage.setItem("cfg_scale", stableDiffusionData.cfg_scale); const changeBatchCount = sliderChangeHandlerFactory("batchCount", "batchCountText", "n_iter", 2);
}
function changeBatchSize() {
document.getElementById("batchSizeText").innerText = stableDiffusionData.batch_size = document.getElementById("batchSize").value;
localStorage.setItem("batch_size", stableDiffusionData.batch_size);
}
function changeBatchCount() {
document.getElementById("batchCountText").innerText = stableDiffusionData.n_iter = document.getElementById("batchCount").value;
localStorage.setItem("n_iter", stableDiffusionData.n_iter);
}
function changeSnapMode() { function changeSnapMode() {
snapToGrid = document.getElementById("cbxSnap").checked; snapToGrid = document.getElementById("cbxSnap").checked;
@ -903,11 +913,6 @@ function checkIfWebuiIsRunning() {
function loadSettings() { function loadSettings() {
// set default values if not set DEFAULTS // set default values if not set DEFAULTS
var _sampler = localStorage.getItem("sampler") == null ? "DDIM" : localStorage.getItem("sampler"); var _sampler = localStorage.getItem("sampler") == null ? "DDIM" : localStorage.getItem("sampler");
var _steps = localStorage.getItem("steps") == null ? 30 : localStorage.getItem("steps");
var _cfg_scale = localStorage.getItem("cfg_scale") == null ? 7.0 : localStorage.getItem("cfg_scale");
var _batch_size = localStorage.getItem("batch_size") == null ? 2 : localStorage.getItem("batch_size");
var _n_iter = localStorage.getItem("n_iter") == null ? 2 : localStorage.getItem("n_iter");
var _scaleFactor = localStorage.getItem("scaleFactor") == null ? 8 : localStorage.getItem("scaleFactor");
var _mask_blur = localStorage.getItem("mask_blur") == null ? 0 : localStorage.getItem("mask_blur"); var _mask_blur = localStorage.getItem("mask_blur") == null ? 0 : localStorage.getItem("mask_blur");
var _seed = localStorage.getItem("seed") == null ? -1 : localStorage.getItem("seed"); var _seed = localStorage.getItem("seed") == null ? -1 : localStorage.getItem("seed");
var _enable_hr = Boolean(localStorage.getItem("enable_hr") == (null || "false") ? false : localStorage.getItem("enable_hr")); var _enable_hr = Boolean(localStorage.getItem("enable_hr") == (null || "false") ? false : localStorage.getItem("enable_hr"));
@ -915,11 +920,6 @@ function loadSettings() {
// set the values into the UI // set the values into the UI
document.getElementById("samplerSelect").value = String(_sampler); document.getElementById("samplerSelect").value = String(_sampler);
document.getElementById("steps").value = Number(_steps);
document.getElementById("cfgScale").value = Number(_cfg_scale);
document.getElementById("batchSize").value = Number(_batch_size);
document.getElementById("batchCount").value = Number(_n_iter);
document.getElementById("scaleFactor").value = Number(_scaleFactor);
document.getElementById("maskBlur").value = Number(_mask_blur); document.getElementById("maskBlur").value = Number(_mask_blur);
document.getElementById("seed").value = Number(_seed); document.getElementById("seed").value = Number(_seed);
document.getElementById("cbxHRFix").checked = Boolean(_enable_hr); document.getElementById("cbxHRFix").checked = Boolean(_enable_hr);