rgbmatrix: Eliminate some duplicated height-calculating code

This was hard to write, so let's have it written in 2 places instead
of 4.
This commit is contained in:
Jeff Epler 2021-01-26 14:35:26 -06:00
parent 368977fb90
commit 20c9f25a65
2 changed files with 3 additions and 3 deletions

View File

@ -219,8 +219,8 @@ STATIC mp_obj_t rgbmatrix_rgbmatrix_make_new(const mp_obj_type_t *type, size_t n
translate("tile must be greater than or equal to zero")); translate("tile must be greater than or equal to zero"));
} }
if (args[ARG_height].u_int != 0) {
int computed_height = (rgb_count / 3) * (1 << (addr_count)) * tile; int computed_height = (rgb_count / 3) * (1 << (addr_count)) * tile;
if (args[ARG_height].u_int != 0) {
if (computed_height != args[ARG_height].u_int) { if (computed_height != args[ARG_height].u_int) {
mp_raise_ValueError_varg( mp_raise_ValueError_varg(
translate("%d address pins, %d rgb pins and %d tiles indicate a height of %d, not %d"), addr_count, rgb_count, tile, computed_height, args[ARG_height].u_int); translate("%d address pins, %d rgb pins and %d tiles indicate a height of %d, not %d"), addr_count, rgb_count, tile, computed_height, args[ARG_height].u_int);
@ -236,7 +236,7 @@ STATIC mp_obj_t rgbmatrix_rgbmatrix_make_new(const mp_obj_type_t *type, size_t n
mp_obj_t framebuffer = args[ARG_framebuffer].u_obj; mp_obj_t framebuffer = args[ARG_framebuffer].u_obj;
if (framebuffer == mp_const_none) { if (framebuffer == mp_const_none) {
int width = args[ARG_width].u_int; int width = args[ARG_width].u_int;
int bufsize = 2 * width * rgb_count / 3 * (1 << addr_count) * tile; int bufsize = 2 * width * computed_height;
framebuffer = mp_obj_new_bytearray_of_zeros(bufsize); framebuffer = mp_obj_new_bytearray_of_zeros(bufsize);
} }

View File

@ -62,7 +62,7 @@ void common_hal_rgbmatrix_rgbmatrix_construct(rgbmatrix_rgbmatrix_obj_t *self, i
} }
self->width = width; self->width = width;
self->bufsize = 2 * width * rgb_count / 3 * (1 << addr_count) * tile; self->bufsize = 2 * width * common_hal_rgbmatrix_rgbmatrix_get_height(self);
common_hal_rgbmatrix_rgbmatrix_reconstruct(self, framebuffer); common_hal_rgbmatrix_rgbmatrix_reconstruct(self, framebuffer);
} }