| modm API documentation
    | 
#include <modm/ui/display/graphic_display.hpp>
 
  
 | Classes | |
| class | Writer | 
| Public Member Functions | |
| virtual uint16_t | getWidth () const = 0 | 
| virtual uint16_t | getHeight () const = 0 | 
| virtual std::size_t | getBufferWidth () const = 0 | 
| virtual std::size_t | getBufferHeight () const = 0 | 
| virtual void | setPixel (int16_t x, int16_t y) = 0 | 
| void | setPixel (glcd::Point p) | 
| virtual void | clearPixel (int16_t x, int16_t y) = 0 | 
| void | clearPixel (glcd::Point p) | 
| virtual void | clear () = 0 | 
| virtual void | update () = 0 | 
| void | drawLine (glcd::Point start, glcd::Point end) | 
| void | drawLine (int16_t x1, int16_t y1, int16_t x2, int16_t y2) | 
| void | drawRectangle (glcd::Point start, uint16_t width, uint16_t height) | 
| void | drawRectangle (int16_t x, int16_t y, uint16_t width, uint16_t height) | 
| void | fillRectangle (glcd::Point start, uint16_t width, uint16_t height) | 
| void | fillRectangle (int16_t x, int16_t y, uint16_t width, uint16_t height) | 
| void | drawRoundedRectangle (glcd::Point start, uint16_t width, uint16_t height, uint16_t radius) | 
| void | drawCircle (glcd::Point center, uint16_t radius) | 
| virtual void | fillCircle (glcd::Point center, uint16_t radius) | 
| void | drawEllipse (glcd::Point center, int16_t rx, int16_t ry) | 
| void | drawImage (glcd::Point start, modm::accessor::Flash< uint8_t > image) | 
| virtual void | drawImageRaw (glcd::Point start, uint16_t width, uint16_t height, modm::accessor::Flash< uint8_t > data) | 
| void | setCursor (glcd::Point position) | 
| void | setCursor (int16_t x, int16_t y) | 
| void | setCursorX (int16_t x) | 
| void | setCursorY (int16_t y) | 
| glcd::Point | getCursor () const | 
| void | setFont (const uint8_t *newFont) | 
| void | setFont (const modm::accessor::Flash< uint8_t > *font) | 
| uint8_t | getFontHeight () const | 
| uint16_t | getStringWidth (const char *s) const | 
| void | write (char c) | 
| IOStream & | ascii () | 
| set the output mode to ASCII style for integer types | |
| IOStream & | bin () | 
| set the output mode to binary style for integer types | |
| IOStream & | endl () | 
| IOStream & | flush () | 
| IOStream & | get (char &c) | 
| Reads one character and returns it if available. Otherwise, returns IOStream::eof. | |
| IOStream & | get (char *s, size_t n) | 
| template<size_t N> | |
| IOStream & | get (char (&s)[N]) | 
| IOStream & | hex () | 
| set the output mode to hexadecimal style for integer types | |
| IOStream & | operator<< (const bool &v) | 
| IOStream & | operator<< (const char &v) | 
| IOStream & | operator<< (const uint8_t &v) | 
| IOStream & | operator<< (const int16_t &v) | 
| IOStream & | operator<< (const uint16_t &v) | 
| IOStream & | operator<< (const int32_t &v) | 
| IOStream & | operator<< (const uint32_t &v) | 
| IOStream & | operator<< (const int64_t &v) | 
| IOStream & | operator<< (const uint64_t &v) | 
| IOStream & | operator<< (const int &v) | 
| IOStream & | operator<< (const unsigned int &v) | 
| IOStream & | operator<< (const float &v) | 
| IOStream & | operator<< (const double &v) | 
| IOStream & | operator<< (const char *s) | 
| IOStream & | operator<< (const std::string_view sv) | 
| IOStream & | operator<< (const void *p) | 
| write the hex value of a pointer | |
| template<class Ret , class... Args> | |
| IOStream & | operator<< (Ret (*pointer)(Args...)) | 
| Write the hex value of any function pointer. | |
| IOStream & | operator<< (IOStream &(*format)(IOStream &)) | 
| IOStream & | printf (const char *fmt,...))) | 
| IOStream & | vprintf (const char *fmt, va_list vlist))) | 
| Static Public Member Functions | |
| static uint8_t | getFontHeight (const modm::accessor::Flash< uint8_t > *font) | 
| static uint16_t | getStringWidth (const char *s, const modm::accessor::Flash< uint8_t > *font) | 
| Static Public Attributes | |
| static constexpr char | eof = -1 | 
| Protected Member Functions | |
| void | drawCircle4 (glcd::Point center, int16_t x, int16_t y) | 
| helper method for drawCircle() and drawEllipse() | |
| virtual void | drawHorizontalLine (glcd::Point start, uint16_t length) | 
| virtual void | drawVerticalLine (glcd::Point start, uint16_t length) | 
| void | writeBin (uint8_t value) | 
| void | writeDouble (const double &value) | 
| void | writeFloat (float value) | 
| void | writeHex (uint8_t value) | 
| void | writeInteger (int16_t value) | 
| void | writeInteger (uint16_t value) | 
| void | writeInteger (int32_t value) | 
| void | writeInteger (uint32_t value) | 
| void | writeInteger (int64_t value) | 
| void | writeInteger (uint64_t value) | 
| template<typename T > | |
| void | writeIntegerMode (const T v) | 
| void | writePointer (const void *value) | 
| Protected Attributes | |
| Writer | writer | 
| modm::accessor::Flash< uint8_t > | font | 
| glcd::Point | cursor | 
| Friends | |
| class | VirtualGraphicDisplay | 
Base class for graphical displays.
Text mode:
All modes relative to the current viewport. This would make drawing a menu system easier.
| 
 | pure virtual | 
Set whole screen to backgroundColor
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::ParallelTft< INTERFACE >, modm::MonochromeGraphicDisplay< Width, Height, BufferWidth, BufferHeight >, modm::MonochromeGraphicDisplay< Width, Height, Width, Height/8 >, modm::MonochromeGraphicDisplay< Width, Height, Width/8, Height >, and modm::VirtualGraphicDisplay.
| 
 | inline | 
Set a pixel to backgroundColor
| p | point | 
| 
 | pure virtual | 
Set a pixel to backgroundColor
| x | x-position | 
| y | y-position | 
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::ParallelTft< INTERFACE >, modm::VirtualGraphicDisplay, modm::MonochromeGraphicDisplayVertical< Width, Height >, modm::MonochromeGraphicDisplayVertical< 84, 48 >, modm::MonochromeGraphicDisplayVertical< 8 *COLUMNS, 8 *ROWS >, modm::MonochromeGraphicDisplayVertical< 132, 176 >, modm::MonochromeGraphicDisplayVertical< WIDTH, HEIGHT >, modm::MonochromeGraphicDisplayVertical< 128, Height >, modm::MonochromeGraphicDisplayVertical< 176, 136 >, modm::MonochromeGraphicDisplayHorizontal< Width, Height >, and modm::MonochromeGraphicDisplayHorizontal< 8 *COLUMNS, 8 *ROWS >.
| void modm::GraphicDisplay::drawCircle | ( | glcd::Point | center, | 
| uint16_t | radius | ||
| ) | 
Draw a filled rectangle with rounded corners
| start | Upper left corner | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| radius | Rounding radius | 
Draw a circle
Uses the midpoint circle algorithm.
| center | Center of the circle | 
| radius | Radius of the circle | 
| void modm::GraphicDisplay::drawEllipse | ( | glcd::Point | center, | 
| int16_t | rx, | ||
| int16_t | ry | ||
| ) | 
Draw an ellipse.
Uses a variation of the midpoint algorithm. May be improved through simplification of the used formula.
| center | Center of the ellipse | 
| rx | Radius in x-direction | 
| ry | Radius in y-direction | 
| void modm::GraphicDisplay::drawImage | ( | glcd::Point | start, | 
| modm::accessor::Flash< uint8_t > | image | ||
| ) | 
Draw an image.
The first byte in the image data specifies the with, the second byte the height. Afterwards the actual image data.
| start | Upper left corner | 
| image | Image data in Flash | 
| 
 | virtual | 
Draw an image.
| start | Upper left corner | 
| width | Image width | 
| height | Image height | 
| data | Image data in Flash without any size information. | 
Reimplemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::MonochromeGraphicDisplayVertical< Width, Height >, modm::MonochromeGraphicDisplayVertical< 84, 48 >, modm::MonochromeGraphicDisplayVertical< 8 *COLUMNS, 8 *ROWS >, modm::MonochromeGraphicDisplayVertical< 132, 176 >, modm::MonochromeGraphicDisplayVertical< WIDTH, HEIGHT >, modm::MonochromeGraphicDisplayVertical< 128, Height >, and modm::MonochromeGraphicDisplayVertical< 176, 136 >.
| 
 | inline | 
Draw a line.
Uses the faster drawHorizontalLine() or drawVerticalLine() if possible, otherwise the line is rastered with the Bresenham line algorithm.
| start | first point | 
| end | second point | 
| void modm::GraphicDisplay::drawLine | ( | int16_t | x1, | 
| int16_t | y1, | ||
| int16_t | x2, | ||
| int16_t | y2 | ||
| ) | 
Draw a line
| x1 | Start x-position | 
| y1 | Start y-position | 
| x2 | End x-position | 
| y3 | End y-position | 
| void modm::GraphicDisplay::drawRectangle | ( | glcd::Point | start, | 
| uint16_t | width, | ||
| uint16_t | height | ||
| ) | 
Draw a rectangle.
| start | Upper left corner | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| 
 | inline | 
Draw a rectangle.
| x | Upper left corner x-position | 
| y | Upper left corner y-position | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| void modm::GraphicDisplay::drawRoundedRectangle | ( | glcd::Point | start, | 
| uint16_t | width, | ||
| uint16_t | height, | ||
| uint16_t | radius | ||
| ) | 
Draw a rectangle with rounded corners
| start | Upper left corner | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| radius | Rounding radius | 
| 
 | virtual | 
Draw a filled circle.
| center | Center of the circle | 
| radius | Radius of the circle | 
Reimplemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >.
| void modm::GraphicDisplay::fillRectangle | ( | glcd::Point | start, | 
| uint16_t | width, | ||
| uint16_t | height | ||
| ) | 
Draw a filled rectangle.
| start | Upper left corner | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| 
 | inline | 
Draw a rectangle.
| x | Upper left corner x-position | 
| y | Upper left corner y-position | 
| width | Width of rectangle | 
| height | Height of rectangle | 
| 
 | inherited | 
reads characters into NULL delimited c string in contrast to the standard implementation, this does not care about newline characters in the input
| 
 | pure virtual | 
Buffer-array size of second dimension
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::MonochromeGraphicDisplay< Width, Height, BufferWidth, BufferHeight >, modm::MonochromeGraphicDisplay< Width, Height, Width, Height/8 >, modm::MonochromeGraphicDisplay< Width, Height, Width/8, Height >, and modm::ParallelTft< INTERFACE >.
| 
 | pure virtual | 
Buffer-array size of first dimension
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::MonochromeGraphicDisplay< Width, Height, BufferWidth, BufferHeight >, modm::MonochromeGraphicDisplay< Width, Height, Width, Height/8 >, modm::MonochromeGraphicDisplay< Width, Height, Width/8, Height >, and modm::ParallelTft< INTERFACE >.
| uint8_t modm::GraphicDisplay::getFontHeight | ( | ) | const | 
Get the height of a character.
| 
 | pure virtual | 
Number of pixel in vertical direction.
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::MonochromeGraphicDisplay< Width, Height, BufferWidth, BufferHeight >, modm::MonochromeGraphicDisplay< Width, Height, Width, Height/8 >, modm::MonochromeGraphicDisplay< Width, Height, Width/8, Height >, modm::ParallelTft< INTERFACE >, and modm::VirtualGraphicDisplay.
| uint16_t modm::GraphicDisplay::getStringWidth | ( | const char * | s | ) | const | 
Get the width of (null terminated) string.
| 
 | pure virtual | 
Number of pixel in horizontal direction.
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::MonochromeGraphicDisplay< Width, Height, BufferWidth, BufferHeight >, modm::MonochromeGraphicDisplay< Width, Height, Width, Height/8 >, modm::MonochromeGraphicDisplay< Width, Height, Width/8, Height >, modm::ParallelTft< INTERFACE >, and modm::VirtualGraphicDisplay.
| 
 | inline | 
Set the cursor for text drawing.
| position | Cursor position | 
| 
 | inline | 
Set the cursor for text drawing.
| x | Cursor x-position | 
| y | Cursor y-position | 
| 
 | inline | 
Set the cursor x-position for text drawing.
| x | Cursor x-position | 
| 
 | inline | 
Set the cursor y-position for text drawing.
| y | Cursor y-position | 
| 
 | inline | 
Set a new font.
Default font is modm::font::FixedWidth5x8.
| newFont | Active font | 
| 
 | inline | 
Set a pixel to foregroundColor
| p | point | 
| 
 | pure virtual | 
Set a pixel to foregroundColor
| x | x-position | 
| y | y-position | 
Implemented in modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::ParallelTft< INTERFACE >, modm::VirtualGraphicDisplay, modm::MonochromeGraphicDisplayVertical< Width, Height >, modm::MonochromeGraphicDisplayVertical< 84, 48 >, modm::MonochromeGraphicDisplayVertical< 8 *COLUMNS, 8 *ROWS >, modm::MonochromeGraphicDisplayVertical< 132, 176 >, modm::MonochromeGraphicDisplayVertical< WIDTH, HEIGHT >, modm::MonochromeGraphicDisplayVertical< 128, Height >, modm::MonochromeGraphicDisplayVertical< 176, 136 >, modm::MonochromeGraphicDisplayHorizontal< Width, Height >, and modm::MonochromeGraphicDisplayHorizontal< 8 *COLUMNS, 8 *ROWS >.
| 
 | pure virtual | 
Transfer the content of the RAM buffer to the real display.
Implemented in modm::Max7219MatrixHorizontal< SPI, CS, COLUMNS, ROWS >, modm::Max7219Matrix< SPI, CS, COLUMNS, ROWS >, modm::St7586s< SPI, CS, RST, DC, Width, Height >, modm::ili9341< Interface, Reset, Backlight, BufferSize >, modm::ParallelTft< INTERFACE >, modm::VirtualGraphicDisplay, modm::St7565< SPI, CS, A0, Reset, Width, Height, TopView >, modm::St7565< SPI, CS, A0, Reset, 132, 32, TopView >, modm::St7565< SPI, CS, A0, Reset, 128, 64, TopView >, modm::St7565< SPI, CS, A0, Reset, 102, 64, TopView >, and modm::Nokia5110< Spi, Ce, Dc, Reset >.
| void modm::GraphicDisplay::write | ( | char | c | ) | 
Write a single character.