]> Repositories - hackapet/Adafruit_Blinka_Displayio.git/commitdiff
Add fontio.FontProtocol
authorAlec Delaney <89490472+tekktrik@users.noreply.github.com>
Wed, 18 May 2022 00:29:32 +0000 (20:29 -0400)
committerGitHub <noreply@github.com>
Wed, 18 May 2022 00:29:32 +0000 (20:29 -0400)
fontio.py

index 59ff0f9364ecf71c7502c7f6051f4eb71821bf90..d6a1ee222c84221b142a24839e0f51f192495807 100644 (file)
--- a/fontio.py
+++ b/fontio.py
@@ -17,13 +17,35 @@ fontio for Blinka
 
 """
 
+from typing import Union, Tuple, Optional
 from PIL import ImageFont
 from displayio import Bitmap
+try:
+    from typing import Protocol
+except ImportError:
+    from typing_extensions import Protocol
 
 __version__ = "0.0.0-auto.0"
 __repo__ = "https://github.com/adafruit/Adafruit_Blinka_displayio.git"
 
 
+class FontProtocol(Protocol):
+"""A protocol shared by `BuiltinFont` and classes in ``adafruit_bitmap_font``"""
+
+    def get_bounding_box(self) -> Union[Tuple[int, int], Tuple[int, int, int, int]]:
+        """Retrieve the maximum bounding box of any glyph in the font.
+
+        The four element version is ``(width, height, x_offset, y_offset)``.
+        The two element version is ``(width, height)``, in which
+        ``x_offset`` and ``y_offset`` are assumed to be zero.
+        """
+
+    def get_glyph(self, codepoint: int) -> Optional["Glyph"]:
+        """Retrieve the Glyph for a given code point
+
+        If the code point is not present in the font, `None` is returned.
+        """
+
 class BuiltinFont:
     """Simulate a font built into CircuitPython"""