123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- /*
- * Copyright (c) 2018 PHYTEC Messtechnik GmbH
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /**
- * @file
- * @brief Public Monochrome Character Framebuffer API
- */
- #ifndef __CFB_H__
- #define __CFB_H__
- #include <device.h>
- #include <drivers/display.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @brief Display Drivers
- * @addtogroup display_interfaces Display Drivers
- * @{
- * @}
- */
- /**
- * @brief Public Monochrome Character Framebuffer API
- * @defgroup monochrome_character_framebuffer Monochrome Character Framebuffer
- * @ingroup display_interfaces
- * @{
- */
- enum cfb_display_param {
- CFB_DISPLAY_HEIGH = 0,
- CFB_DISPLAY_WIDTH,
- CFB_DISPLAY_PPT,
- CFB_DISPLAY_ROWS,
- CFB_DISPLAY_COLS,
- };
- enum cfb_font_caps {
- CFB_FONT_MONO_VPACKED = BIT(0),
- CFB_FONT_MONO_HPACKED = BIT(1),
- CFB_FONT_MSB_FIRST = BIT(2),
- };
- struct cfb_font {
- const void *data;
- enum cfb_font_caps caps;
- uint8_t width;
- uint8_t height;
- uint8_t first_char;
- uint8_t last_char;
- };
- /**
- * @brief Macro for creating a font entry.
- *
- * @param _name Name of the font entry.
- * @param _width Width of the font in pixels
- * @param _height Height of the font in pixels.
- * @param _caps Font capabilities.
- * @param _data Raw data of the font.
- * @param _fc Character mapped to first font element.
- * @param _lc Character mapped to last font element.
- */
- #define FONT_ENTRY_DEFINE(_name, _width, _height, _caps, _data, _fc, _lc) \
- static const STRUCT_SECTION_ITERABLE(cfb_font, _name) = { \
- .data = _data, \
- .caps = _caps, \
- .width = _width, \
- .height = _height, \
- .first_char = _fc, \
- .last_char = _lc, \
- }
- /**
- * @brief Print a string into the framebuffer.
- *
- * @param dev Pointer to device structure for driver instance
- * @param str String to print
- * @param x Position in X direction of the beginning of the string
- * @param y Position in Y direction of the beginning of the string
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_print(const struct device *dev, char *str, uint16_t x, uint16_t y);
- /**
- * @brief Clear framebuffer.
- *
- * @param dev Pointer to device structure for driver instance
- * @param clear_display Clear the display as well
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_framebuffer_clear(const struct device *dev, bool clear_display);
- /**
- * @brief Invert Pixels.
- *
- * @param dev Pointer to device structure for driver instance
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_framebuffer_invert(const struct device *dev);
- /**
- * @brief Finalize framebuffer and write it to display RAM,
- * invert or reorder pixels if necessary.
- *
- * @param dev Pointer to device structure for driver instance
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_framebuffer_finalize(const struct device *dev);
- /**
- * @brief Get display parameter.
- *
- * @param dev Pointer to device structure for driver instance
- * @param cfb_display_param One of the display parameters
- *
- * @return Display parameter value
- */
- int cfb_get_display_parameter(const struct device *dev,
- enum cfb_display_param);
- /**
- * @brief Set font.
- *
- * @param dev Pointer to device structure for driver instance
- * @param idx Font index
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_framebuffer_set_font(const struct device *dev, uint8_t idx);
- /**
- * @brief Get font size.
- *
- * @param dev Pointer to device structure for driver instance
- * @param idx Font index
- * @param width Pointers to the variable where the font width will be stored.
- * @param height Pointers to the variable where the font height will be stored.
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_get_font_size(const struct device *dev, uint8_t idx, uint8_t *width,
- uint8_t *height);
- /**
- * @brief Get number of fonts.
- *
- * @param dev Pointer to device structure for driver instance
- *
- * @return number of fonts
- */
- int cfb_get_numof_fonts(const struct device *dev);
- /**
- * @brief Initialize Character Framebuffer.
- *
- * @param dev Pointer to device structure for driver instance
- *
- * @return 0 on success, negative value otherwise
- */
- int cfb_framebuffer_init(const struct device *dev);
- #ifdef __cplusplus
- }
- #endif
- /**
- * @}
- */
- #endif /* __CFB_H__ */
|