oled_driver.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. /*
  2. Copyright 2019 Ryan Caltabiano <https://github.com/XScorpion2>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. #pragma once
  15. #include <stdint.h>
  16. #include <stdbool.h>
  17. #if defined(OLED_DISPLAY_CUSTOM)
  18. // Expected user to implement the necessary defines
  19. #elif defined(OLED_DISPLAY_128X64)
  20. // Double height 128x64
  21. #define OLED_DISPLAY_WIDTH 128
  22. #define OLED_DISPLAY_HEIGHT 64
  23. #define OLED_MATRIX_SIZE (OLED_DISPLAY_HEIGHT / 8 * OLED_DISPLAY_WIDTH) // 1024 (compile time mathed)
  24. #define OLED_BLOCK_TYPE uint16_t
  25. #define OLED_BLOCK_COUNT (sizeof(OLED_BLOCK_TYPE) * 8) // 16 (compile time mathed)
  26. #define OLED_BLOCK_SIZE (OLED_MATRIX_SIZE / OLED_BLOCK_COUNT) // 64 (compile time mathed)
  27. // For 90 degree rotation, we map our internal matrix to oled matrix using fixed arrays
  28. // The OLED writes to it's memory horizontally, starting top left, but our memory starts bottom left in this mode
  29. #define OLED_SOURCE_MAP { 0, 8, 16, 24, 32, 40, 48, 56 }
  30. #define OLED_TARGET_MAP { 56, 48, 40, 32, 24, 16, 8, 0 }
  31. // If OLED_BLOCK_TYPE is uint8_t, these tables would look like:
  32. // #define OLED_SOURCE_MAP { 0, 8, 16, 24, 32, 40, 48, 56, 64, 72, 80, 88, 96, 104, 112, 120 }
  33. // #define OLED_TARGET_MAP { 56, 120, 48, 112, 40, 104, 32, 96, 24, 88, 16, 80, 8, 72, 0, 64 }
  34. #else // defined(OLED_DISPLAY_128X64)
  35. // Default 128x32
  36. #define OLED_DISPLAY_WIDTH 128
  37. #define OLED_DISPLAY_HEIGHT 32
  38. #define OLED_MATRIX_SIZE (OLED_DISPLAY_HEIGHT / 8 * OLED_DISPLAY_WIDTH) // 512 (compile time mathed)
  39. #define OLED_BLOCK_TYPE uint8_t // Type to use for segmenting the oled display for smart rendering, use unsigned types only
  40. #define OLED_BLOCK_COUNT (sizeof(OLED_BLOCK_TYPE) * 8) // 8 (compile time mathed)
  41. #define OLED_BLOCK_SIZE (OLED_MATRIX_SIZE / OLED_BLOCK_COUNT) // 128 (compile time mathed)
  42. // For 90 degree rotation, we map our internal matrix to oled matrix using fixed arrays
  43. // The OLED writes to it's memory horizontally, starting top left, but our memory starts bottom left in this mode
  44. #define OLED_SOURCE_MAP { 0, 8, 16, 24, 32, 40, 48, 56 }
  45. #define OLED_TARGET_MAP { 48, 32, 16, 0, 56, 40, 24, 8 }
  46. #endif // defined(OLED_DISPLAY_CUSTOM)
  47. // Address to use for tthe i2d oled communication
  48. #if !defined(OLED_DISPLAY_ADDRESS)
  49. #define OLED_DISPLAY_ADDRESS 0x3C
  50. #endif
  51. // Custom font file to use
  52. #if !defined(OLED_FONT_H)
  53. #define OLED_FONT_H "glcdfont.c"
  54. #endif
  55. // unsigned char value of the first character in the font file
  56. #if !defined(OLED_FONT_START)
  57. #define OLED_FONT_START 0
  58. #endif
  59. // unsigned char value of the last character in the font file
  60. #if !defined(OLED_FONT_END)
  61. #define OLED_FONT_END 224
  62. #endif
  63. // Font render width
  64. #if !defined(OLED_FONT_WIDTH)
  65. #define OLED_FONT_WIDTH 6
  66. #endif
  67. // Font render height
  68. #if !defined(OLED_FONT_HEIGHT)
  69. #define OLED_FONT_HEIGHT 8
  70. #endif
  71. #define OLED_ROTATION_0 0x00
  72. #define OLED_ROTATION_90 0x01
  73. #define OLED_ROTATION_180 0x02
  74. #define OLED_ROTATION_270 0x03
  75. // Initialize the oled display, rotating the rendered output based on the define passed in.
  76. // Returns true if the OLED was initialized successfully
  77. bool oled_init(uint8_t rotation);
  78. // Called at the start of oled_init, weak function overridable by the user
  79. // rotation - the value passed into oled_init
  80. // Return new uint8_t if you want to override default rotation
  81. uint8_t oled_init_user(uint8_t rotation);
  82. // Clears the display buffer, resets cursor position to 0, and sets the buffer to dirty for rendering
  83. void oled_clear(void);
  84. // Renders the dirty chunks of the buffer to oled display
  85. void oled_render(void);
  86. // Moves cursor to character position indicated by column and line, wraps if out of bounds
  87. // Max column denoted by 'oled_max_chars()' and max lines by 'oled_max_lines()' functions
  88. void oled_set_cursor(uint8_t col, uint8_t line);
  89. // Advances the cursor to the next page, writing ' ' if true
  90. // Wraps to the begining when out of bounds
  91. void oled_advance_page(bool clearPageRemainder);
  92. // Moves the cursor forward 1 character length
  93. // Advance page if there is not enough room for the next character
  94. // Wraps to the begining when out of bounds
  95. void oled_advance_char(void);
  96. // Writes a single character to the buffer at current cursor position
  97. // Advances the cursor while writing, inverts the pixels if true
  98. // Main handler that writes character data to the display buffer
  99. void oled_write_char(const char data, bool invert);
  100. // Writes a string to the buffer at current cursor position
  101. // Advances the cursor while writing, inverts the pixels if true
  102. void oled_write(const char *data, bool invert);
  103. // Writes a string to the buffer at current cursor position
  104. // Advances the cursor while writing, inverts the pixels if true
  105. // Advances the cursor to the next page, wiring ' ' to the remainder of the current page
  106. void oled_write_ln(const char *data, bool invert);
  107. #if defined(__AVR__)
  108. // Writes a PROGMEM string to the buffer at current cursor position
  109. // Advances the cursor while writing, inverts the pixels if true
  110. // Remapped to call 'void oled_write(const char *data, bool invert);' on ARM
  111. void oled_write_P(const char *data, bool invert);
  112. // Writes a PROGMEM string to the buffer at current cursor position
  113. // Advances the cursor while writing, inverts the pixels if true
  114. // Advances the cursor to the next page, wiring ' ' to the remainder of the current page
  115. // Remapped to call 'void oled_write_ln(const char *data, bool invert);' on ARM
  116. void oled_write_ln_P(const char *data, bool invert);
  117. #else
  118. // Writes a string to the buffer at current cursor position
  119. // Advances the cursor while writing, inverts the pixels if true
  120. #define oled_write_P(data, invert) oled_write(data, invert)
  121. // Writes a string to the buffer at current cursor position
  122. // Advances the cursor while writing, inverts the pixels if true
  123. // Advances the cursor to the next page, wiring ' ' to the remainder of the current page
  124. #define oled_write_ln_P(data, invert) oled_write(data, invert)
  125. #endif // defined(__AVR__)
  126. // Can be used to manually turn on the screen if it is off
  127. // Returns true if the screen was on or turns on
  128. bool oled_on(void);
  129. // Can be used to manually turn off the screen if it is on
  130. // Returns true if the screen was off or turns off
  131. bool oled_off(void);
  132. // Basically it's oled_render, but with timeout management and oled_task_user calling!
  133. void oled_task(void);
  134. // Called at the start of oled_task, weak function overridable by the user
  135. void oled_task_user(void);
  136. // Scrolls the entire display right
  137. // Returns true if the screen was scrolling or starts scrolling
  138. // NOTE: display contents cannot be changed while scrolling
  139. bool oled_scroll_right(void);
  140. // Scrolls the entire display left
  141. // Returns true if the screen was scrolling or starts scrolling
  142. // NOTE: display contents cannot be changed while scrolling
  143. bool oled_scroll_left(void);
  144. // Turns off display scrolling
  145. // Returns true if the screen was not scrolling or stops scrolling
  146. bool oled_scroll_off(void);
  147. // Returns the maximum number of characters that will fit on a line
  148. uint8_t oled_max_chars(void);
  149. // Returns the maximum number of lines that will fit on the oled
  150. uint8_t oled_max_lines(void);