diff options
Diffstat (limited to 'src/sliceitoff/display')
-rw-r--r-- | src/sliceitoff/display/__init__.py | 7 | ||||
-rw-r--r-- | src/sliceitoff/display/display.py | 19 | ||||
-rw-r--r-- | src/sliceitoff/display/scaling.py | 36 | ||||
-rw-r--r-- | src/sliceitoff/display/static.py | 9 |
4 files changed, 40 insertions, 31 deletions
diff --git a/src/sliceitoff/display/__init__.py b/src/sliceitoff/display/__init__.py index 296f519..25b6f18 100644 --- a/src/sliceitoff/display/__init__.py +++ b/src/sliceitoff/display/__init__.py @@ -1,8 +1,5 @@ +from .scaling import Scaling from .display import Display -from .static import ( - Scaling, - INTERNAL_WIDTH, - INTERNAL_HEIGHT, - INTERNAL_ASPECT) +from .static import INTERNAL_WIDTH, INTERNAL_HEIGHT diff --git a/src/sliceitoff/display/display.py b/src/sliceitoff/display/display.py index af61d49..ae98134 100644 --- a/src/sliceitoff/display/display.py +++ b/src/sliceitoff/display/display.py @@ -1,10 +1,6 @@ import pygame -from .static import ( - Scaling, - INTERNAL_WIDTH, - INTERNAL_HEIGHT, - INTERNAL_ASPECT) +from .scaling import Scaling class Display(): def __init__(self): @@ -13,18 +9,7 @@ class Display(): self.screen = pygame.display.set_mode( (mode_info.current_w, mode_info.current_h), pygame.FULLSCREEN | pygame.SCALED ) - - def get_scaling(self): - w, h = self.screen.get_size() - if w/h <= INTERNAL_ASPECT: - scale = w / INTERNAL_WIDTH - left = 0 - top = int((h - INTERNAL_HEIGHT * scale) / 2) - else : - scale = h / INTERNAL_HEIGHT - left = int((w - INTERNAL_WIDTH * scale) / 2) - top = 0 - return Scaling(scale, left, top) + Scaling.update_scaling(self.screen.get_size()) def update(self, groups = None): """ Updates the screen: clear, blit gropus and flip """ diff --git a/src/sliceitoff/display/scaling.py b/src/sliceitoff/display/scaling.py new file mode 100644 index 0000000..6be00da --- /dev/null +++ b/src/sliceitoff/display/scaling.py @@ -0,0 +1,36 @@ +import pygame + +from .static import INTERNAL_WIDTH, INTERNAL_HEIGHT + +class Scaling(): + factor = 0.02 + left = 0 + top = 0 + + @staticmethod + def area_to_rect(area: tuple) -> pygame.Rect: + """ converts area coordinates to pygame.Rect""" + return pygame.Rect( + area[0] * __class__.factor + __class__.left, + area[1] * __class__.factor + __class__.top, + area[2] * __class__.factor, + area[3] * __class__.factor) + + @staticmethod + def scale_coordinates(coords: tuple ) -> tuple: + return ( + coords[0] * __class__.factor + __class__.left, + coords[1] * __class__.factor + __class__.top) + + @staticmethod + def update_scaling(size: tuple) -> None: + if size[0] / size[1] <= INTERNAL_WIDTH / INTERNAL_HEIGHT: + __class__.factor = size[0] / INTERNAL_WIDTH + __class__.left = 0 + __class__.top = (size[1] - INTERNAL_HEIGHT * __class__.factor) // 2 + else: + __class__.factor = size[1] / INTERNAL_HEIGHT + __class__.left = (size[0] - INTERNAL_WIDTH * __class__.factor) // 2 + __class__.top = 0 + +
\ No newline at end of file diff --git a/src/sliceitoff/display/static.py b/src/sliceitoff/display/static.py index 43dc385..6e5d0dc 100644 --- a/src/sliceitoff/display/static.py +++ b/src/sliceitoff/display/static.py @@ -1,11 +1,2 @@ -from dataclasses import dataclass - INTERNAL_WIDTH = 40000 INTERNAL_HEIGHT = 30000 -INTERNAL_ASPECT = INTERNAL_WIDTH / INTERNAL_HEIGHT - -@dataclass -class Scaling(): - scale: float - left: int - top: int |