Martin Tomov commited on
Commit
3814c3a
·
verified ·
1 Parent(s): 5fc1e3f

retain original color

Browse files
Files changed (1) hide show
  1. app.py +5 -8
app.py CHANGED
@@ -136,15 +136,12 @@ def extract_and_paste_insect(original_image: np.ndarray, detection: DetectionRes
136
  insect_crop = original_image[ymin:ymax, xmin:xmax]
137
  mask_crop = mask[ymin:ymax, xmin:xmax]
138
 
139
- insect = cv2.bitwise_and(insect_crop, insect_crop, mask=mask_crop)
140
-
141
  # Ensure the insect retains its original color
142
- color_insect = cv2.bitwise_and(insect_crop, insect_crop, mask=mask_crop)
143
- non_mask_area = cv2.bitwise_and(background[ymin:ymax, xmin:xmax], background[ymin:ymax, xmin:xmax], mask=cv2.bitwise_not(mask_crop))
144
- combined = cv2.add(non_mask_area, color_insect)
145
-
146
- x_offset, y_offset = xmin, ymin
147
- background[y_offset:y_offset + combined.shape[0], x_offset:x_offset + combined.shape[1]] = combined
148
 
149
  def create_yellow_background_with_insects(image: np.ndarray, detections: List[DetectionResult]) -> np.ndarray:
150
  yellow_background = np.full((image.shape[0], image.shape[1], 3), (0, 255, 255), dtype=np.uint8) # BGR for yellow
 
136
  insect_crop = original_image[ymin:ymax, xmin:xmax]
137
  mask_crop = mask[ymin:ymax, xmin:xmax]
138
 
 
 
139
  # Ensure the insect retains its original color
140
+ insect = cv2.bitwise_and(insect_crop, insect_crop, mask=mask_crop)
141
+
142
+ # Place the insect on the yellow background
143
+ for c in range(3):
144
+ background[ymin:ymax, xmin:xmax, c] = background[ymin:ymax, xmin:xmax, c] * (1 - mask_crop) + insect[:, :, c] * mask_crop
 
145
 
146
  def create_yellow_background_with_insects(image: np.ndarray, detections: List[DetectionResult]) -> np.ndarray:
147
  yellow_background = np.full((image.shape[0], image.shape[1], 3), (0, 255, 255), dtype=np.uint8) # BGR for yellow