From 61e44f2f314d03859bd53488377bbe7ac83540f7 Mon Sep 17 00:00:00 2001 From: Daniel Drown Date: Mon, 9 Dec 2024 16:22:15 -0600 Subject: [PATCH] add support for 24 bit color depth --- shared-module/displayio/ColorConverter.c | 2 +- shared-module/displayio/TileGrid.c | 6 ++++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/shared-module/displayio/ColorConverter.c b/shared-module/displayio/ColorConverter.c index 512d45108ebe..fe8307604211 100644 --- a/shared-module/displayio/ColorConverter.c +++ b/shared-module/displayio/ColorConverter.c @@ -292,7 +292,7 @@ void displayio_convert_color(const _displayio_colorspace_t *colorspace, bool dit output_color->pixel = (luma >> colorspace->grayscale_bit) & bitmask; output_color->opaque = true; return; - } else if (colorspace->depth == 32) { + } else if (colorspace->depth == 32 || colorspace->depth == 24) { output_color->pixel = pixel; output_color->opaque = true; return; diff --git a/shared-module/displayio/TileGrid.c b/shared-module/displayio/TileGrid.c index 137dc02250e0..926637c11fbd 100644 --- a/shared-module/displayio/TileGrid.c +++ b/shared-module/displayio/TileGrid.c @@ -448,8 +448,6 @@ bool displayio_tilegrid_fill_area(displayio_tilegrid_t *self, y_shift = temp_shift; } - uint8_t pixels_per_byte = 8 / colorspace->depth; - displayio_input_pixel_t input_pixel; displayio_output_pixel_t output_pixel; @@ -503,9 +501,13 @@ bool displayio_tilegrid_fill_area(displayio_tilegrid_t *self, *(((uint16_t *)buffer) + offset) = output_pixel.pixel; } else if (colorspace->depth == 32) { *(((uint32_t *)buffer) + offset) = output_pixel.pixel; + } else if (colorspace->depth == 24) { + memcpy(((uint8_t *)buffer) + offset * 3, &output_pixel.pixel, 3); } else if (colorspace->depth == 8) { *(((uint8_t *)buffer) + offset) = output_pixel.pixel; } else if (colorspace->depth < 8) { + uint8_t pixels_per_byte = 8 / colorspace->depth; + // Reorder the offsets to pack multiple rows into a byte (meaning they share a column). if (!colorspace->pixels_in_byte_share_row) { uint16_t width = displayio_area_width(area);