X-Git-Url: https://git.karo-electronics.de/?p=oswald.git;a=blobdiff_plain;f=ui%2Foswald_graphics.c;h=eef4536a7c0fbc6be92be8b0a1e9abd98aaa8ab9;hp=304aa7af6154c31939ac6c1322781a7815c2b93e;hb=16600ff42846105227c8a3cbb4f2b818ca41811d;hpb=1553c23cf33de5d8a193ffc8c7014cf826fc9fd3 diff --git a/ui/oswald_graphics.c b/ui/oswald_graphics.c index 304aa7a..eef4536 100644 --- a/ui/oswald_graphics.c +++ b/ui/oswald_graphics.c @@ -1,30 +1,80 @@ -#include "oswald-ui.h" +#include "oswald.h" #include "oswald_strings.h" #include "oswald_fonts.h" +#include "oswald_hal.h" #include "oswald_graphics.h" +// dummies for MW replacement stuff + +void SetFont(etFontType Type) +{ +} + +u8t WriteLcdString(const uint8_t x, const uint8_t y, const char *str) +{ + return 1; +} + +void WriteLcdNumber(const uint8_t x, const uint8_t y, const int16_t number) +{ +} + +u8t WriteLcdCharacter(const uint8_t x, const uint8_t y, const uint8_t Character) +{ + return 1; +} + + +void oswald_draw_bitmap_offset(const unsigned int xstart, const unsigned int ystart, const unsigned int xoff, const unsigned int yoff, const unsigned int width, const unsigned int height, const void *bmp) +{ + unsigned int x, y; + uint8_t *cb; + + if (bmp == NULL) + return; + + // we only draw set pixel, unset pixel remain as they are + for (y=yoff; ydy) { - pdx = incx; pdy = 0; - ddx=incx; ddy=incy; - es =dy; el =dx; + pdx = incx; + pdy = 0; + ddx=incx; + ddy=incy; + es =dy; + el =dx; } else { - pdx=0; pdy=incy; - ddx=incx; ddy=incy; - es =dx; el =dy; + pdx=0; + pdy=incy; + ddx=incx; + ddy=incy; + es =dx; + el =dy; } x = xstart; @@ -121,10 +177,10 @@ void oswald_draw_line_ww(u8t xstart, u8t ystart, u8t xend, u8t yend, u8t thickne hal_lcd_set_pixel(x, y+i, TRUE); } } - hal_lcd_update_display(); + // hal_lcd_update_display(); } -u8t oswald_write_character(u8t x, u8t y, oswald_font_face face, u8t Character) +uint8_t oswald_write_character(const uint8_t x, const uint8_t y, const oswald_font_face face, const uint8_t Character) { #if 0 u8t CharacterHeight = GetCharacterHeight(); @@ -140,25 +196,44 @@ u8t oswald_write_character(u8t x, u8t y, oswald_font_face face, u8t Character) if (bitmap[ly] & (1< 0 ? (8-(oswald_fonts[face].width % 8)) : 0, 0, ((oswald_fonts[face].width / 8) + ((oswald_fonts[face].width % 8) ? 1 : 0))*8, oswald_fonts[face].height, cdata); + + return oswald_fonts[face].width; +#endif } -void oswald_write_string(u8t x, u8t y, oswald_font_face face, u8t *str) +void oswald_write_string(const uint8_t x, const uint8_t y, const oswald_font_face face, char *str) { - register lx, i, strl; + uint8_t lx, i, strl; strl = oswald_strlen(str); if (strl == 0) @@ -166,15 +241,15 @@ void oswald_write_string(u8t x, u8t y, oswald_font_face face, u8t *str) lx = x; for (i=0; i