X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka_Displayio.git/blobdiff_plain/bcb0b57a0f94e7b83178a81c8a81ebe7f9921d80..33accffa7278997a55e237473c33880813def934:/displayio/_structs.py diff --git a/displayio/_structs.py b/displayio/_structs.py index 1e76121..3f0c2e1 100644 --- a/displayio/_structs.py +++ b/displayio/_structs.py @@ -19,20 +19,10 @@ Struct Data Classes for Blinka Displayio from dataclasses import dataclass -__version__ = "0.0.0-auto.0" +__version__ = "0.0.0+auto.0" __repo__ = "https://github.com/adafruit/Adafruit_Blinka_Displayio.git" -@dataclass -class RectangleStruct: - # pylint: disable=invalid-name - """Rectangle Struct Dataclass. To eventually be replaced by Area.""" - x1: int - y1: int - x2: int - y2: int - - @dataclass class TransformStruct: # pylint: disable=invalid-name @@ -49,7 +39,7 @@ class TransformStruct: @dataclass class ColorspaceStruct: - # pylint: disable=invalid-name + # pylint: disable=invalid-name, too-many-instance-attributes """Colorspace Struct Dataclass""" depth: int bytes_per_cell: int = 0 @@ -58,7 +48,49 @@ class ColorspaceStruct: grayscale_bit: int = 0 grayscale: bool = False tricolor: bool = False + sevencolor: bool = False # Acep e-ink screens. pixels_in_byte_share_row: bool = False reverse_pixels_in_byte: bool = False reverse_bytes_in_word: bool = False dither: bool = False + + +@dataclass +class InputPixelStruct: + """InputPixel Struct Dataclass""" + + pixel: int = 0 + x: int = 0 + y: int = 0 + tile: int = 0 + tile_x: int = 0 + tile_y: int = 0 + + +@dataclass +class OutputPixelStruct: + """OutputPixel Struct Dataclass""" + + pixel: int = 0 + opaque: bool = False + + +@dataclass +class ColorStruct: + """Color Struct Dataclass""" + + rgb888: int = 0 + cached_colorspace: ColorspaceStruct = None + cached_color: int = 0 + cached_colorspace_grayscale_bit: int = 0 + cached_colorspace_grayscale: bool = False + transparent: bool = False + + def rgba(self) -> tuple[int, int, int, int]: + """Return the color as a tuple of red, green, blue, alpha""" + return ( + self.rgb888 >> 16, + (self.rgb888 >> 8) & 0xFF, + self.rgb888 & 0xFF, + 0 if self.transparent else 0xFF, + )