2022-05-17 00:48:22 +01:00
|
|
|
init python:
|
|
|
|
whitespace_dict = {}
|
2022-09-21 19:22:14 +01:00
|
|
|
with renpy.open_file("images.whitespace") as fp:
|
2022-05-17 00:48:22 +01:00
|
|
|
line = fp.readline()
|
|
|
|
while line:
|
|
|
|
path, area = line.strip("\r\n").split(':')
|
2022-09-21 21:57:04 +01:00
|
|
|
whitespace_dict[path] = list(map(int, area.split(',')))
|
2022-05-17 00:48:22 +01:00
|
|
|
line = fp.readline()
|
|
|
|
|
|
|
|
def crop_whitespace(path):
|
|
|
|
# Return box from whitespace_dict, or calculate and store it
|
2023-06-08 17:41:06 +01:00
|
|
|
|
|
|
|
def _find_file_surface(obj):
|
|
|
|
if isinstance(obj, str):
|
|
|
|
return obj, Image(obj).load()
|
|
|
|
elif isinstance(obj, im.Image):
|
|
|
|
return obj.filename, obj.load()
|
|
|
|
elif isinstance(obj, Transform):
|
|
|
|
return _find_file_surface(obj.child)
|
|
|
|
|
2022-05-17 00:48:22 +01:00
|
|
|
if path in whitespace_dict:
|
|
|
|
box = whitespace_dict[path]
|
|
|
|
else:
|
2023-06-08 17:41:06 +01:00
|
|
|
path, surf = _find_file_surface(path)
|
|
|
|
size = surf.get_size()
|
2022-05-17 00:48:22 +01:00
|
|
|
box = tuple(surf.get_bounding_rect())
|
2023-06-08 17:41:06 +01:00
|
|
|
|
|
|
|
if size[0] != 1010:
|
|
|
|
ratio = size[0] / 1010
|
|
|
|
box = tuple(v/ratio for v in box)
|
2022-05-17 00:48:22 +01:00
|
|
|
whitespace_dict[path] = box
|
|
|
|
return box
|
|
|
|
|
|
|
|
def crop_image_zoom(path, xsize, ysize, grayscale=False):
|
|
|
|
x, y, w, h = crop_whitespace(path)
|
|
|
|
matrix = SaturationMatrix(0) if grayscale else None
|
|
|
|
sprite = Image(path)
|
|
|
|
|
|
|
|
return Transform(sprite, crop=(x, y, w, h), xsize=xsize, ysize=ysize, fit="contain", matrixcolor=matrix, subpixel=True)
|
|
|
|
|
|
|
|
def get_zoom(image, size):
|
2022-09-21 21:57:04 +01:00
|
|
|
if isinstance(image, str):
|
2022-05-17 00:48:22 +01:00
|
|
|
image = Image(image)
|
|
|
|
|
|
|
|
r = renpy.render(image, 800, 800, 0, 0)
|
|
|
|
x, y = r.get_size()
|
|
|
|
xsize, ysize = size
|
|
|
|
|
|
|
|
return min(ysize / y, xsize / x)
|