right-click erase is now an option
This commit is contained in:
parent
fe508f8b21
commit
3062766c13
2 changed files with 13 additions and 1 deletions
|
@ -65,6 +65,8 @@
|
||||||
<input type="range" id="scaleFactor" name="scaleFactor" min="1" max="16" /><br />
|
<input type="range" id="scaleFactor" name="scaleFactor" min="1" max="16" /><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>
|
||||||
|
<input type="checkbox" id="cbxEnableErasing" onchange="changeEnableErasing()"><br />
|
||||||
<label for="cbxPaint">Mask mode?</label>
|
<label for="cbxPaint">Mask mode?</label>
|
||||||
<input type="checkbox" id="cbxPaint" onchange="changePaintMode()"><br />
|
<input type="checkbox" id="cbxPaint" onchange="changePaintMode()"><br />
|
||||||
<label for="cbxErase"><s>Erase mask?</s></label>
|
<label for="cbxErase"><s>Erase mask?</s></label>
|
||||||
|
|
12
js/index.js
12
js/index.js
|
@ -117,6 +117,7 @@ var arbitraryImageData;
|
||||||
var arbitraryImageBitmap;
|
var arbitraryImageBitmap;
|
||||||
var arbitraryImageBase64; // seriously js cmon work with me here
|
var arbitraryImageBase64; // seriously js cmon work with me here
|
||||||
var placingArbitraryImage = false; // for when the user has loaded an existing image from their computer
|
var placingArbitraryImage = false; // for when the user has loaded an existing image from their computer
|
||||||
|
var enableErasing = false; // accidental right-click erase if the user isn't trying to erase is a bad thing
|
||||||
|
|
||||||
// info div, sometimes hidden
|
// info div, sometimes hidden
|
||||||
let mouseXInfo = document.getElementById("mouseX");
|
let mouseXInfo = document.getElementById("mouseX");
|
||||||
|
@ -464,7 +465,7 @@ function mouseDown(evt) {
|
||||||
nextBox.h = basePixelCount * scaleFactor;
|
nextBox.h = basePixelCount * scaleFactor;
|
||||||
drawTargets.push(nextBox);
|
drawTargets.push(nextBox);
|
||||||
}
|
}
|
||||||
} else if (evt.button == 2 && !paintMode) { // right click, also gotta make sure mask blob isn't being used as it's visually inconsistent with behavior of erased region
|
} else if (evt.button == 2 && enableErasing && !paintMode) { // right click, also gotta make sure mask blob isn't being used as it's visually inconsistent with behavior of erased region
|
||||||
// erase the canvas underneath the cursor,
|
// erase the canvas underneath the cursor,
|
||||||
ctx = imgCanvas.getContext('2d');
|
ctx = imgCanvas.getContext('2d');
|
||||||
if (snapToGrid) {
|
if (snapToGrid) {
|
||||||
|
@ -753,11 +754,18 @@ function changePaintMode() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeEraseMode() {
|
function changeEraseMode() {
|
||||||
|
//TODO rename/refactor to make it more obvious this is just for painted masks
|
||||||
eraseMode = document.getElementById("cbxErase").checked;
|
eraseMode = document.getElementById("cbxErase").checked;
|
||||||
clearTargetMask();
|
clearTargetMask();
|
||||||
ovCtx.clearRect(0, 0, ovCanvas.width, ovCanvas.height);
|
ovCtx.clearRect(0, 0, ovCanvas.width, ovCanvas.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function changeEnableErasing() {
|
||||||
|
// yeah because this is for the image layer
|
||||||
|
enableErasing = document.getElementById("cbxEnableErasing").checked;
|
||||||
|
localStorage.setItem("enable_erase", enableErasing);
|
||||||
|
}
|
||||||
|
|
||||||
function changeSampler() {
|
function changeSampler() {
|
||||||
stableDiffusionData.sampler_index = document.getElementById("samplerSelect").value;
|
stableDiffusionData.sampler_index = document.getElementById("samplerSelect").value;
|
||||||
localStorage.setItem("sampler", stableDiffusionData.sampler_index);
|
localStorage.setItem("sampler", stableDiffusionData.sampler_index);
|
||||||
|
@ -916,10 +924,12 @@ function loadSettings() {
|
||||||
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"));
|
||||||
|
var _enable_erase = Boolean(localStorage.getItem("enable_erase") == (null || "false") ? false : localStorage.getItem("enable_erase"));
|
||||||
|
|
||||||
// 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("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);
|
||||||
|
document.getElementById("cbxEnableErasing").checked = Boolean(_enable_erase);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue