fffiloni commited on
Commit
88590fc
·
verified ·
1 Parent(s): 2278a79

fixes resize alignment with vertical images

Browse files
Files changed (1) hide show
  1. app.py +26 -28
app.py CHANGED
@@ -58,19 +58,15 @@ def infer(image, width, height, overlap_width, num_inference_steps, resize_optio
58
  target_size = (width, height)
59
  overlap = overlap_width
60
 
61
- # Upscale if source is smaller than target in both dimensions
62
- if source.width < target_size[0] and source.height < target_size[1]:
63
- scale_factor = min(target_size[0] / source.width, target_size[1] / source.height)
64
- new_width = int(source.width * scale_factor)
65
- new_height = int(source.height * scale_factor)
66
- source = source.resize((new_width, new_height), Image.LANCZOS)
67
-
68
- if source.width > target_size[0] or source.height > target_size[1]:
69
- scale_factor = min(target_size[0] / source.width, target_size[1] / source.height)
70
- new_width = int(source.width * scale_factor)
71
- new_height = int(source.height * scale_factor)
72
- source = source.resize((new_width, new_height), Image.LANCZOS)
73
 
 
 
 
 
74
  if resize_option == "Full":
75
  resize_size = max(source.width, source.height)
76
  elif resize_option == "1/2":
@@ -87,29 +83,28 @@ def infer(image, width, height, overlap_width, num_inference_steps, resize_optio
87
  new_height = int(resize_size * aspect_ratio)
88
  source = source.resize((new_width, new_height), Image.LANCZOS)
89
 
90
- if not can_expand(source.width, source.height, target_size[0], target_size[1], alignment):
91
- alignment = "Middle"
92
-
93
  # Calculate margins based on alignment
94
  if alignment == "Middle":
95
- margin_x = (target_size[0] - source.width) // 2
96
- margin_y = (target_size[1] - source.height) // 2
97
  elif alignment == "Left":
98
  margin_x = 0
99
- margin_y = (target_size[1] - source.height) // 2
100
  elif alignment == "Right":
101
- margin_x = target_size[0] - source.width
102
- margin_y = (target_size[1] - source.height) // 2
103
  elif alignment == "Top":
104
- margin_x = (target_size[0] - source.width) // 2
105
  margin_y = 0
106
  elif alignment == "Bottom":
107
- margin_x = (target_size[0] - source.width) // 2
108
- margin_y = target_size[1] - source.height
109
 
 
110
  background = Image.new('RGB', target_size, (255, 255, 255))
111
  background.paste(source, (margin_x, margin_y))
112
 
 
113
  mask = Image.new('L', target_size, 255)
114
  mask_draw = ImageDraw.Draw(mask)
115
 
@@ -117,29 +112,32 @@ def infer(image, width, height, overlap_width, num_inference_steps, resize_optio
117
  if alignment == "Middle":
118
  mask_draw.rectangle([
119
  (margin_x + overlap, margin_y + overlap),
120
- (margin_x + source.width - overlap, margin_y + source.height - overlap)
121
  ], fill=0)
122
  elif alignment == "Left":
123
  mask_draw.rectangle([
124
  (margin_x, margin_y),
125
- (margin_x + source.width - overlap, margin_y + source.height)
126
  ], fill=0)
127
  elif alignment == "Right":
128
  mask_draw.rectangle([
129
  (margin_x + overlap, margin_y),
130
- (margin_x + source.width, margin_y + source.height)
131
  ], fill=0)
132
  elif alignment == "Top":
133
  mask_draw.rectangle([
134
  (margin_x, margin_y),
135
- (margin_x + source.width, margin_y + source.height - overlap)
136
  ], fill=0)
137
  elif alignment == "Bottom":
138
  mask_draw.rectangle([
139
  (margin_x, margin_y + overlap),
140
- (margin_x + source.width, margin_y + source.height)
141
  ], fill=0)
142
 
 
 
 
143
  cnet_image = background.copy()
144
  cnet_image.paste(0, (0, 0), mask)
145
 
 
58
  target_size = (width, height)
59
  overlap = overlap_width
60
 
61
+ # Calculate the scaling factor to fit the image within the target size
62
+ scale_factor = min(target_size[0] / source.width, target_size[1] / source.height)
63
+ new_width = int(source.width * scale_factor)
64
+ new_height = int(source.height * scale_factor)
 
 
 
 
 
 
 
 
65
 
66
+ # Resize the source image
67
+ source = source.resize((new_width, new_height), Image.LANCZOS)
68
+
69
+ # Apply resize option
70
  if resize_option == "Full":
71
  resize_size = max(source.width, source.height)
72
  elif resize_option == "1/2":
 
83
  new_height = int(resize_size * aspect_ratio)
84
  source = source.resize((new_width, new_height), Image.LANCZOS)
85
 
 
 
 
86
  # Calculate margins based on alignment
87
  if alignment == "Middle":
88
+ margin_x = (target_size[0] - new_width) // 2
89
+ margin_y = (target_size[1] - new_height) // 2
90
  elif alignment == "Left":
91
  margin_x = 0
92
+ margin_y = (target_size[1] - new_height) // 2
93
  elif alignment == "Right":
94
+ margin_x = target_size[0] - new_width
95
+ margin_y = (target_size[1] - new_height) // 2
96
  elif alignment == "Top":
97
+ margin_x = (target_size[0] - new_width) // 2
98
  margin_y = 0
99
  elif alignment == "Bottom":
100
+ margin_x = (target_size[0] - new_width) // 2
101
+ margin_y = target_size[1] - new_height
102
 
103
+ # Create a new background image and paste the resized source image
104
  background = Image.new('RGB', target_size, (255, 255, 255))
105
  background.paste(source, (margin_x, margin_y))
106
 
107
+ # Create the mask
108
  mask = Image.new('L', target_size, 255)
109
  mask_draw = ImageDraw.Draw(mask)
110
 
 
112
  if alignment == "Middle":
113
  mask_draw.rectangle([
114
  (margin_x + overlap, margin_y + overlap),
115
+ (margin_x + new_width - overlap, margin_y + new_height - overlap)
116
  ], fill=0)
117
  elif alignment == "Left":
118
  mask_draw.rectangle([
119
  (margin_x, margin_y),
120
+ (margin_x + new_width - overlap, margin_y + new_height)
121
  ], fill=0)
122
  elif alignment == "Right":
123
  mask_draw.rectangle([
124
  (margin_x + overlap, margin_y),
125
+ (margin_x + new_width, margin_y + new_height)
126
  ], fill=0)
127
  elif alignment == "Top":
128
  mask_draw.rectangle([
129
  (margin_x, margin_y),
130
+ (margin_x + new_width, margin_y + new_height - overlap)
131
  ], fill=0)
132
  elif alignment == "Bottom":
133
  mask_draw.rectangle([
134
  (margin_x, margin_y + overlap),
135
+ (margin_x + new_width, margin_y + new_height)
136
  ], fill=0)
137
 
138
+ if not can_expand(source.width, source.height, target_size[0], target_size[1], alignment):
139
+ alignment = "Middle"
140
+
141
  cnet_image = background.copy()
142
  cnet_image.paste(0, (0, 0), mask)
143