X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka_Displayio.git/blobdiff_plain/28d05688b18970a511437eb433b8d2e2fc3c6e1e..570bcc81be0a1659816c3412f32a47b36d217243:/displayio/display.py diff --git a/displayio/display.py b/displayio/display.py index c5a82a3..b9f86dc 100644 --- a/displayio/display.py +++ b/displayio/display.py @@ -169,6 +169,7 @@ class Display: data_size = init_sequence[i + 1] delay = (data_size & 0x80) > 0 data_size &= ~0x80 + self._write(command, init_sequence[i + 2 : i + 2 + data_size]) delay_time_ms = 10 if delay: @@ -180,11 +181,15 @@ class Display: i += 2 + data_size def _write(self, command, data): - if self._single_byte_bounds: - self._bus.send(True, bytes([command]) + data, toggle_every_byte=True) + self._bus.begin_transaction() + if self._data_as_commands: + if command is not None: + self._bus.send(True, bytes([command]), toggle_every_byte=True) + self._bus.send(command is not None, data) else: self._bus.send(True, bytes([command]), toggle_every_byte=True) self._bus.send(False, data) + self._bus.end_transaction() def _release(self): self._bus.release() @@ -208,6 +213,8 @@ class Display: When auto refresh is on, updates the display immediately. (The display will also update without calls to this.) """ + self._subrectangles = [] + # Go through groups and and add each to buffer if self._current_group is not None: buffer = Image.new("RGBA", (self._width, self._height)) @@ -216,8 +223,9 @@ class Display: # save image to buffer (or probably refresh buffer so we can compare) self._buffer.paste(buffer) - # Eventually calculate dirty rectangles here - self._subrectangles.append(Rectangle(0, 0, self._width, self._height)) + if self._current_group is not None: + # Eventually calculate dirty rectangles here + self._subrectangles.append(Rectangle(0, 0, self._width, self._height)) for area in self._subrectangles: self._refresh_display_area(area) @@ -261,7 +269,10 @@ class Display: ), ) - self._write(self._write_ram_command, pixels) + if self._data_as_commands: + self._write(None, pixels) + else: + self._write(self._write_ram_command, pixels) def _clip(self, rectangle): if self._rotation in (90, 270): @@ -342,13 +353,12 @@ class Display: @brightness.setter def brightness(self, value): - print("Brightness set") if 0 <= float(value) <= 1.0: self._brightness = value if self._backlight_type == BACKLIGHT_IN_OUT: - self._backlight.value = int(round(self._brightness)) - print(int(round(self._brightness))) + self._backlight.value = round(self._brightness) # PWM not currently implemented + # Command-based brightness not implemented else: raise ValueError("Brightness must be between 0.0 and 1.0")