from PIL import Image def get_image(image_path, row, col, image_size=1024, grid_width=1): left_point = (image_size + grid_width) * col up_point = (image_size + grid_width) * row right_point = left_point + image_size down_point = up_point + image_size if type(image_path) is str: image = Image.open(image_path) else: image = image_path croped_image = image.crop((left_point, up_point, right_point, down_point)) return croped_image def get_image_v2(image_path, row, col, image_size=1024, grid_row_space=1, grid_col_space=1): left_point = (image_size + grid_col_space) * col up_point = (image_size + grid_row_space) * row right_point = left_point + image_size down_point = up_point + image_size if type(image_path) is str: image = Image.open(image_path) else: image = image_path croped_image = image.crop((left_point, up_point, right_point, down_point)) return croped_image def create_image(row, col, image_size=1024, grid_width=1, background_color=(255,255,255), top_padding = 0, bottom_padding = 0, left_padding = 0, right_padding = 0): image = Image.new('RGB', (image_size * col + grid_width * (col - 1) + left_padding , image_size * row + grid_width * (row - 1)), background_color) return image def paste_image(grid, image, row, col, image_size=1024, grid_width=1, top_padding = 0, bottom_padding = 0, left_padding = 0, right_padding = 0): left_point = (image_size + grid_width) * col + left_padding up_point = (image_size + grid_width) * row + top_padding right_point = left_point + image_size down_point = up_point + image_size grid.paste(image, (left_point, up_point, right_point, down_point)) return grid def paste_image_v2(grid, image, row, col, grid_size=1024, grid_width=1, top_padding = 0, bottom_padding = 0, left_padding = 0, right_padding = 0): left_point = (grid_size + grid_width) * col + left_padding up_point = (grid_size + grid_width) * row + top_padding image_width, image_height = image.size right_point = left_point + image_width down_point = up_point + image_height grid.paste(image, (left_point, up_point, right_point, down_point)) return grid def pivot_figure(file_path, image_size=1024, grid_width=1): if type(file_path) is str: image = Image.open(file_path) else: image = file_path image_col = image.width // image_size image_row = image.height // image_size grid = create_image(image_col, image_row, image_size, grid_width) for row in range(image_row): for col in range(image_col): croped_image = get_image(image, row, col, image_size, grid_width) grid = paste_image(grid, croped_image, col, row, image_size, grid_width) return grid def horizontal_flip_figure(file_path, image_size=1024, grid_width=1): if type(file_path) is str: image = Image.open(file_path) else: image = file_path image_col = image.width // image_size image_row = image.height // image_size grid = create_image(image_row, image_col, image_size, grid_width) for row in range(image_row): for col in range(image_col): croped_image = get_image(image, row, image_col - col - 1, image_size, grid_width) grid = paste_image(grid, croped_image, row, col, image_size, grid_width) return grid def vertical_flip_figure(file_path, image_size=1024, grid_width=1): if type(file_path) is str: image = Image.open(file_path) else: image = file_path image_col = image.width // image_size image_row = image.height // image_size grid = create_image(image_row, image_col, image_size, grid_width) for row in range(image_row): for col in range(image_col): croped_image = get_image(image, image_row - row - 1, col, image_size, grid_width) grid = paste_image(grid, croped_image, row, col, image_size, grid_width) return grid