X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka_Displayio.git/blobdiff_plain/d927861dbab8524c9655679459c32229a87f67dd..42ec38854ce93ad1e7c1de6e20e12f044b7b47b7:/displayio/display.py diff --git a/displayio/display.py b/displayio/display.py index 904302b..4db7fd1 100644 --- a/displayio/display.py +++ b/displayio/display.py @@ -135,7 +135,7 @@ class Display: self._height = height self._colstart = colstart self._rowstart = rowstart - self._rotation = rotation + self._rotation = 0 self._auto_brightness = auto_brightness self._brightness = brightness self._auto_refresh = auto_refresh @@ -144,6 +144,7 @@ class Display: self._subrectangles = [] self._bounds_encoding = ">BB" if single_byte_bounds else ">HH" self._current_group = None + self.rotation = rotation displays.append(self) self._refresh_thread = None if self._auto_refresh: @@ -217,7 +218,14 @@ class Display: def _refresh_display_area(self, rectangle): """Loop through dirty rectangles and redraw that area.""" - data = numpy.array(self._buffer.crop(rectangle).convert("RGB")).astype("uint16") + + img = self._buffer.convert("RGB").crop(rectangle) + img = img.rotate(self._rotation, expand=True) + + display_rectangle = self._apply_rotation(rectangle) + img = img.crop(self._clip(display_rectangle)) + + data = numpy.array(img).astype("uint16") color = ( ((data[:, :, 0] & 0xF8) << 8) | ((data[:, :, 1] & 0xFC) << 3) @@ -231,17 +239,62 @@ class Display: self._write( self._set_column_command, self._encode_pos( - rectangle.x1 + self._colstart, rectangle.x2 + self._colstart - 1 + display_rectangle.x1 + self._colstart, + display_rectangle.x2 + self._colstart - 1, ), ) self._write( self._set_row_command, self._encode_pos( - rectangle.y1 + self._rowstart, rectangle.y2 + self._rowstart - 1 + display_rectangle.y1 + self._rowstart, + display_rectangle.y2 + self._rowstart - 1, ), ) + self._write(self._write_ram_command, pixels) + def _clip(self, rectangle): + if self._rotation in (90, 270): + width, height = self._height, self._width + else: + width, height = self._width, self._height + + if rectangle.x1 < 0: + rectangle.x1 = 0 + if rectangle.y1 < 0: + rectangle.y1 = 0 + if rectangle.x2 > width: + rectangle.x2 = width + if rectangle.y2 > height: + rectangle.y2 = height + + return rectangle + + def _apply_rotation(self, rectangle): + """Adjust the rectangle coordinates based on rotation""" + if self._rotation == 90: + return Rectangle( + self._height - rectangle.y2, + rectangle.x1, + self._height - rectangle.y1, + rectangle.x2, + ) + if self._rotation == 180: + return Rectangle( + self._width - rectangle.x2, + self._height - rectangle.y2, + self._width - rectangle.x1, + self._height - rectangle.y1, + ) + if self._rotation == 270: + return Rectangle( + rectangle.y1, + self._width - rectangle.x2, + rectangle.y2, + self._width - rectangle.x1, + ) + return rectangle + def _encode_pos(self, x, y): """Encode a postion into bytes.""" return struct.pack(self._bounds_encoding, x, y)