2020-05-02 02:21:35 -07:00
|
|
|
#ifndef MICROPY_INCLUDED_SHARED_BINDINGS_VECTORIO_SHAPE_H
|
|
|
|
#define MICROPY_INCLUDED_SHARED_BINDINGS_VECTORIO_SHAPE_H
|
|
|
|
|
2021-08-01 13:01:57 -07:00
|
|
|
#include "py/objproperty.h"
|
2021-08-08 00:14:53 -07:00
|
|
|
#include "py/objtuple.h"
|
2021-08-01 13:01:57 -07:00
|
|
|
|
|
|
|
#include "shared-bindings/vectorio/__init__.h"
|
2020-05-02 02:21:35 -07:00
|
|
|
#include "shared-module/vectorio/VectorShape.h"
|
2020-05-08 23:03:15 -07:00
|
|
|
#include "shared-module/displayio/area.h"
|
2020-05-02 02:21:35 -07:00
|
|
|
|
|
|
|
extern const mp_obj_type_t vectorio_vector_shape_type;
|
|
|
|
|
2021-08-01 13:01:57 -07:00
|
|
|
// Python shared bindings constructor
|
2021-09-10 09:24:33 +01:00
|
|
|
mp_obj_t vectorio_vector_shape_make_new(const mp_obj_t shape, const mp_obj_t pixel_shader, int32_t x, int32_t y);
|
2021-08-01 13:01:57 -07:00
|
|
|
|
|
|
|
// C data constructor
|
2020-05-02 02:21:35 -07:00
|
|
|
void common_hal_vectorio_vector_shape_construct(vectorio_vector_shape_t *self,
|
2021-03-15 19:27:36 +05:30
|
|
|
vectorio_ishape_t ishape,
|
2021-09-10 09:24:33 +01:00
|
|
|
mp_obj_t pixel_shader, int32_t x, int32_t y);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
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
|
|
|
bool common_hal_vectorio_vector_shape_contains(vectorio_vector_shape_t *self, mp_int_t x, mp_int_t y);
|
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
void common_hal_vectorio_vector_shape_set_dirty(void *self);
|
|
|
|
|
|
|
|
mp_int_t common_hal_vectorio_vector_shape_get_x(vectorio_vector_shape_t *self);
|
2021-09-10 21:48:01 +01:00
|
|
|
void common_hal_vectorio_vector_shape_set_x(vectorio_vector_shape_t *self, mp_int_t x);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
2021-08-08 00:14:53 -07:00
|
|
|
mp_obj_tuple_t *common_hal_vectorio_vector_shape_get_location(vectorio_vector_shape_t *self);
|
|
|
|
void common_hal_vectorio_vector_shape_set_location(vectorio_vector_shape_t *self, mp_obj_t xy);
|
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
mp_int_t common_hal_vectorio_vector_shape_get_y(vectorio_vector_shape_t *self);
|
2021-09-10 21:48:01 +01:00
|
|
|
void common_hal_vectorio_vector_shape_set_y(vectorio_vector_shape_t *self, mp_int_t y);
|
2020-05-02 02:21:35 -07:00
|
|
|
|
|
|
|
mp_obj_t common_hal_vectorio_vector_shape_get_pixel_shader(vectorio_vector_shape_t *self);
|
|
|
|
void common_hal_vectorio_vector_shape_set_pixel_shader(vectorio_vector_shape_t *self, mp_obj_t pixel_shader);
|
|
|
|
|
2020-05-08 23:03:15 -07:00
|
|
|
void vectorio_vector_shape_update_transform(vectorio_vector_shape_t *self, displayio_buffer_transform_t *group_transform);
|
|
|
|
|
2021-08-01 13:01:57 -07:00
|
|
|
// Composable property definition for shapes that use VectorShape
|
|
|
|
extern vectorio_draw_protocol_impl_t vectorio_vector_shape_draw_protocol_impl;
|
2022-05-01 10:24:05 -06:00
|
|
|
extern const mp_obj_property_getset_t vectorio_vector_shape_x_obj;
|
|
|
|
extern const mp_obj_property_getset_t vectorio_vector_shape_y_obj;
|
|
|
|
extern const mp_obj_property_getset_t vectorio_vector_shape_location_obj;
|
|
|
|
extern const mp_obj_property_getset_t vectorio_vector_shape_pixel_shader_obj;
|
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
|
|
|
extern const mp_obj_fun_builtin_fixed_t vectorio_vector_shape_contains_obj;
|
2021-08-01 13:01:57 -07:00
|
|
|
|
2020-05-02 02:21:35 -07:00
|
|
|
#endif // MICROPY_INCLUDED_SHARED_BINDINGS_VECTORIO_SHAPE_H
|