import numpy as np
import cv2
#%%
def get_new_scan_vertices(prev_mask, coords, scan_size=256):
    x0, y0 = coords
    x1, y1 = x0 + scan_size, y0 + scan_size

    # Create new scan mask
    new_mask = np.zeros_like(prev_mask, dtype=bool)
    new_mask[y0:y1, x0:x1] = True
    
    # Calculate the overlapping region: intersection between new and previous masks
    overlap_mask = new_mask & prev_mask

    # Convert to uint8 format for OpenCV
    overlap_mask_uint8 = overlap_mask.astype(np.uint8) * 255

    # Find external contours of the overlapping region
    contours, _ = cv2.findContours(overlap_mask_uint8, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

    # Extract vertices from contours
    vertices = []
    for cnt in contours:
        for point in cnt:
            y, x = point[0]  # OpenCV uses (y, x)
            vertices.append((x, y))

    return vertices

def crop_fire_region(fire_image, vertices, coords):
    # Adjust the vertices to the new scan region coordinates
    adjusted_vertices = [(x - coords[0], y - coords[1]) for x, y in vertices]
    
    # Dimensions of the fire_image (it is now 256x256)
    H, W = fire_image.shape

    # Create a boolean mask where True represents points inside the polygon
    mask = np.zeros((H, W), dtype=bool)

    # Check if points are inside the polygon using even-odd rule
    def is_point_inside_polygon(x, y, vertices):
        n = len(vertices)
        inside = False
        p1x, p1y = vertices[0]
        for i in range(n + 1):
            p2x, p2y = vertices[i % n]
            if y > min(p1y, p2y):
                if y <= max(p1y, p2y):
                    if x <= max(p1x, p2x):
                        if p1y != p2y:
                            xinters = (y - p1y) * (p2x - p1x) / (p2y - p1y) + p1x
                        if p1x == p2x or x <= xinters:
                            inside = not inside
            p1x, p1y = p2x, p2y
        return inside

    # Iterate through the fire_image region and check if it's inside the polygon
    for y in range(H):
        for x in range(W):
            if is_point_inside_polygon(x, y, adjusted_vertices):
                mask[y, x] = True

    # Apply the mask to the fire_image to get the cropped region
    cropped_image = fire_image[mask]

    return cropped_image

