X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka_Displayio.git/blobdiff_plain/cfee25c8ae316776ce54589eae64409ea41bc42b..ccf2ba325ec856e092637d645b4b9ae499d12f45:/displayio/_tilegrid.py diff --git a/displayio/_tilegrid.py b/displayio/_tilegrid.py index 5abfad4..9287e98 100644 --- a/displayio/_tilegrid.py +++ b/displayio/_tilegrid.py @@ -319,7 +319,7 @@ class TileGrid: ) # In Pixels # Check the mask first to see if the pixel has already been set - if mask[offset // 8] & (1 << (offset % 8)): + if mask[offset // 32] & (1 << (offset % 32)): continue local_x = input_pixel.x // self._absolute_transform.scale tile_location = ( @@ -363,24 +363,24 @@ class TileGrid: if not output_pixel.opaque: full_coverage = False else: - mask[offset // 8] |= 1 << (offset % 8) + mask[offset // 32] |= 1 << (offset % 32) # print("Mask", mask) if colorspace.depth == 16: struct.pack_into( "H", - buffer, - offset * 2, + buffer.cast("H"), + offset, output_pixel.pixel, ) elif colorspace.depth == 32: struct.pack_into( "I", buffer, - offset * 4, + offset, output_pixel.pixel, ) elif colorspace.depth == 8: - buffer[offset] = output_pixel.pixel & 0xFF + buffer.cast("B")[offset] = output_pixel.pixel & 0xFF elif colorspace.depth < 8: # Reorder the offsets to pack multiple rows into # a byte (meaning they share a column). @@ -399,7 +399,9 @@ class TileGrid: if colorspace.reverse_pixels_in_byte: # Reverse the shift by subtracting it from the leftmost shift shift = (pixels_per_byte - 1) * colorspace.depth - shift - buffer[offset // pixels_per_byte] |= output_pixel.pixel << shift + buffer.cast("B")[offset // pixels_per_byte] |= ( + output_pixel.pixel << shift + ) return full_coverage