My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

u8g_ll_api.c 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573
  1. /*
  2. u8g_ll_api.c
  3. low level api
  4. Universal 8bit Graphics Library
  5. Copyright (c) 2011, olikraus@gmail.com
  6. All rights reserved.
  7. Redistribution and use in source and binary forms, with or without modification,
  8. are permitted provided that the following conditions are met:
  9. * Redistributions of source code must retain the above copyright notice, this list
  10. of conditions and the following disclaimer.
  11. * Redistributions in binary form must reproduce the above copyright notice, this
  12. list of conditions and the following disclaimer in the documentation and/or other
  13. materials provided with the distribution.
  14. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
  15. CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  16. INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  17. MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  18. DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
  19. CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  20. SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  21. NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  22. LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  23. CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  24. STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  25. ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  26. ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. */
  28. #include <stddef.h>
  29. #include "u8g.h"
  30. uint8_t u8g_call_dev_fn(u8g_t *u8g, u8g_dev_t *dev, uint8_t msg, void *arg)
  31. {
  32. return dev->dev_fn(u8g, dev, msg, arg);
  33. }
  34. /*====================================================================*/
  35. uint8_t u8g_InitLL(u8g_t *u8g, u8g_dev_t *dev)
  36. {
  37. uint8_t r;
  38. u8g->state_cb(U8G_STATE_MSG_BACKUP_ENV);
  39. r = u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_INIT, NULL);
  40. u8g->state_cb(U8G_STATE_MSG_BACKUP_U8G);
  41. u8g->state_cb(U8G_STATE_MSG_RESTORE_ENV);
  42. return r;
  43. }
  44. void u8g_FirstPageLL(u8g_t *u8g, u8g_dev_t *dev)
  45. {
  46. u8g->state_cb(U8G_STATE_MSG_BACKUP_ENV);
  47. u8g->state_cb(U8G_STATE_MSG_RESTORE_U8G);
  48. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_PAGE_FIRST, NULL);
  49. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_GET_PAGE_BOX, &(u8g->current_page));
  50. u8g->state_cb(U8G_STATE_MSG_RESTORE_ENV);
  51. }
  52. uint8_t u8g_NextPageLL(u8g_t *u8g, u8g_dev_t *dev)
  53. {
  54. uint8_t r;
  55. u8g->state_cb(U8G_STATE_MSG_BACKUP_ENV);
  56. u8g->state_cb(U8G_STATE_MSG_RESTORE_U8G);
  57. r = u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_PAGE_NEXT, NULL);
  58. if ( r != 0 )
  59. {
  60. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_GET_PAGE_BOX, &(u8g->current_page));
  61. }
  62. u8g->state_cb(U8G_STATE_MSG_RESTORE_ENV);
  63. return r;
  64. }
  65. uint8_t u8g_SetContrastLL(u8g_t *u8g, u8g_dev_t *dev, uint8_t contrast)
  66. {
  67. return u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_CONTRAST, &contrast);
  68. }
  69. void u8g_DrawPixelLL(u8g_t *u8g, u8g_dev_t *dev, u8g_uint_t x, u8g_uint_t y)
  70. {
  71. u8g_dev_arg_pixel_t *arg = &(u8g->arg_pixel);
  72. arg->x = x;
  73. arg->y = y;
  74. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_SET_PIXEL, arg);
  75. }
  76. void u8g_Draw8PixelLL(u8g_t *u8g, u8g_dev_t *dev, u8g_uint_t x, u8g_uint_t y, uint8_t dir, uint8_t pixel)
  77. {
  78. u8g_dev_arg_pixel_t *arg = &(u8g->arg_pixel);
  79. arg->x = x;
  80. arg->y = y;
  81. arg->dir = dir;
  82. arg->pixel = pixel;
  83. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_SET_8PIXEL, arg);
  84. }
  85. void u8g_Draw4TPixelLL(u8g_t *u8g, u8g_dev_t *dev, u8g_uint_t x, u8g_uint_t y, uint8_t dir, uint8_t pixel)
  86. {
  87. u8g_dev_arg_pixel_t *arg = &(u8g->arg_pixel);
  88. arg->x = x;
  89. arg->y = y;
  90. arg->dir = dir;
  91. arg->pixel = pixel;
  92. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_SET_4TPIXEL, arg);
  93. }
  94. #ifdef U8G_DEV_MSG_IS_BBX_INTERSECTION
  95. uint8_t u8g_IsBBXIntersectionLL(u8g_t *u8g, u8g_dev_t *dev, u8g_uint_t x, u8g_uint_t y, u8g_uint_t w, u8g_uint_t h)
  96. {
  97. return u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_IS_BBX_INTERSECTION, &arg);
  98. }
  99. #endif
  100. u8g_uint_t u8g_GetWidthLL(u8g_t *u8g, u8g_dev_t *dev)
  101. {
  102. u8g_uint_t r;
  103. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_GET_WIDTH, &r);
  104. return r;
  105. }
  106. u8g_uint_t u8g_GetHeightLL(u8g_t *u8g, u8g_dev_t *dev)
  107. {
  108. u8g_uint_t r;
  109. u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_GET_HEIGHT, &r);
  110. return r;
  111. }
  112. u8g_uint_t u8g_GetModeLL(u8g_t *u8g, u8g_dev_t *dev)
  113. {
  114. return u8g_call_dev_fn(u8g, dev, U8G_DEV_MSG_GET_MODE, NULL);
  115. }
  116. /*====================================================================*/
  117. void u8g_UpdateDimension(u8g_t *u8g)
  118. {
  119. u8g->width = u8g_GetWidthLL(u8g, u8g->dev);
  120. u8g->height = u8g_GetHeightLL(u8g, u8g->dev);
  121. u8g->mode = u8g_GetModeLL(u8g, u8g->dev);
  122. /* 9 Dec 2012: u8g_scale.c requires update of current page */
  123. u8g_call_dev_fn(u8g, u8g->dev, U8G_DEV_MSG_GET_PAGE_BOX, &(u8g->current_page));
  124. }
  125. static void u8g_init_data(u8g_t *u8g)
  126. {
  127. u8g->font = NULL;
  128. u8g->cursor_font = NULL;
  129. u8g->cursor_bg_color = 0;
  130. u8g->cursor_fg_color = 1;
  131. u8g->cursor_encoding = 34;
  132. u8g->cursor_fn = (u8g_draw_cursor_fn)0;
  133. #if defined(U8G_WITH_PINLIST)
  134. {
  135. uint8_t i;
  136. for( i = 0; i < U8G_PIN_LIST_LEN; i++ )
  137. u8g->pin_list[i] = U8G_PIN_NONE;
  138. }
  139. #endif
  140. u8g_SetColorIndex(u8g, 1);
  141. u8g_SetFontPosBaseline(u8g);
  142. u8g->font_height_mode = U8G_FONT_HEIGHT_MODE_XTEXT;
  143. u8g->font_ref_ascent = 0;
  144. u8g->font_ref_descent = 0;
  145. u8g->font_line_spacing_factor = 64; /* 64 = 1.0, 77 = 1.2 line spacing factor */
  146. u8g->line_spacing = 0;
  147. u8g->state_cb = u8g_state_dummy_cb;
  148. }
  149. uint8_t u8g_Begin(u8g_t *u8g)
  150. {
  151. /* call and init low level driver and com device */
  152. if ( u8g_InitLL(u8g, u8g->dev) == 0 )
  153. return 0;
  154. /* fetch width and height from the low level */
  155. u8g_UpdateDimension(u8g);
  156. return 1;
  157. }
  158. uint8_t u8g_Init(u8g_t *u8g, u8g_dev_t *dev)
  159. {
  160. u8g_init_data(u8g);
  161. u8g->dev = dev;
  162. /* On the Arduino Environment this will lead to two calls to u8g_Begin(), the following line will be called first (by U8glib constructors) */
  163. /* if - in future releases - this is removed, then still call u8g_UpdateDimension() */
  164. /* if Arduino call u8g_UpdateDimension else u8g_Begin */
  165. /* issue 146 */
  166. return u8g_Begin(u8g);
  167. }
  168. /* special init for pure ARM systems */
  169. uint8_t u8g_InitComFn(u8g_t *u8g, u8g_dev_t *dev, u8g_com_fnptr com_fn)
  170. {
  171. u8g_init_data(u8g);
  172. #if defined(U8G_WITH_PINLIST)
  173. {
  174. uint8_t i;
  175. for( i = 0; i < U8G_PIN_LIST_LEN; i++ )
  176. u8g->pin_list[i] = U8G_PIN_DUMMY;
  177. }
  178. #endif
  179. u8g->dev = dev;
  180. /* replace the device procedure with a custom communication procedure */
  181. u8g->dev->com_fn = com_fn;
  182. /* On the Arduino Environment this will lead to two calls to u8g_Begin(), the following line will be called first (by U8glib constructors) */
  183. /* if - in future releases - this is removed, then still call u8g_UpdateDimension() */
  184. /* if Arduino call u8g_UpdateDimension else u8g_Begin */
  185. /* issue 146 */
  186. return u8g_Begin(u8g);
  187. }
  188. #if defined(U8G_WITH_PINLIST)
  189. uint8_t u8g_InitSPI(u8g_t *u8g, u8g_dev_t *dev, uint8_t sck, uint8_t mosi, uint8_t cs, uint8_t a0, uint8_t reset)
  190. {
  191. /* fill data structure with some suitable values */
  192. u8g_init_data(u8g);
  193. u8g->dev = dev;
  194. /* assign user pins */
  195. u8g->pin_list[U8G_PI_SCK] = sck;
  196. u8g->pin_list[U8G_PI_MOSI] = mosi;
  197. u8g->pin_list[U8G_PI_CS] = cs;
  198. u8g->pin_list[U8G_PI_A0] = a0;
  199. u8g->pin_list[U8G_PI_RESET] = reset;
  200. /* On the Arduino Environment this will lead to two calls to u8g_Begin(), the following line will be called first (by U8glib constructors) */
  201. /* if - in future releases - this is removed, then still call u8g_UpdateDimension() */
  202. /* if Arduino call u8g_UpdateDimension else u8g_Begin */
  203. /* issue 146 */
  204. return u8g_Begin(u8g);
  205. }
  206. uint8_t u8g_InitHWSPI(u8g_t *u8g, u8g_dev_t *dev, uint8_t cs, uint8_t a0, uint8_t reset)
  207. {
  208. /* fill data structure with some suitable values */
  209. u8g_init_data(u8g);
  210. u8g->dev = dev;
  211. /* assign user pins */
  212. u8g->pin_list[U8G_PI_CS] = cs;
  213. u8g->pin_list[U8G_PI_A0] = a0;
  214. u8g->pin_list[U8G_PI_RESET] = reset;
  215. return u8g_Begin(u8g);
  216. }
  217. uint8_t u8g_InitI2C(u8g_t *u8g, u8g_dev_t *dev, uint8_t options)
  218. {
  219. /* fill data structure with some suitable values */
  220. u8g_init_data(u8g);
  221. u8g->dev = dev;
  222. u8g->pin_list[U8G_PI_I2C_OPTION] = options;
  223. return u8g_Begin(u8g);
  224. }
  225. uint8_t u8g_Init8BitFixedPort(u8g_t *u8g, u8g_dev_t *dev, uint8_t en, uint8_t cs, uint8_t di, uint8_t rw, uint8_t reset)
  226. {
  227. /* fill data structure with some suitable values */
  228. u8g_init_data(u8g);
  229. u8g->dev = dev;
  230. /* assign user pins */
  231. u8g->pin_list[U8G_PI_EN] = en;
  232. u8g->pin_list[U8G_PI_CS] = cs;
  233. u8g->pin_list[U8G_PI_DI] = di;
  234. u8g->pin_list[U8G_PI_RW] = rw;
  235. u8g->pin_list[U8G_PI_RESET] = reset;
  236. return u8g_Begin(u8g);
  237. }
  238. uint8_t u8g_Init8Bit(u8g_t *u8g, u8g_dev_t *dev, uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3, uint8_t d4, uint8_t d5, uint8_t d6, uint8_t d7,
  239. uint8_t en, uint8_t cs1, uint8_t cs2, uint8_t di, uint8_t rw, uint8_t reset)
  240. {
  241. /* fill data structure with some suitable values */
  242. u8g_init_data(u8g);
  243. u8g->dev = dev;
  244. /* assign user pins */
  245. u8g->pin_list[U8G_PI_D0] = d0;
  246. u8g->pin_list[U8G_PI_D1] = d1;
  247. u8g->pin_list[U8G_PI_D2] = d2;
  248. u8g->pin_list[U8G_PI_D3] = d3;
  249. u8g->pin_list[U8G_PI_D4] = d4;
  250. u8g->pin_list[U8G_PI_D5] = d5;
  251. u8g->pin_list[U8G_PI_D6] = d6;
  252. u8g->pin_list[U8G_PI_D7] = d7;
  253. u8g->pin_list[U8G_PI_EN] = en;
  254. u8g->pin_list[U8G_PI_CS1] = cs1;
  255. u8g->pin_list[U8G_PI_CS2] = cs2;
  256. u8g->pin_list[U8G_PI_DI] = di;
  257. u8g->pin_list[U8G_PI_RW] = rw;
  258. u8g->pin_list[U8G_PI_RESET] = reset;
  259. return u8g_Begin(u8g);
  260. }
  261. /*
  262. PIN_D0 8
  263. PIN_D1 9
  264. PIN_D2 10
  265. PIN_D3 11
  266. PIN_D4 4
  267. PIN_D5 5
  268. PIN_D6 6
  269. PIN_D7 7
  270. PIN_CS 14
  271. PIN_A0 15
  272. PIN_RESET 16
  273. PIN_WR 17
  274. PIN_RD 18
  275. u8g_InitRW8Bit(u8g, dev, d0, d1, d2, d3, d4, d5, d6, d7, cs, a0, wr, rd, reset)
  276. u8g_InitRW8Bit(u8g, dev, 8, 9, 10, 11, 4, 5, 6, 7, 14, 15, 17, 18, 16)
  277. */
  278. uint8_t u8g_InitRW8Bit(u8g_t *u8g, u8g_dev_t *dev, uint8_t d0, uint8_t d1, uint8_t d2, uint8_t d3, uint8_t d4, uint8_t d5, uint8_t d6, uint8_t d7,
  279. uint8_t cs, uint8_t a0, uint8_t wr, uint8_t rd, uint8_t reset)
  280. {
  281. /* fill data structure with some suitable values */
  282. u8g_init_data(u8g);
  283. u8g->dev = dev;
  284. /* assign user pins */
  285. u8g->pin_list[U8G_PI_D0] = d0;
  286. u8g->pin_list[U8G_PI_D1] = d1;
  287. u8g->pin_list[U8G_PI_D2] = d2;
  288. u8g->pin_list[U8G_PI_D3] = d3;
  289. u8g->pin_list[U8G_PI_D4] = d4;
  290. u8g->pin_list[U8G_PI_D5] = d5;
  291. u8g->pin_list[U8G_PI_D6] = d6;
  292. u8g->pin_list[U8G_PI_D7] = d7;
  293. u8g->pin_list[U8G_PI_CS] = cs;
  294. u8g->pin_list[U8G_PI_A0] = a0;
  295. u8g->pin_list[U8G_PI_WR] = wr;
  296. u8g->pin_list[U8G_PI_RD] = rd;
  297. u8g->pin_list[U8G_PI_RESET] = reset;
  298. return u8g_Begin(u8g);
  299. }
  300. #endif /* defined(U8G_WITH_PINLIST) */
  301. void u8g_FirstPage(u8g_t *u8g)
  302. {
  303. u8g_FirstPageLL(u8g, u8g->dev);
  304. }
  305. uint8_t u8g_NextPage(u8g_t *u8g)
  306. {
  307. if ( u8g->cursor_fn != (u8g_draw_cursor_fn)0 )
  308. {
  309. u8g->cursor_fn(u8g);
  310. }
  311. return u8g_NextPageLL(u8g, u8g->dev);
  312. }
  313. uint8_t u8g_SetContrast(u8g_t *u8g, uint8_t contrast)
  314. {
  315. return u8g_SetContrastLL(u8g, u8g->dev, contrast);
  316. }
  317. void u8g_SleepOn(u8g_t *u8g)
  318. {
  319. u8g_call_dev_fn(u8g, u8g->dev, U8G_DEV_MSG_SLEEP_ON, NULL);
  320. }
  321. void u8g_SleepOff(u8g_t *u8g)
  322. {
  323. u8g_call_dev_fn(u8g, u8g->dev, U8G_DEV_MSG_SLEEP_OFF, NULL);
  324. }
  325. void u8g_DrawPixel(u8g_t *u8g, u8g_uint_t x, u8g_uint_t y)
  326. {
  327. u8g_DrawPixelLL(u8g, u8g->dev, x, y);
  328. }
  329. void u8g_Draw8Pixel(u8g_t *u8g, u8g_uint_t x, u8g_uint_t y, uint8_t dir, uint8_t pixel)
  330. {
  331. u8g_Draw8PixelLL(u8g, u8g->dev, x, y, dir, pixel);
  332. }
  333. void u8g_Draw4TPixel(u8g_t *u8g, u8g_uint_t x, u8g_uint_t y, uint8_t dir, uint8_t pixel)
  334. {
  335. u8g_Draw4TPixelLL(u8g, u8g->dev, x, y, dir, pixel);
  336. }
  337. /* u8g_IsBBXIntersection() has been moved to u8g_clip.c */
  338. #ifdef OBSOLETE_CODE
  339. uint8_t u8g_IsBBXIntersection(u8g_t *u8g, u8g_uint_t x, u8g_uint_t y, u8g_uint_t w, u8g_uint_t h)
  340. {
  341. /* new code */
  342. u8g_dev_arg_bbx_t arg;
  343. arg.x = x;
  344. arg.y = y;
  345. arg.w = w;
  346. arg.h = h;
  347. return u8g_is_box_bbx_intersection(&(u8g->current_page), &arg);
  348. /* old code */
  349. //return u8g_IsBBXIntersectionLL(u8g, u8g->dev, x, y, w, h);
  350. }
  351. #endif
  352. /*
  353. idx: index for the palette entry (0..255)
  354. r: value for red (0..255)
  355. g: value for green (0..255)
  356. b: value for blue (0..255)
  357. */
  358. void u8g_SetColorEntry(u8g_t *u8g, uint8_t idx, uint8_t r, uint8_t g, uint8_t b)
  359. {
  360. u8g_dev_arg_irgb_t irgb;
  361. irgb.idx = idx;
  362. irgb.r = r;
  363. irgb.g = g;
  364. irgb.b = b;
  365. u8g_call_dev_fn(u8g, u8g->dev, U8G_DEV_MSG_SET_COLOR_ENTRY, &irgb);
  366. }
  367. void u8g_SetColorIndex(u8g_t *u8g, uint8_t idx)
  368. {
  369. u8g->arg_pixel.color = idx;
  370. /*u8g->color_index = idx; */ /* must be removed */
  371. }
  372. void u8g_SetHiColor(u8g_t *u8g, uint16_t rgb)
  373. {
  374. u8g->arg_pixel.color = rgb&255;
  375. u8g->arg_pixel.hi_color = rgb>>8;
  376. /*u8g->color_index = idx; */ /* must be removed */
  377. }
  378. void u8g_SetHiColorByRGB(u8g_t *u8g, uint8_t r, uint8_t g, uint8_t b)
  379. {
  380. r &= ~7;
  381. g >>= 2;
  382. b >>= 3;
  383. u8g->arg_pixel.color = b;
  384. u8g->arg_pixel.color |= (g & 7) << 5;
  385. u8g->arg_pixel.hi_color = r;
  386. u8g->arg_pixel.hi_color |= (g>>3) & 7;
  387. //u8g_SetHiColor(u8g, U8G_GET_HICOLOR_BY_RGB(r,g,b));
  388. }
  389. void u8g_SetRGB(u8g_t *u8g, uint8_t r, uint8_t g, uint8_t b)
  390. {
  391. if ( u8g->mode == U8G_MODE_R3G3B2 )
  392. {
  393. r &= 0x0e0;
  394. g &= 0x0e0;
  395. g >>= 3;
  396. b >>= 6;
  397. u8g->arg_pixel.color = r | g | b;
  398. }
  399. else if ( u8g->mode == U8G_MODE_HICOLOR )
  400. {
  401. u8g_SetHiColorByRGB(u8g, r,g,b);
  402. }
  403. else
  404. {
  405. u8g->arg_pixel.color = r;
  406. u8g->arg_pixel.hi_color = g;
  407. u8g->arg_pixel.blue = b;
  408. }
  409. }
  410. uint8_t u8g_GetColorIndex(u8g_t *u8g)
  411. {
  412. return u8g->arg_pixel.color;
  413. }
  414. uint8_t u8g_GetDefaultForegroundColor(u8g_t *u8g)
  415. {
  416. uint8_t mode;
  417. mode = u8g_GetMode(u8g);
  418. if ( mode == U8G_MODE_R3G3B2 )
  419. return 255; /* white */
  420. else if ( u8g_GetMode(u8g) == U8G_MODE_GRAY2BIT )
  421. return 3; /* max intensity */
  422. else /* if ( u8g.getMode() == U8G_MODE_BW ) */
  423. return 1; /* pixel on */
  424. return 1;
  425. }
  426. void u8g_SetDefaultForegroundColor(u8g_t *u8g)
  427. {
  428. if ( u8g->mode == U8G_MODE_HICOLOR )
  429. {
  430. u8g->arg_pixel.color = 0x0ff;
  431. u8g->arg_pixel.hi_color = 0x0ff;
  432. }
  433. else
  434. {
  435. u8g_SetColorIndex(u8g, u8g_GetDefaultForegroundColor(u8g));
  436. }
  437. }
  438. uint8_t u8g_GetDefaultBackgroundColor(u8g_t *u8g)
  439. {
  440. return 0;
  441. }
  442. void u8g_SetDefaultBackgroundColor(u8g_t *u8g)
  443. {
  444. u8g_SetColorIndex(u8g, u8g_GetDefaultBackgroundColor(u8g)); /* pixel on / black */
  445. }
  446. uint8_t u8g_GetDefaultMidColor(u8g_t *u8g)
  447. {
  448. uint8_t mode;
  449. mode = u8g_GetMode(u8g);
  450. if ( mode == U8G_MODE_R3G3B2 )
  451. return 0x06d; /* gray: 01101101 */
  452. else if ( u8g_GetMode(u8g) == U8G_MODE_GRAY2BIT )
  453. return 1; /* low mid intensity */
  454. else /* if ( u8g.getMode() == U8G_MODE_BW ) */
  455. return 1; /* pixel on */
  456. return 1; /* default */
  457. }
  458. void u8g_SetDefaultMidColor(u8g_t *u8g)
  459. {
  460. u8g_SetColorIndex(u8g, u8g_GetDefaultMidColor(u8g));
  461. }