allow tuple or list for Palette color
This commit is contained in:
parent
67440acd3e
commit
a4ebd2f7c1
@ -10,6 +10,9 @@ INTERNAL_FLASH_FILESYSTEM = 1
|
||||
LONGINT_IMPL = NONE
|
||||
|
||||
CIRCUITPY_SMALL_BUILD = 1
|
||||
# TODO: Turn off analogio for now for space reasons, but restore it
|
||||
# when frozen module gets smaller.
|
||||
CIRCUITPY_ANALOGIO = 0
|
||||
CIRCUITPY_AUDIOBUSIO = 0
|
||||
CIRCUITPY_BITBANGIO = 0
|
||||
CIRCUITPY_FREQUENCYIO = 0
|
||||
|
@ -86,7 +86,8 @@ STATIC mp_obj_t group_unary_op(mp_unary_op_t op, mp_obj_t self_in) {
|
||||
//| Sets the pixel color at the given index. The index should be an integer in the range 0 to color_count-1.
|
||||
//|
|
||||
//| The value argument represents a color, and can be from 0x000000 to 0xFFFFFF (to represent an RGB value).
|
||||
//| Value can be an int, bytes (3 bytes (RGB) or 4 bytes (RGB + pad byte)), or bytearray.
|
||||
//| Value can be an int, bytes (3 bytes (RGB) or 4 bytes (RGB + pad byte)), bytearray,
|
||||
//| or a tuple or list of 3 integers.
|
||||
//|
|
||||
//| This allows you to::
|
||||
//|
|
||||
@ -94,6 +95,7 @@ STATIC mp_obj_t group_unary_op(mp_unary_op_t op, mp_obj_t self_in) {
|
||||
//| palette[1] = b'\xff\xff\x00' # set using 3 bytes
|
||||
//| palette[2] = b'\xff\xff\x00\x00' # set using 4 bytes
|
||||
//| palette[3] = bytearray(b'\x00\x00\xFF') # set using a bytearay of 3 or 4 bytes
|
||||
//| palette[4] = (10, 20, 30) # set using a tuple of 3 integers
|
||||
//|
|
||||
STATIC mp_obj_t palette_subscr(mp_obj_t self_in, mp_obj_t index_in, mp_obj_t value) {
|
||||
if (value == MP_OBJ_NULL) {
|
||||
@ -111,6 +113,12 @@ STATIC mp_obj_t palette_subscr(mp_obj_t self_in, mp_obj_t index_in, mp_obj_t val
|
||||
return MP_OBJ_NEW_SMALL_INT(common_hal_displayio_palette_get_color(self, index));
|
||||
}
|
||||
|
||||
// Convert a tuple or list to a bytearray.
|
||||
if (MP_OBJ_IS_TYPE(value, &mp_type_tuple) ||
|
||||
MP_OBJ_IS_TYPE(value, &mp_type_list)) {
|
||||
value = mp_type_bytes.make_new(&mp_type_bytes, 1, &value, NULL);
|
||||
}
|
||||
|
||||
uint32_t color;
|
||||
mp_int_t int_value;
|
||||
mp_buffer_info_t bufinfo;
|
||||
@ -130,7 +138,7 @@ STATIC mp_obj_t palette_subscr(mp_obj_t self_in, mp_obj_t index_in, mp_obj_t val
|
||||
}
|
||||
color = int_value;
|
||||
} else {
|
||||
mp_raise_TypeError(translate("color buffer must be a buffer or int"));
|
||||
mp_raise_TypeError(translate("color buffer must be a buffer, tuple, list, or int"));
|
||||
}
|
||||
common_hal_displayio_palette_set_color(self, index, color);
|
||||
return mp_const_none;
|
||||
|
Loading…
x
Reference in New Issue
Block a user