Skip to content

Commit

Permalink
feat:compatible with inconsistent/empty mask
Browse files Browse the repository at this point in the history
Signed-off-by: storyicon <storyicon@foxmail.com>
  • Loading branch information
storyicon committed Apr 18, 2024
1 parent 0980fdf commit 71314e4
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 12 deletions.
4 changes: 2 additions & 2 deletions modules/masking.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ def get_crop_region(mask, pad=0):
if box:
x1, y1, x2, y2 = box
else: # when no box is found
x1 = y1 = 0
x2, y2 = mask_img.size
x1, y1 = mask_img.size
x2 = y2 = 0
return max(x1 - pad, 0), max(y1 - pad, 0), min(x2 + pad, mask_img.size[0]), min(y2 + pad, mask_img.size[1])


Expand Down
23 changes: 13 additions & 10 deletions modules/processing.py
Original file line number Diff line number Diff line change
Expand Up @@ -1537,23 +1537,24 @@ def init(self, all_prompts, all_seeds, all_subseeds):
if self.mask_blur_x > 0 or self.mask_blur_y > 0:
self.extra_generation_params["Mask blur"] = self.mask_blur

if image_mask.size != (self.width, self.height):
image_mask = images.resize_image(self.resize_mode, image_mask, self.width, self.height)

if self.inpaint_full_res:
self.mask_for_overlay = image_mask
mask = image_mask.convert('L')
crop_region = masking.get_crop_region(mask, self.inpaint_full_res_padding)
crop_region = masking.expand_crop_region(crop_region, self.width, self.height, mask.width, mask.height)
x1, y1, x2, y2 = crop_region

mask = mask.crop(crop_region)
image_mask = images.resize_image(2, mask, self.width, self.height)
self.paste_to = (x1, y1, x2-x1, y2-y1)

if crop_region[0] >= crop_region[2] and crop_region[1] >= crop_region[3]:
crop_region = None
image_mask = None
self.mask_for_overlay = None
else:
crop_region = masking.expand_crop_region(crop_region, self.width, self.height, mask.width, mask.height)
x1, y1, x2, y2 = crop_region
mask = mask.crop(crop_region)
image_mask = images.resize_image(2, mask, self.width, self.height)
self.paste_to = (x1, y1, x2-x1, y2-y1)
self.extra_generation_params["Inpaint area"] = "Only masked"
self.extra_generation_params["Masked area padding"] = self.inpaint_full_res_padding
else:
image_mask = images.resize_image(self.resize_mode, image_mask, self.width, self.height)
np_mask = np.array(image_mask)
np_mask = np.clip((np_mask.astype(np.float32)) * 2, 0, 255).astype(np.uint8)
self.mask_for_overlay = Image.fromarray(np_mask)
Expand All @@ -1579,6 +1580,8 @@ def init(self, all_prompts, all_seeds, all_subseeds):
image = images.resize_image(self.resize_mode, image, self.width, self.height)

if image_mask is not None:
if self.mask_for_overlay.size != (image.width, image.height):
self.mask_for_overlay = images.resize_image(self.resize_mode, self.mask_for_overlay, image.width, image.height)
image_masked = Image.new('RGBa', (image.width, image.height))
image_masked.paste(image.convert("RGBA").convert("RGBa"), mask=ImageOps.invert(self.mask_for_overlay.convert('L')))

Expand Down

0 comments on commit 71314e4

Please sign in to comment.