]> Repositories - hackapet/Adafruit_Blinka_Displayio.git/blobdiff - displayio/display.py
Removed unused transform
[hackapet/Adafruit_Blinka_Displayio.git] / displayio / display.py
index e5998e1c8a6e3361280a2fb7b40e6aa166b91dbd..4db7fd188ad31cd6c4a31a6e8d8092b6342863c7 100644 (file)
@@ -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:
@@ -218,8 +219,11 @@ class Display:
     def _refresh_display_area(self, rectangle):
         """Loop through dirty rectangles and redraw that area."""
 
-        img = self._buffer.crop(rectangle).convert("RGB")
-        img = img.rotate(self._rotation)
+        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 = (
@@ -232,8 +236,6 @@ class Display:
             numpy.dstack(((color >> 8) & 0xFF, color & 0xFF)).flatten().tolist()
         )
 
-        display_rectangle = self._apply_rotation(rectangle)
-
         self._write(
             self._set_column_command,
             self._encode_pos(
@@ -251,13 +253,30 @@ class Display:
 
         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._width - rectangle.y2,
+                self._height - rectangle.y2,
                 rectangle.x1,
-                self._width - rectangle.y1,
+                self._height - rectangle.y1,
                 rectangle.x2,
             )
         if self._rotation == 180:
@@ -270,9 +289,9 @@ class Display:
         if self._rotation == 270:
             return Rectangle(
                 rectangle.y1,
-                self._height - rectangle.x2,
+                self._width - rectangle.x2,
                 rectangle.y2,
-                self._height - rectangle.x1,
+                self._width - rectangle.x1,
             )
         return rectangle