X-Git-Url: https://git.karo-electronics.de/?p=oswald.git;a=blobdiff_plain;f=ui%2Foswald_graphics.c;h=eef4536a7c0fbc6be92be8b0a1e9abd98aaa8ab9;hp=36894abeb49a842c8ffb5da326bafe86ef37d6c3;hb=16600ff42846105227c8a3cbb4f2b818ca41811d;hpb=dff6532fd5dbbd4a6c2f0fff2c428201b225c529 diff --git a/ui/oswald_graphics.c b/ui/oswald_graphics.c index 36894ab..eef4536 100644 --- a/ui/oswald_graphics.c +++ b/ui/oswald_graphics.c @@ -1,11 +1,78 @@ -#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 oswald_draw_Line(u8t xstart, u8t ystart, u8t xend, u8t yend) +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; y = ystart; err = el/2; - lcd_set_pixel(x, y, TRUE); + hal_lcd_set_pixel(x, y, TRUE); for (i=1; i 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) @@ -149,15 +241,15 @@ void oswald_write_string(u8t x, u8t y, oswald_font_face face, u8t *str) lx = x; for (i=0; i