diff options
-rw-r--r-- | src/main.c | 2 | ||||
-rw-r--r-- | src/text.c | 19 | ||||
-rw-r--r-- | src/text.h | 6 |
3 files changed, 25 insertions, 2 deletions
@@ -36,6 +36,8 @@ main(int argc, char **argv) font = font_find(argv[1]); text = text_new(argv[2]); + text_set_width(text, 80); + text_set_height(text, 25); image = image_new("test.png"); image_render(image, text, font); text_destroy(&text); @@ -96,6 +96,18 @@ text_get_height(struct text *text) return text->height; } +size_t +text_set_width(struct text *text, size_t width) +{ + return text->width = MAX(text->width, width); +} + +size_t +text_set_height(struct text *text, size_t height) +{ + return text->height = MAX(text->height, height); +} + void text_render(struct text *text, struct font *font, png_bytepp rows) { @@ -142,8 +154,11 @@ text_render(struct text *text, struct font *font, png_bytepp rows) ++string; } } - for (; col < text->width; ++col) { - font_render(font, &fg, &bg, ' ', rows, row, col); + for (; row < text->height; ++row) { + for (; col < text->width; ++col) { + font_render(font, &fg, &bg, ' ', rows, row, col); + } + col = 0; } free(string_start); @@ -37,6 +37,12 @@ text_get_width(struct text *text) __attribute__((pure)); size_t text_get_height(struct text *text) __attribute__((pure)); +size_t +text_set_width(struct text *text, size_t width); + +size_t +text_set_height(struct text *text, size_t height); + void text_render(struct text *text, struct font *font, png_bytepp rows); |