Skip to content

Commit 227ac67

Browse files
committed
Add reverse_rows option to bitmaptools.readinto
1 parent 542fb58 commit 227ac67

File tree

3 files changed

+9
-6
lines changed

3 files changed

+9
-6
lines changed

shared-bindings/bitmaptools/__init__.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -456,14 +456,15 @@ MP_DEFINE_CONST_FUN_OBJ_KW(bitmaptools_arrayblit_obj, 0, bitmaptools_arrayblit);
456456
//|
457457

458458
STATIC mp_obj_t bitmaptools_readinto(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
459-
enum { ARG_bitmap, ARG_file, ARG_bits_per_pixel, ARG_element_size, ARG_reverse_pixels_in_element, ARG_swap_bytes_in_element };
459+
enum { ARG_bitmap, ARG_file, ARG_bits_per_pixel, ARG_element_size, ARG_reverse_pixels_in_element, ARG_swap_bytes_in_element, ARG_reverse_rows };
460460
static const mp_arg_t allowed_args[] = {
461461
{ MP_QSTR_bitmap, MP_ARG_REQUIRED | MP_ARG_OBJ },
462462
{ MP_QSTR_file, MP_ARG_REQUIRED | MP_ARG_OBJ },
463463
{ MP_QSTR_bits_per_pixel, MP_ARG_REQUIRED | MP_ARG_INT },
464464
{ MP_QSTR_element_size, MP_ARG_INT, { .u_int = 1 } },
465465
{ MP_QSTR_reverse_pixels_in_element, MP_ARG_BOOL, { .u_bool = false } },
466466
{ MP_QSTR_swap_bytes_in_element, MP_ARG_BOOL, { .u_bool = false } },
467+
{ MP_QSTR_reverse_rows, MP_ARG_BOOL, { .u_bool = false } },
467468
};
468469

469470
mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
@@ -504,8 +505,9 @@ STATIC mp_obj_t bitmaptools_readinto(size_t n_args, const mp_obj_t *pos_args, mp
504505

505506
bool reverse_pixels_in_element = args[ARG_reverse_pixels_in_element].u_bool;
506507
bool swap_bytes_in_element = args[ARG_swap_bytes_in_element].u_bool;
508+
bool reverse_rows = args[ARG_reverse_rows].u_bool;
507509

508-
common_hal_bitmaptools_readinto(bitmap, file, element_size, bits_per_pixel, reverse_pixels_in_element, swap_bytes_in_element);
510+
common_hal_bitmaptools_readinto(bitmap, file, element_size, bits_per_pixel, reverse_pixels_in_element, swap_bytes_in_element, reverse_rows);
509511

510512
return mp_const_none;
511513
}

shared-bindings/bitmaptools/__init__.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -51,7 +51,7 @@ void common_hal_bitmaptools_draw_line(displayio_bitmap_t *destination,
5151
int16_t x1, int16_t y1,
5252
uint32_t value);
5353

54-
void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* file, int element_size, int bits_per_pixel, bool reverse_pixels_in_word, bool swap_bytes);
54+
void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* file, int element_size, int bits_per_pixel, bool reverse_pixels_in_word, bool swap_bytes, bool reverse_rows);
5555
void common_hal_bitmaptools_arrayblit(displayio_bitmap_t *self, void *data, int element_size, int x1, int y1, int x2, int y2, bool skip_specified, uint32_t skip_index);
5656

5757
#endif // MICROPY_INCLUDED_SHARED_BINDINGS_BITMAPTOOLS__INIT__H

shared-module/bitmaptools/__init__.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -367,7 +367,7 @@ void common_hal_bitmaptools_arrayblit(displayio_bitmap_t *self, void *data, int
367367
}
368368
}
369369

370-
void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* file, int element_size, int bits_per_pixel, bool reverse_pixels_in_element, bool swap_bytes) {
370+
void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* file, int element_size, int bits_per_pixel, bool reverse_pixels_in_element, bool swap_bytes, bool reverse_rows) {
371371
uint32_t mask = (1 << common_hal_displayio_bitmap_get_bits_per_value(self)) - 1;
372372

373373
if (self->read_only) {
@@ -378,10 +378,12 @@ void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* f
378378
size_t rowsize = element_size * elements_per_row;
379379
size_t rowsize_in_u32 = (rowsize + sizeof(uint32_t) - 1) / sizeof(uint32_t);
380380
size_t rowsize_in_u16 = (rowsize + sizeof(uint16_t) - 1) / sizeof(uint16_t);
381+
381382
for(int y=0; y<self->height; y++) {
382383
uint32_t rowdata32[rowsize_in_u32];
383384
uint16_t *rowdata16 = (uint16_t*)rowdata32;
384385
uint8_t *rowdata8 = (uint8_t*)rowdata32;
386+
const int y_draw = reverse_rows ? (self->height) - 1 - y : y;
385387

386388
UINT bytes_read = 0;
387389
if (f_read(&file->fp, rowdata32, rowsize, &bytes_read) != FR_OK || bytes_read != rowsize) {
@@ -447,8 +449,7 @@ void common_hal_bitmaptools_readinto(displayio_bitmap_t *self, pyb_file_obj_t* f
447449
value = rowdata32[x];
448450
break;
449451
}
450-
451-
displayio_bitmap_write_pixel(self, x, y, value & mask);
452+
displayio_bitmap_write_pixel(self, x, y_draw, value & mask);
452453
}
453454
}
454455

0 commit comments

Comments
 (0)