Path: blob/master/javascript/imageMaskFix.js
3055 views
/**1* temporary fix for https://github.com/AUTOMATIC1111/stable-diffusion-webui/issues/6682* @see https://github.com/gradio-app/gradio/issues/17213*/4function imageMaskResize() {5const canvases = gradioApp().querySelectorAll('#img2maskimg .touch-none canvas');6if (!canvases.length) {7window.removeEventListener('resize', imageMaskResize);8return;9}1011const wrapper = canvases[0].closest('.touch-none');12const previewImage = wrapper.previousElementSibling;1314if (!previewImage.complete) {15previewImage.addEventListener('load', imageMaskResize);16return;17}1819const w = previewImage.width;20const h = previewImage.height;21const nw = previewImage.naturalWidth;22const nh = previewImage.naturalHeight;23const portrait = nh > nw;2425const wW = Math.min(w, portrait ? h / nh * nw : w / nw * nw);26const wH = Math.min(h, portrait ? h / nh * nh : w / nw * nh);2728wrapper.style.width = `${wW}px`;29wrapper.style.height = `${wH}px`;30wrapper.style.left = `0px`;31wrapper.style.top = `0px`;3233canvases.forEach(c => {34c.style.width = c.style.height = '';35c.style.maxWidth = '100%';36c.style.maxHeight = '100%';37c.style.objectFit = 'contain';38});39}4041onAfterUiUpdate(imageMaskResize);42window.addEventListener('resize', imageMaskResize);434445