aboutsummaryrefslogtreecommitdiff
path: root/drivers/oled/oled_driver.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/oled/oled_driver.c')
-rw-r--r--drivers/oled/oled_driver.c22
1 files changed, 17 insertions, 5 deletions
diff --git a/drivers/oled/oled_driver.c b/drivers/oled/oled_driver.c
index ba11db1d2..53bb8ca3f 100644
--- a/drivers/oled/oled_driver.c
+++ b/drivers/oled/oled_driver.c
@@ -119,6 +119,9 @@ uint32_t oled_timeout;
119#if OLED_SCROLL_TIMEOUT > 0 119#if OLED_SCROLL_TIMEOUT > 0
120uint32_t oled_scroll_timeout; 120uint32_t oled_scroll_timeout;
121#endif 121#endif
122#if OLED_UPDATE_INTERVAL > 0
123uint16_t oled_update_timeout;
124#endif
122 125
123// Internal variables to reduce math instructions 126// Internal variables to reduce math instructions
124 127
@@ -468,8 +471,9 @@ void oled_write_raw_byte(const char data, uint16_t index) {
468} 471}
469 472
470void oled_write_raw(const char *data, uint16_t size) { 473void oled_write_raw(const char *data, uint16_t size) {
471 if (size > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE; 474 uint16_t cursor_start_index = oled_cursor - &oled_buffer[0];
472 for (uint16_t i = 0; i < size; i++) { 475 if ((size + cursor_start_index) > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE - cursor_start_index;
476 for (uint16_t i = cursor_start_index; i < cursor_start_index + size; i++) {
473 if (oled_buffer[i] == data[i]) continue; 477 if (oled_buffer[i] == data[i]) continue;
474 oled_buffer[i] = data[i]; 478 oled_buffer[i] = data[i];
475 oled_dirty |= ((OLED_BLOCK_TYPE)1 << (i / OLED_BLOCK_SIZE)); 479 oled_dirty |= ((OLED_BLOCK_TYPE)1 << (i / OLED_BLOCK_SIZE));
@@ -511,8 +515,9 @@ void oled_write_ln_P(const char *data, bool invert) {
511} 515}
512 516
513void oled_write_raw_P(const char *data, uint16_t size) { 517void oled_write_raw_P(const char *data, uint16_t size) {
514 if (size > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE; 518 uint16_t cursor_start_index = oled_cursor - &oled_buffer[0];
515 for (uint16_t i = 0; i < size; i++) { 519 if ((size + cursor_start_index) > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE - cursor_start_index;
520 for (uint16_t i = cursor_start_index; i < cursor_start_index + size; i++) {
516 uint8_t c = pgm_read_byte(data++); 521 uint8_t c = pgm_read_byte(data++);
517 if (oled_buffer[i] == c) continue; 522 if (oled_buffer[i] == c) continue;
518 oled_buffer[i] = c; 523 oled_buffer[i] = c;
@@ -650,9 +655,16 @@ void oled_task(void) {
650 return; 655 return;
651 } 656 }
652 657
658#if OLED_UPDATE_INTERVAL > 0
659 if (timer_elapsed(oled_update_timeout) >= OLED_UPDATE_INTERVAL) {
660 oled_update_timeout = timer_read();
661 oled_set_cursor(0, 0);
662 oled_task_user();
663 }
664#else
653 oled_set_cursor(0, 0); 665 oled_set_cursor(0, 0);
654
655 oled_task_user(); 666 oled_task_user();
667#endif
656 668
657#if OLED_SCROLL_TIMEOUT > 0 669#if OLED_SCROLL_TIMEOUT > 0
658 if (oled_dirty && oled_scrolling) { 670 if (oled_dirty && oled_scrolling) {