1 /* 2 * Copyright (c) 2018 PHYTEC Messtechnik GmbH 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 /** 8 * @file 9 * @brief Public Monochrome Character Framebuffer API 10 */ 11 12 #ifndef ZEPHYR_INCLUDE_DISPLAY_CFB_H_ 13 #define ZEPHYR_INCLUDE_DISPLAY_CFB_H_ 14 15 #include <zephyr/device.h> 16 #include <zephyr/drivers/display.h> 17 #include <zephyr/sys/iterable_sections.h> 18 19 #ifdef __cplusplus 20 extern "C" { 21 #endif 22 23 /** 24 * @brief Public Monochrome Character Framebuffer API 25 * @defgroup monochrome_character_framebuffer Monochrome Character Framebuffer 26 * @ingroup utilities 27 * @{ 28 */ 29 30 enum cfb_display_param { 31 CFB_DISPLAY_HEIGH = 0, 32 CFB_DISPLAY_WIDTH, 33 CFB_DISPLAY_PPT, 34 CFB_DISPLAY_ROWS, 35 CFB_DISPLAY_COLS, 36 }; 37 38 enum cfb_font_caps { 39 CFB_FONT_MONO_VPACKED = BIT(0), 40 CFB_FONT_MONO_HPACKED = BIT(1), 41 CFB_FONT_MSB_FIRST = BIT(2), 42 }; 43 44 struct cfb_font { 45 const void *data; 46 enum cfb_font_caps caps; 47 uint8_t width; 48 uint8_t height; 49 uint8_t first_char; 50 uint8_t last_char; 51 }; 52 53 struct cfb_position { 54 uint16_t x; 55 uint16_t y; 56 }; 57 58 /** 59 * @brief Macro for creating a font entry. 60 * 61 * @param _name Name of the font entry. 62 * @param _width Width of the font in pixels 63 * @param _height Height of the font in pixels. 64 * @param _caps Font capabilities. 65 * @param _data Raw data of the font. 66 * @param _fc Character mapped to first font element. 67 * @param _lc Character mapped to last font element. 68 */ 69 #define FONT_ENTRY_DEFINE(_name, _width, _height, _caps, _data, _fc, _lc) \ 70 static const STRUCT_SECTION_ITERABLE(cfb_font, _name) = { \ 71 .data = _data, \ 72 .caps = _caps, \ 73 .width = _width, \ 74 .height = _height, \ 75 .first_char = _fc, \ 76 .last_char = _lc, \ 77 } 78 79 /** 80 * @brief Print a string into the framebuffer. 81 * 82 * @param dev Pointer to device structure for driver instance 83 * @param str String to print 84 * @param x Position in X direction of the beginning of the string 85 * @param y Position in Y direction of the beginning of the string 86 * 87 * @return 0 on success, negative value otherwise 88 */ 89 int cfb_print(const struct device *dev, const char *const str, uint16_t x, uint16_t y); 90 91 /** 92 * @brief Print a string into the framebuffer. 93 * For compare to cfb_print, cfb_draw_text accept non tile-aligned coords 94 * and not line wrapping. 95 * 96 * @param dev Pointer to device structure for driver instance 97 * @param str String to print 98 * @param x Position in X direction of the beginning of the string 99 * @param y Position in Y direction of the beginning of the string 100 * 101 * @return 0 on success, negative value otherwise 102 */ 103 int cfb_draw_text(const struct device *dev, const char *const str, int16_t x, int16_t y); 104 105 /** 106 * @brief Draw a point. 107 * 108 * @param dev Pointer to device structure for driver instance 109 * @param pos position of the point 110 * 111 * @return 0 on success, negative value otherwise 112 */ 113 int cfb_draw_point(const struct device *dev, const struct cfb_position *pos); 114 115 /** 116 * @brief Draw a line. 117 * 118 * @param dev Pointer to device structure for driver instance 119 * @param start start position of the line 120 * @param end end position of the line 121 * 122 * @return 0 on success, negative value otherwise 123 */ 124 int cfb_draw_line(const struct device *dev, const struct cfb_position *start, 125 const struct cfb_position *end); 126 127 /** 128 * @brief Draw a rectangle. 129 * 130 * @param dev Pointer to device structure for driver instance 131 * @param start Top-Left position of the rectangle 132 * @param end Bottom-Right position of the rectangle 133 * 134 * @return 0 on success, negative value otherwise 135 */ 136 int cfb_draw_rect(const struct device *dev, const struct cfb_position *start, 137 const struct cfb_position *end); 138 139 /** 140 * @brief Clear framebuffer. 141 * 142 * @param dev Pointer to device structure for driver instance 143 * @param clear_display Clear the display as well 144 * 145 * @return 0 on success, negative value otherwise 146 */ 147 int cfb_framebuffer_clear(const struct device *dev, bool clear_display); 148 149 /** 150 * @brief Invert Pixels. 151 * 152 * @param dev Pointer to device structure for driver instance 153 * 154 * @return 0 on success, negative value otherwise 155 */ 156 int cfb_framebuffer_invert(const struct device *dev); 157 158 /** 159 * @brief Invert Pixels in selected area. 160 * 161 * @param dev Pointer to device structure for driver instance 162 * @param x Position in X direction of the beginning of area 163 * @param y Position in Y direction of the beginning of area 164 * @param width Width of area in pixels 165 * @param height Height of area in pixels 166 * 167 * @return 0 on success, negative value otherwise 168 */ 169 int cfb_invert_area(const struct device *dev, uint16_t x, uint16_t y, 170 uint16_t width, uint16_t height); 171 172 /** 173 * @brief Finalize framebuffer and write it to display RAM, 174 * invert or reorder pixels if necessary. 175 * 176 * @param dev Pointer to device structure for driver instance 177 * 178 * @return 0 on success, negative value otherwise 179 */ 180 int cfb_framebuffer_finalize(const struct device *dev); 181 182 /** 183 * @brief Get display parameter. 184 * 185 * @param dev Pointer to device structure for driver instance 186 * @param cfb_display_param One of the display parameters 187 * 188 * @return Display parameter value 189 */ 190 int cfb_get_display_parameter(const struct device *dev, 191 enum cfb_display_param); 192 193 /** 194 * @brief Set font. 195 * 196 * @param dev Pointer to device structure for driver instance 197 * @param idx Font index 198 * 199 * @return 0 on success, negative value otherwise 200 */ 201 int cfb_framebuffer_set_font(const struct device *dev, uint8_t idx); 202 203 /** 204 * @brief Set font kerning (spacing between individual letters). 205 * 206 * @param dev Pointer to device structure for driver instance 207 * @param kerning Font kerning 208 * 209 * @return 0 on success, negative value otherwise 210 */ 211 int cfb_set_kerning(const struct device *dev, int8_t kerning); 212 213 /** 214 * @brief Get font size. 215 * 216 * @param dev Pointer to device structure for driver instance 217 * @param idx Font index 218 * @param width Pointers to the variable where the font width will be stored. 219 * @param height Pointers to the variable where the font height will be stored. 220 * 221 * @return 0 on success, negative value otherwise 222 */ 223 int cfb_get_font_size(const struct device *dev, uint8_t idx, uint8_t *width, 224 uint8_t *height); 225 226 /** 227 * @brief Get number of fonts. 228 * 229 * @param dev Pointer to device structure for driver instance 230 * 231 * @return number of fonts 232 */ 233 int cfb_get_numof_fonts(const struct device *dev); 234 235 /** 236 * @brief Initialize Character Framebuffer. 237 * 238 * @param dev Pointer to device structure for driver instance 239 * 240 * @return 0 on success, negative value otherwise 241 */ 242 int cfb_framebuffer_init(const struct device *dev); 243 244 /** 245 * @brief Deinitialize Character Framebuffer. 246 * 247 * @param dev Pointer to device structure for driver instance 248 */ 249 void cfb_framebuffer_deinit(const struct device *dev); 250 251 #ifdef __cplusplus 252 } 253 #endif 254 255 /** 256 * @} 257 */ 258 259 #endif /* ZEPHYR_INCLUDE_DISPLAY_CFB_H_ */ 260