Spaces:
Running
on
Zero
Running
on
Zero
Martin Tomov
commited on
Ensure the insect retains its original color
Browse files
app.py
CHANGED
@@ -138,11 +138,13 @@ def extract_and_paste_insect(original_image: np.ndarray, detection: DetectionRes
|
|
138 |
|
139 |
insect = cv2.bitwise_and(insect_crop, insect_crop, mask=mask_crop)
|
140 |
|
141 |
-
|
142 |
-
|
|
|
|
|
143 |
|
144 |
-
|
145 |
-
|
146 |
|
147 |
def create_yellow_background_with_insects(image: np.ndarray, detections: List[DetectionResult]) -> np.ndarray:
|
148 |
yellow_background = np.full((image.shape[0], image.shape[1], 3), (0, 255, 255), dtype=np.uint8) # BGR for yellow
|
|
|
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
|