taki0112's picture
add code
4f4656c
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