pimoroni-pico/micropython/modules/pico_scroll/pico_scroll.cpp

177 lines
5.1 KiB
C++
Raw Normal View History

2021-01-19 18:43:43 +00:00
#include "hardware/spi.h"
#include "hardware/sync.h"
#include "pico/binary_info.h"
2021-04-16 06:33:39 +01:00
#include "pico/stdlib.h"
2021-01-19 18:43:43 +00:00
#include "libraries/pico_scroll/pico_scroll.hpp"
2021-01-19 18:43:43 +00:00
using namespace pimoroni;
PicoScroll *scroll = nullptr;
2021-01-19 18:43:43 +00:00
extern "C" {
#include "pico_scroll.h"
#define NOT_INITIALISED_MSG "Cannot call this function, as picoscroll is not initialised. Call picoscroll.init() first."
2021-04-07 16:01:50 +01:00
#define BUFFER_TOO_SMALL_MSG "bytearray too small: len(image) < width * height."
2021-04-08 06:25:50 +01:00
#define INCORRECT_SIZE_MSG "Scroll height wrong: > 8 pixels."
2021-04-07 16:01:50 +01:00
2021-01-19 18:43:43 +00:00
mp_obj_t picoscroll_init() {
if(scroll == nullptr)
scroll = new PicoScroll();
scroll->init();
2021-01-19 18:43:43 +00:00
return mp_const_none;
}
mp_obj_t picoscroll_get_width() {
return mp_obj_new_int(PicoScroll::WIDTH);
}
mp_obj_t picoscroll_get_height() {
return mp_obj_new_int(PicoScroll::HEIGHT);
}
mp_obj_t picoscroll_update() {
if(scroll != nullptr)
scroll->update();
else
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
2021-01-19 18:43:43 +00:00
return mp_const_none;
}
mp_obj_t picoscroll_set_pixel(mp_obj_t x_obj, mp_obj_t y_obj, mp_obj_t v_obj) {
2021-04-16 06:13:36 +01:00
if (scroll != nullptr) {
int x = mp_obj_get_int(x_obj);
int y = mp_obj_get_int(y_obj);
int val = mp_obj_get_int(v_obj);
2021-04-16 06:13:36 +01:00
if (x < 0 || x >= PicoScroll::WIDTH || y < 0 || y >= PicoScroll::HEIGHT)
mp_raise_ValueError("x or y out of range.");
else {
2021-04-16 06:13:36 +01:00
if (val < 0 || val > 255)
mp_raise_ValueError("val out of range. Expected 0 to 255");
else
scroll->set_pixel(x, y, val);
}
2021-04-16 06:13:36 +01:00
} else
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
2021-01-19 18:43:43 +00:00
return mp_const_none;
}
2021-04-16 06:33:39 +01:00
mp_obj_t picoscroll_scroll_text(mp_obj_t text_obj, mp_obj_t brightness_obj,
mp_obj_t delay_ms_obj) {
if (scroll != nullptr) {
mp_buffer_info_t bufinfo;
mp_get_buffer_raise(text_obj, &bufinfo, MP_BUFFER_READ);
int brightness = mp_obj_get_int(brightness_obj);
int delay_ms = mp_obj_get_int(delay_ms_obj);
scroll->scroll_text((const char *)bufinfo.buf, bufinfo.len, brightness, delay_ms);
2021-04-16 06:33:39 +01:00
} else {
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
}
return mp_const_none;
}
2021-04-16 06:13:36 +01:00
mp_obj_t picoscroll_show_text(mp_obj_t text_obj, mp_obj_t brightness_obj,
mp_obj_t offset_obj) {
if (scroll != nullptr) {
mp_buffer_info_t bufinfo;
2021-04-16 06:13:36 +01:00
mp_get_buffer_raise(text_obj, &bufinfo, MP_BUFFER_READ);
int brightness = mp_obj_get_int(brightness_obj);
int offset = mp_obj_get_int(offset_obj);
2021-04-16 06:13:36 +01:00
scroll->set_text((const char *)bufinfo.buf, bufinfo.len, brightness, offset);
} else {
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
}
return mp_const_none;
}
2021-04-16 06:13:36 +01:00
2021-04-07 15:21:01 +01:00
mp_obj_t picoscroll_set_pixels(mp_obj_t image_obj) {
2021-04-16 06:13:36 +01:00
if (scroll != nullptr) {
2021-04-07 15:21:01 +01:00
mp_buffer_info_t bufinfo;
2021-04-16 06:13:36 +01:00
mp_get_buffer_raise(image_obj, &bufinfo, MP_BUFFER_RW);
2021-04-07 16:01:50 +01:00
2021-04-16 06:13:36 +01:00
if (bufinfo.len < (PicoScroll::WIDTH * PicoScroll::HEIGHT)) {
mp_raise_msg(&mp_type_IndexError, BUFFER_TOO_SMALL_MSG);
}
2021-04-07 16:01:50 +01:00
scroll->set_pixels((const char*)bufinfo.buf);
2021-04-16 06:13:36 +01:00
} else
2021-04-07 15:21:01 +01:00
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
return mp_const_none;
}
2021-04-16 06:13:36 +01:00
mp_obj_t picoscroll_show_bitmap_1d(mp_obj_t bitmap_obj, mp_obj_t brightness_obj,
mp_obj_t offset_obj) {
if (scroll != nullptr) {
2021-04-08 06:25:50 +01:00
mp_buffer_info_t bufinfo;
2021-04-16 06:13:36 +01:00
mp_get_buffer_raise(bitmap_obj, &bufinfo, MP_BUFFER_RW);
2021-04-08 06:25:50 +01:00
int offset = mp_obj_get_int(offset_obj);
int brightness = mp_obj_get_int(brightness_obj);
2021-04-16 06:13:36 +01:00
int length = bufinfo.len;
// clear the scroll, so only need to write visible bytes
scroll->clear();
if ((offset < -PicoScroll::WIDTH) || (offset > length)) {
2021-04-16 06:13:36 +01:00
return mp_const_none;
}
scroll->set_bitmap_1d((const char *)bufinfo.buf, bufinfo.len, brightness, offset);
2021-04-08 06:25:50 +01:00
} else {
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
}
return mp_const_none;
}
2021-01-19 18:43:43 +00:00
mp_obj_t picoscroll_clear() {
2021-04-16 06:13:36 +01:00
if (scroll != nullptr)
scroll->clear();
else
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
2021-01-19 18:43:43 +00:00
return mp_const_none;
}
mp_obj_t picoscroll_is_pressed(mp_obj_t button_obj) {
bool buttonPressed = false;
if(scroll != nullptr) {
int buttonID = mp_obj_get_int(button_obj);
switch(buttonID) {
case 0:
buttonPressed = scroll->is_pressed(PicoScroll::A);
break;
case 1:
buttonPressed = scroll->is_pressed(PicoScroll::B);
break;
case 2:
buttonPressed = scroll->is_pressed(PicoScroll::X);
break;
case 3:
buttonPressed = scroll->is_pressed(PicoScroll::Y);
break;
default:
mp_raise_ValueError("button not valid. Expected 0 to 3");
break;
}
2021-01-19 18:43:43 +00:00
}
else
mp_raise_msg(&mp_type_RuntimeError, NOT_INITIALISED_MSG);
2021-01-19 18:43:43 +00:00
return buttonPressed ? mp_const_true : mp_const_false;
}
2021-04-07 15:21:01 +01:00
}