import matplotlib.pyplot as plt
from matplotlib.patches import Rectangle, FancyArrowPatch

# ================================
# 1. Finder pattern (8x8) coloring
#    local_r, local_c are [0..7]
# ================================
def _get_finder_color(local_r, local_c):
    # 7x7 main body + 1 cell around (separator) = 8x8.
    if local_r == 7 or local_c == 7:
        return 0  # Separator (white)

    if local_r in [0, 6] or local_c in [0, 6]:
        return 1  # Outer frame (black)
    if local_r in [1, 5] or local_c in [1, 5]:
        return 0  # Inner (white)
    return 1      # Center (black)

# ================================
# 2. Timing pattern (row=6 or col=6)
# ================================
def _get_timing_color(r, c):
    # Alternating black and white for row=6 or col=6
    if r == 6:
        return 1 if (c % 2 == 0) else 0
    if c == 6:
        return 1 if (r % 2 == 0) else 0
    return None

# ================================
# 3. Alignment pattern (5x5)
# ================================
def _get_alignment_color(local_r, local_c):
    # Outer frame (0 or 4) => black (1)
    # 1 or 3 => white (0)
    # Center (2,2) => black (1)
    if local_r in [0, 4] or local_c in [0, 4]:
        return 1
    if local_r in [1, 3] or local_c in [1, 3]:
        return 0
    return 1

# ================================
# 4. Format Info coordinates
# ================================
top_left_format_info = {
    (8,0),(8,1),(8,2),(8,3),(8,4),(8,5),(8,7),(8,8),
    (0,8),(1,8),(2,8),(3,8),(4,8),(5,8),(7,8)
}
top_right_format_info = {
    (8,24),(8,23),(8,22),(8,21),(8,20),(8,19),(8,18),(8,17),
    (25,8),(24,8),(23,8),(22,8),(21,8),(20,8),(19,8),(18,8),(17,8)
}
ALL_FORMAT_INFO = top_left_format_info.union(top_right_format_info)

# ================================
# 5. Functional pattern determination
# ================================
def get_module_color(r, c):
    """
    Version 2 (25x25) (r,c):
      - 3 finder patterns
      - Timing pattern
      - Alignment pattern
      - Format Info
      - Others (None) = data area
    """
    # Finder (top-left)
    if 0 <= r <= 7 and 0 <= c <= 7:
        return _get_finder_color(r, c)
    # Finder (top-right)
    if 0 <= r <= 7 and 17 <= c <= 24:
        return _get_finder_color(r, 24 - c)  # Left-right flip
    # Finder (bottom-left)
    if 17 <= r <= 24 and 0 <= c <= 7:
        return _get_finder_color(24 - r, c)  # Up-down flip

    # Timing
    t = _get_timing_color(r, c)
    if t is not None:
        return t

    # Alignment (5x5 near center)
    if 16 <= r <= 20 and 16 <= c <= 20:
        return _get_alignment_color(r - 16, c - 16)

    # Format info
    if (r, c) in ALL_FORMAT_INFO:
        return 2  # aliceblue display

    # Others (None) are data area
    return None

# ================================
# 6. Main
# ================================
def main():
    size = 25

    # (A) Functional pattern & data area drawing (reference: for visualization)
    fig, ax = plt.subplots(figsize=(7, 7))
    for r in range(size):
        for c in range(size):
            val = get_module_color(r, c)
            if val is None:
                facecolor = 'white'       # Data area
            elif val == 1:
                facecolor = 'black'       # Black
            elif val == 0:
                facecolor = 'lightgray'   # White (gray emphasized)
            elif val == 2:
                facecolor = 'aliceblue'   # Format info
            else:
                facecolor = 'white'

            rect = Rectangle((c, r), 1, 1,
                             edgecolor='black',
                             facecolor=facecolor,
                             linewidth=1)
            ax.add_patch(rect)

    ax.set_xlim(0, size)
    ax.set_ylim(0, size)
    ax.set_aspect('equal', 'box')
    ax.invert_yaxis()
    plt.axis('off')
    plt.tight_layout()
    # plt.show()  # Turn on if needed

    # --------------------------------------------------
    # (B) "Previous order" = bottom-right to left vertical zigzag (2 columns at a time)
    #     - current_col from 24 to 0
    #     - while switching direction_up
    #     - get cells that are not functional patterns (None)
    # --------------------------------------------------
    data_coords = []
    direction_up = True
    current_col = 24

    while current_col >= 0:
        col_pair = [current_col]
        if current_col - 1 >= 0:
            col_pair.append(current_col - 1)

        if direction_up:
        else:

        for rr in row_range:
            for cc in col_pair:
                if get_module_color(rr, cc) is None:
                    data_coords.append((rr, cc))

        current_col -= 2
        direction_up = not direction_up

    # --------------------------------------------------
    # (C) Output data_coords as plain list style
    # --------------------------------------------------
    print("ARROW_PATH = [")
    for (r, c) in data_coords:
        print(f"    ({r}, {c}),")
    print("]")

if __name__ == '__main__':
    main()
