2021-08-01 13:01:57 -07:00
|
|
|
#include "shared-bindings/vectorio/__init__.h"
|
2020-05-02 02:21:35 -07:00
|
|
|
#include "shared-bindings/vectorio/Circle.h"
|
2021-08-01 13:01:57 -07:00
|
|
|
#include "shared-bindings/vectorio/VectorShape.h"
|
2020-05-02 02:21:35 -07:00
|
|
|
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "py/objproperty.h"
|
|
|
|
#include "py/objtype.h"
|
|
|
|
#include "py/runtime.h"
|
2022-05-27 12:59:54 -07:00
|
|
|
#include "supervisor/shared/translate/translate.h"
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2020-05-12 18:40:02 -07:00
|
|
|
//| class Circle:
|
2022-09-27 15:21:42 -05:00
|
|
|
//| def __init__(
|
|
|
|
//| self,
|
|
|
|
//| pixel_shader: Union[displayio.ColorConverter, displayio.Palette],
|
|
|
|
//| radius: int,
|
|
|
|
//| x: int,
|
|
|
|
//| y: int,
|
|
|
|
//| ) -> None:
|
2020-05-12 18:40:02 -07:00
|
|
|
//| """Circle is positioned on screen by its center point.
|
2020-05-02 02:21:35 -07:00
|
|
|
//|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| :param Union[~displayio.ColorConverter,~displayio.Palette] pixel_shader: The pixel shader that produces colors from values
|
|
|
|
//| :param int radius: The radius of the circle in pixels
|
|
|
|
//| :param int x: Initial x position of the axis.
|
|
|
|
//| :param int y: Initial y position of the axis.
|
2023-02-01 13:38:41 +05:30
|
|
|
//| :param int color_index: Initial color_index to use when selecting color from the palette.
|
|
|
|
//| """
|
2021-10-15 13:43:12 -05:00
|
|
|
static mp_obj_t vectorio_circle_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args) {
|
2022-03-19 11:30:37 -05:00
|
|
|
enum { ARG_pixel_shader, ARG_radius, ARG_x, ARG_y, ARG_color_index };
|
2020-05-02 02:21:35 -07:00
|
|
|
static const mp_arg_t allowed_args[] = {
|
2021-08-01 13:01:57 -07:00
|
|
|
{ MP_QSTR_pixel_shader, MP_ARG_OBJ | MP_ARG_KW_ONLY | MP_ARG_REQUIRED },
|
2020-05-02 02:21:35 -07:00
|
|
|
{ MP_QSTR_radius, MP_ARG_REQUIRED | MP_ARG_INT },
|
2021-08-01 13:01:57 -07:00
|
|
|
{ MP_QSTR_x, MP_ARG_INT | MP_ARG_KW_ONLY, {.u_int = 0} },
|
|
|
|
{ MP_QSTR_y, MP_ARG_INT | MP_ARG_KW_ONLY, {.u_int = 0} },
|
2022-03-19 11:30:37 -05:00
|
|
|
{ MP_QSTR_color_index, MP_ARG_INT | MP_ARG_KW_ONLY, {.u_int = 0} },
|
2020-05-02 02:21:35 -07:00
|
|
|
};
|
|
|
|
mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
|
2021-10-15 13:43:12 -05:00
|
|
|
mp_arg_parse_all_kw_array(n_args, n_kw, all_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
|
|
|
mp_int_t radius = args[ARG_radius].u_int;
|
2022-06-23 11:45:02 -05:00
|
|
|
mp_arg_validate_int_min(radius, 1, MP_QSTR_radius);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
|
|
|
vectorio_circle_t *self = m_new_obj(vectorio_circle_t);
|
|
|
|
self->base.type = &vectorio_circle_type;
|
2022-03-19 11:30:37 -05:00
|
|
|
uint16_t color_index = args[ARG_color_index].u_int;
|
|
|
|
common_hal_vectorio_circle_construct(self, radius, color_index);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2021-08-01 13:01:57 -07:00
|
|
|
// VectorShape parts
|
|
|
|
mp_obj_t pixel_shader = args[ARG_pixel_shader].u_obj;
|
2021-09-10 09:24:33 +01:00
|
|
|
int32_t x = args[ARG_x].u_int;
|
|
|
|
int32_t y = args[ARG_y].u_int;
|
2021-08-01 13:01:57 -07:00
|
|
|
mp_obj_t vector_shape = vectorio_vector_shape_make_new(self, pixel_shader, x, y);
|
|
|
|
self->draw_protocol_instance = vector_shape;
|
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
return MP_OBJ_FROM_PTR(self);
|
|
|
|
}
|
|
|
|
|
2021-08-01 13:01:57 -07:00
|
|
|
STATIC const vectorio_draw_protocol_t circle_draw_protocol = {
|
|
|
|
MP_PROTO_IMPLEMENT(MP_QSTR_protocol_draw)
|
|
|
|
.draw_get_protocol_self = (draw_get_protocol_self_fun)common_hal_vectorio_circle_get_draw_protocol,
|
|
|
|
.draw_protocol_impl = &vectorio_vector_shape_draw_protocol_impl
|
|
|
|
};
|
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| radius: int
|
2020-05-12 18:40:02 -07:00
|
|
|
//| """The radius of the circle in pixels."""
|
2020-05-02 02:21:35 -07:00
|
|
|
STATIC mp_obj_t vectorio_circle_obj_get_radius(mp_obj_t self_in) {
|
|
|
|
vectorio_circle_t *self = MP_OBJ_TO_PTR(self_in);
|
|
|
|
return mp_obj_new_int(common_hal_vectorio_circle_get_radius(self));
|
|
|
|
}
|
|
|
|
MP_DEFINE_CONST_FUN_OBJ_1(vectorio_circle_get_radius_obj, vectorio_circle_obj_get_radius);
|
|
|
|
|
|
|
|
STATIC mp_obj_t vectorio_circle_obj_set_radius(mp_obj_t self_in, mp_obj_t radius) {
|
|
|
|
vectorio_circle_t *self = MP_OBJ_TO_PTR(self_in);
|
|
|
|
common_hal_vectorio_circle_set_radius(self, mp_obj_get_int(radius));
|
|
|
|
return mp_const_none;
|
|
|
|
}
|
|
|
|
MP_DEFINE_CONST_FUN_OBJ_2(vectorio_circle_set_radius_obj, vectorio_circle_obj_set_radius);
|
|
|
|
|
2022-05-01 10:24:05 -06:00
|
|
|
MP_PROPERTY_GETSET(vectorio_circle_radius_obj,
|
2022-05-01 09:16:53 -06:00
|
|
|
(mp_obj_t)&vectorio_circle_get_radius_obj,
|
|
|
|
(mp_obj_t)&vectorio_circle_set_radius_obj);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| color_index: int
|
2022-03-19 11:30:37 -05:00
|
|
|
//| """The color_index of the circle as 0 based index of the palette."""
|
|
|
|
STATIC mp_obj_t vectorio_circle_obj_get_color_index(mp_obj_t self_in) {
|
|
|
|
vectorio_circle_t *self = MP_OBJ_TO_PTR(self_in);
|
|
|
|
return mp_obj_new_int(common_hal_vectorio_circle_get_color_index(self));
|
|
|
|
}
|
|
|
|
MP_DEFINE_CONST_FUN_OBJ_1(vectorio_circle_get_color_index_obj, vectorio_circle_obj_get_color_index);
|
|
|
|
|
|
|
|
STATIC mp_obj_t vectorio_circle_obj_set_color_index(mp_obj_t self_in, mp_obj_t color_index) {
|
|
|
|
vectorio_circle_t *self = MP_OBJ_TO_PTR(self_in);
|
|
|
|
common_hal_vectorio_circle_set_color_index(self, mp_obj_get_int(color_index));
|
|
|
|
return mp_const_none;
|
|
|
|
}
|
|
|
|
MP_DEFINE_CONST_FUN_OBJ_2(vectorio_circle_set_color_index_obj, vectorio_circle_obj_set_color_index);
|
|
|
|
|
2022-05-01 10:24:05 -06:00
|
|
|
MP_PROPERTY_GETSET(vectorio_circle_color_index_obj,
|
2022-05-01 09:16:53 -06:00
|
|
|
(mp_obj_t)&vectorio_circle_get_color_index_obj,
|
|
|
|
(mp_obj_t)&vectorio_circle_set_color_index_obj);
|
2022-03-19 11:30:37 -05:00
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2021-09-11 23:37:41 +01:00
|
|
|
// Documentation for properties inherited from VectorShape.
|
|
|
|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| x: int
|
2021-09-11 23:37:41 +01:00
|
|
|
//| """X position of the center point of the circle in the parent."""
|
|
|
|
//|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| y: int
|
2021-09-11 23:37:41 +01:00
|
|
|
//| """Y position of the center point of the circle in the parent."""
|
|
|
|
//|
|
2022-11-11 20:18:42 -06:00
|
|
|
//| hidden: bool
|
2022-11-11 17:50:07 -06:00
|
|
|
//| """Hide the circle or not."""
|
|
|
|
//|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| location: Tuple[int, int]
|
2021-09-11 23:37:41 +01:00
|
|
|
//| """(X,Y) position of the center point of the circle in the parent."""
|
|
|
|
//|
|
2022-09-27 15:21:42 -05:00
|
|
|
//| pixel_shader: Union[displayio.ColorConverter, displayio.Palette]
|
2021-09-11 23:37:41 +01:00
|
|
|
//| """The pixel shader of the circle."""
|
2022-09-29 19:22:32 -05:00
|
|
|
//|
|
2021-09-11 23:37:41 +01:00
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
STATIC const mp_rom_map_elem_t vectorio_circle_locals_dict_table[] = {
|
vectorio contains(x, y)
new utility function for all vectorio shape specializations for testing
whether a screen-space x,y point falls within a shape's x,y.
This respects the current orientation of the screen in the manner of
displayio and vectorio - so your x,y requests are in the same coordinate
domain as your x,y locations and your width/height etc. properties that
ou set on other shapes. I.e., if you're using this for touch points then
you will need to make sure the touch events are in the same x,y domain as
your display.
```
contains(2, 4) -> true
------------------
| |
| |
| -- |
| | \ |
| |. \ |
| | \ |
| |____\ |
| |
------------------
contains(5, 4) -> false
------------------
| |
| |
| -- |
| | \ |
| | \. |
| | \ |
| |____\ |
| |
------------------
```
This helps provide low overhead introspection of shape coverage on screen.
It's envisioned that this will be used for things like touch-and-drag
widget controls, touch "areas" and may help with random ornament placement
on toy Christmas trees.
2021-12-27 11:31:18 -10:00
|
|
|
// Functions
|
|
|
|
{ MP_ROM_QSTR(MP_QSTR_contains), MP_ROM_PTR(&vectorio_vector_shape_contains_obj) },
|
2021-08-01 13:01:57 -07:00
|
|
|
// Properties
|
2020-05-02 02:21:35 -07:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_radius), MP_ROM_PTR(&vectorio_circle_radius_obj) },
|
2021-08-01 13:01:57 -07:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_x), MP_ROM_PTR(&vectorio_vector_shape_x_obj) },
|
|
|
|
{ MP_ROM_QSTR(MP_QSTR_y), MP_ROM_PTR(&vectorio_vector_shape_y_obj) },
|
2022-11-11 17:50:07 -06:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_hidden), MP_ROM_PTR(&vectorio_vector_shape_hidden_obj) },
|
2022-03-19 11:30:37 -05:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_color_index), MP_ROM_PTR(&vectorio_circle_color_index_obj) },
|
2021-08-08 00:14:53 -07:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_location), MP_ROM_PTR(&vectorio_vector_shape_location_obj) },
|
2021-08-01 13:01:57 -07:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_pixel_shader), MP_ROM_PTR(&vectorio_vector_shape_pixel_shader_obj) },
|
2020-05-02 02:21:35 -07:00
|
|
|
};
|
|
|
|
STATIC MP_DEFINE_CONST_DICT(vectorio_circle_locals_dict, vectorio_circle_locals_dict_table);
|
|
|
|
|
|
|
|
const mp_obj_type_t vectorio_circle_type = {
|
|
|
|
{ &mp_type_type },
|
|
|
|
.name = MP_QSTR_Circle,
|
2021-08-01 13:01:57 -07:00
|
|
|
.flags = MP_TYPE_FLAG_EXTENDED,
|
2020-05-02 02:21:35 -07:00
|
|
|
.make_new = vectorio_circle_make_new,
|
2021-03-15 19:27:36 +05:30
|
|
|
.locals_dict = (mp_obj_dict_t *)&vectorio_circle_locals_dict,
|
2021-08-01 13:01:57 -07:00
|
|
|
MP_TYPE_EXTENDED_FIELDS(
|
|
|
|
.protocol = &circle_draw_protocol,
|
|
|
|
),
|
2020-05-02 02:21:35 -07:00
|
|
|
};
|