From 89bf2bf2197e44f0745bcae1400227c2999573cd Mon Sep 17 00:00:00 2001 From: Viljami Ilola <+@hix.fi> Date: Mon, 18 Mar 2024 16:27:51 +0200 Subject: fonts from fnt-file --- src/sliceitoff/images/__init__.py | 1 + src/sliceitoff/images/fonts.py | 42 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 43 insertions(+) create mode 100644 src/sliceitoff/images/fonts.py (limited to 'src/sliceitoff/images') diff --git a/src/sliceitoff/images/__init__.py b/src/sliceitoff/images/__init__.py index d87dfa0..c11d718 100644 --- a/src/sliceitoff/images/__init__.py +++ b/src/sliceitoff/images/__init__.py @@ -1 +1,2 @@ from .images import Images +from .fonts import Fonts, Font diff --git a/src/sliceitoff/images/fonts.py b/src/sliceitoff/images/fonts.py new file mode 100644 index 0000000..d3d15cf --- /dev/null +++ b/src/sliceitoff/images/fonts.py @@ -0,0 +1,42 @@ +import os +import pygame + +from display import Scaling + +DEBUG = os.getenv("DEBUG") + +class Fonts: + fonts = {} + + @staticmethod + def load_fonts(base_path): + filename_fontlist = os.path.join(base_path, "assets", "fonts.lst") + with open( filename_fontlist ) as fontlist_file: + for line in fontlist_file: + name, *path = line.strip().split() + filename = os.path.join(base_path, *path) + font = Font(filename) + __class__.fonts[name] = Font(filename) + return True + + +class Font: + def __init__(self, filename, height = 16): + if DEBUG: + print(f"Loading font {filename = }") + self.surfaces = [] + with open(filename, mode="rb") as fnt_file: + for _ in range(256): + surface = pygame.Surface((8,height), pygame.SRCALPHA) + for line in range(16): + byte = fnt_file.read(1)[0] + if line >= height: + continue + for bit in range(8): + if byte & 0x80: + surface.set_at((bit,line),"white") + byte <<= 1 + self.surfaces.append(surface) + + def get(self, ch): + return self.surfaces[ch.encode('cp437')[0]%256] -- cgit v1.2.3