From 10ba70d54541b0f5bbf16ee2736d659e7b5e40c7 Mon Sep 17 00:00:00 2001 From: EKNr1 Date: Wed, 18 Dec 2024 17:33:16 +0100 Subject: [PATCH] Added simple "page system". --- .../pygame_tools/pgui/page_system/__init__.py | 8 +++ .../pygame_tools/pgui/page_system/page.py | 49 ++++++++++++++++ .../pgui/page_system/page_manager.py | 56 +++++++++++++++++++ 3 files changed, 113 insertions(+) create mode 100644 wobbl_tools/pygame_tools/pgui/page_system/__init__.py create mode 100644 wobbl_tools/pygame_tools/pgui/page_system/page.py create mode 100644 wobbl_tools/pygame_tools/pgui/page_system/page_manager.py diff --git a/wobbl_tools/pygame_tools/pgui/page_system/__init__.py b/wobbl_tools/pygame_tools/pgui/page_system/__init__.py new file mode 100644 index 0000000..3a8d7dc --- /dev/null +++ b/wobbl_tools/pygame_tools/pgui/page_system/__init__.py @@ -0,0 +1,8 @@ +#!/usr/bin/python3 + +""" +Simple module to create "pages". Pages can be used like web browser tabs. +""" + +from .page_manager import PageManager +from .page import Page \ No newline at end of file diff --git a/wobbl_tools/pygame_tools/pgui/page_system/page.py b/wobbl_tools/pygame_tools/pgui/page_system/page.py new file mode 100644 index 0000000..9801830 --- /dev/null +++ b/wobbl_tools/pygame_tools/pgui/page_system/page.py @@ -0,0 +1,49 @@ +#!/usr/bin/python3 + +import pygame + + +class Page: + """ + Represents a "page". Can be used similar to a browser tab. + To use this properly, you have to overwrite this class. + """ + + def __init__( + self, + app: any=None, + surface: pygame.Surface=None, + main_container: "Container"=None, + ): + """ + :param app: Can be any class. This has no builtin functionality, + but this can be useful if you want to access something in your main class from a widget or something else. + :param surface: If you dont want to directly draw a container's surface onto the screen, + you can also draw your own surface. + """ + + self.app = app + self.surface = surface + self.main_container = main_container + + def draw(self, surface: pygame.Surface) -> None: + """ + Draws the main container on the given surface. + + :param pygame.Surface surface: The surface to draw on. + """ + + if not self.surface is None: + surface.blit(self.surface, (0, 0)) + + if not self.main_container is None: + self.main_container.draw(surface) + + def update(self) -> None: + """ + Updates the main container. + """ + + if not self.main_container is None: + self.main_container.update() + diff --git a/wobbl_tools/pygame_tools/pgui/page_system/page_manager.py b/wobbl_tools/pygame_tools/pgui/page_system/page_manager.py new file mode 100644 index 0000000..26a4aac --- /dev/null +++ b/wobbl_tools/pygame_tools/pgui/page_system/page_manager.py @@ -0,0 +1,56 @@ +#!/usr/bin/python3 + +from pygame import Surface +from .page import Page + + +class PageManager: + """ + Simple class for managing "pages". A page can be used like a tab in a web browser or something else. + """ + + def __init__(self, app: any=None): + """ + :param app: Some class that gets passed to all pages so they can all access it. + This has no builtin functionality. + """ + + self.app = app + + self.DefaultPage = Page() # empty page, should be overwritten + + self.current_page = "DefaultPage" + + self.page_names = [] + + def draw(self, surface: Surface) -> None: + """ + Draws the current page onto a pygame.Surface. + + :param pygame.Surface surface: The surface to draw on. + """ + + getattr(self, self.current_page).draw(surface) + + def update(self) -> None: + """ + Updates all pages. + """ + + for page_name in self.page_names: + page = getattr(self, page_name) + page.update() + + def __iadd__(self, other: Page): + self.page_names.append(type(other).__name__) + setattr(self, type(other).__name__, other) + + return self + + def __setattr__(self, key, value): + self.__dict__[key] = value + + if key == "current_page": + getattr(self, self.current_page).visible = False # tell the page that it is not visible anymore + + getattr(self, value).visible = True # and tell the new page that it is now visible