mirror of
				https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
				synced 2025-10-31 18:15:16 +00:00 
			
		
		
		
	 a1d3cbf92c
			
		
	
	
		a1d3cbf92c
		
	
	
	
	
		
			
			left / top alignment was necessary with gradio 3.4.1. In gradio 3.5 the parent div of the image mask is centered, so the left / top alignment put the mask in the wrong place as described in #2750 #2795 #2805. This fix was tested on Windows 10 / Chrome.
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * temporary fix for https://github.com/AUTOMATIC1111/stable-diffusion-webui/issues/668
 | |
|  * @see https://github.com/gradio-app/gradio/issues/1721
 | |
|  */
 | |
| window.addEventListener( 'resize', () => imageMaskResize());
 | |
| function imageMaskResize() {
 | |
|     const canvases = gradioApp().querySelectorAll('#img2maskimg .touch-none canvas');
 | |
|     if ( ! canvases.length ) {
 | |
|     canvases_fixed = false;
 | |
|     window.removeEventListener( 'resize', imageMaskResize );
 | |
|     return;
 | |
|     }
 | |
| 
 | |
|     const wrapper = canvases[0].closest('.touch-none');
 | |
|     const previewImage = wrapper.previousElementSibling;
 | |
| 
 | |
|     if ( ! previewImage.complete ) {
 | |
|         previewImage.addEventListener( 'load', () => imageMaskResize());
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     const w = previewImage.width;
 | |
|     const h = previewImage.height;
 | |
|     const nw = previewImage.naturalWidth;
 | |
|     const nh = previewImage.naturalHeight;
 | |
|     const portrait = nh > nw;
 | |
|     const factor = portrait;
 | |
| 
 | |
|     const wW = Math.min(w, portrait ? h/nh*nw : w/nw*nw);
 | |
|     const wH = Math.min(h, portrait ? h/nh*nh : w/nw*nh);
 | |
| 
 | |
|     wrapper.style.width = `${wW}px`;
 | |
|     wrapper.style.height = `${wH}px`;
 | |
|     wrapper.style.left = `0px`;
 | |
|     wrapper.style.top = `0px`;
 | |
| 
 | |
|     canvases.forEach( c => {
 | |
|         c.style.width = c.style.height = '';
 | |
|         c.style.maxWidth = '100%';
 | |
|         c.style.maxHeight = '100%';
 | |
|         c.style.objectFit = 'contain';
 | |
|     });
 | |
|  }
 | |
|   
 | |
|  onUiUpdate(() => imageMaskResize());
 |