from shapely import Polygon
import shapely

import numpy as np

from molecule_movement.sampling import Sampler
from .structures import *
from .corridor import compute_corridor
from .characters import *
from .quantum_corral import *
from .hexagon import *
from .lines import *
from .helpers import get_multipolygon_coords, remove_closing_point, interpolate_line

def resize(polygon: Polygon, x: float, y: float) -> Polygon:
    return shapely.affinity.scale(polygon, x, y, origin=(0,0))

ATOM = Point(0,0).buffer(0.3)

CIRCLE = Point(1,1).buffer(1.0)
RECTANGLE = Polygon([(0,0), (0,1), (1,1), (1,0)])
TRIANGLE = Polygon([(0,0), (1,0), (0.5,1)])
DDNB = Polygon([(1.5,0.0),
                (1.2,0.05),
                (0.9,0.2),
                (0.6,0.3),
                (0.3,0.5),
                (0.0,0.9),
                (0.1,1.2),
                (0.3,1.4),
                (0.6,1.5),
                (0.9,1.55),
                (1.2,1.6),
                (1.5,1.55),
                (1.8,1.6),
                (2.1,1.5),
                (2.4,1.5),
                (2.7,1.4),
                (2.9,1.2),
                (3.0,0.9),
                (2.7,0.5),
                (2.4,0.3),
                (2.1,0.2),
                (1.8,0.05)
               ])

FePc = Polygon([(2.20, 1.10),
                (2.10, 0.90),
                (1.91, 0.80),
                (1.70, 0.75),
                (1.48, 0.71),
                (1.44, 0.49),
                (1.39, 0.28),
                (1.29, 0.09),
                (1.09, 0.00),
                (0.90, 0.09),
                (0.80, 0.28),
                (0.75, 0.49),
                (0.71, 0.71),
                (0.49, 0.75),
                (0.28, 0.80),
                (0.09, 0.90),
                (0.00, 1.09),
                (0.09, 1.29),
                (0.28, 1.39),
                (0.49, 1.44),
                (0.71, 1.48),
                (0.75, 1.70),
                (0.80, 1.91),
                (0.90, 2.10),
                (1.09, 2.20),
                (1.29, 2.10),
                (1.39, 1.91),
                (1.44, 1.70),
                (1.48, 1.48),
                (1.70, 1.44),
                (1.91, 1.39),
                (2.10, 1.29),
                (2.20, 1.10)])

def random_convex_polygon(min: int = 1, max: int = 6, seed: Optional[int] = None):
    sampler = Sampler(lambda _: 1, lambda _: 1, width=1, height=1, seed=seed)
    points = list()
    for _ in range(15):
        points.append(sampler.sample_position([]))
    shape = 2.
    scaling = np.random.default_rng(seed).standard_gamma(shape, 2)
    x_scale, y_scale = np.where(scaling < min, min, np.where(scaling > max, max, scaling))
    return resize(shapely.Polygon(points).convex_hull, x_scale, y_scale)
