X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Flibgame%2Ftext.c;h=23de7cac548849a90e4c395a35391e9b0b1fb640;hp=c8cc667dd98db66e2ce72fbe702965c1bb3c8051;hb=359536f46007d1b9148bed9c529056faa91b8aab;hpb=0868de4751d9e3d4b2f3185c52edb5569217d39a diff --git a/src/libgame/text.c b/src/libgame/text.c index c8cc667d..23de7cac 100644 --- a/src/libgame/text.c +++ b/src/libgame/text.c @@ -107,11 +107,13 @@ static void FreeFontClipmasks() #endif /* TARGET_X11_NATIVE_PERFORMANCE_WORKAROUND */ void InitFontInfo(struct FontBitmapInfo *font_bitmap_info, int num_fonts, - int (*select_font_function)(int)) + int (*select_font_function)(int), + int (*get_font_from_token_function)(char *)) { gfx.num_fonts = num_fonts; gfx.font_bitmap_info = font_bitmap_info; gfx.select_font_function = select_font_function; + gfx.get_font_from_token_function = get_font_from_token_function; #if defined(TARGET_X11_NATIVE_PERFORMANCE_WORKAROUND) InitFontClipmasks(); @@ -186,13 +188,38 @@ void getFontCharSource(int font_nr, char c, Bitmap **bitmap, int *x, int *y) } +/* ========================================================================= */ +/* text string helper functions */ +/* ========================================================================= */ + +int maxWordLengthInString(char *text) +{ + char *text_ptr; + int max_word_len = 0; + + for (text_ptr = text; *text_ptr; text_ptr++) + max_word_len = (*text_ptr != ' ' ? max_word_len + 1 : 0); + + return max_word_len; +} + + /* ========================================================================= */ /* simple text drawing functions */ /* ========================================================================= */ -void DrawInitText(char *text, int ypos, int font_nr) +void DrawInitTextExt(char *text, int ypos, int font_nr, boolean force) { + static unsigned long progress_delay = 0; + unsigned long progress_delay_value = 100; /* (in milliseconds) */ + + UPDATE_BUSY_STATE(); + + if (!force && !DelayReached(&progress_delay, progress_delay_value)) + return; + if (window != NULL && + gfx.draw_init_text && gfx.num_fonts > 0 && gfx.font_bitmap_info[font_nr].bitmap != NULL) { @@ -209,6 +236,16 @@ void DrawInitText(char *text, int ypos, int font_nr) } } +void DrawInitText(char *text, int ypos, int font_nr) +{ + DrawInitTextExt(text, ypos, font_nr, TRUE); +} + +void DrawInitTextIfNeeded(char *text, int ypos, int font_nr) +{ + DrawInitTextExt(text, ypos, font_nr, FALSE); +} + void DrawTextF(int x, int y, int font_nr, char *format, ...) { char buffer[MAX_OUTPUT_LINESIZE + 1]; @@ -707,7 +744,8 @@ static boolean getCheckedTokenValueFromString(char *string, char **token, } static void DrawTextBuffer_Flush(int x, int y, char *buffer, int font_nr, - int line_length, int cut_length, int mask_mode, + int line_length, int cut_length, + int line_spacing, int mask_mode, boolean centered, int current_line) { int buffer_len = strlen(buffer); @@ -718,7 +756,7 @@ static void DrawTextBuffer_Flush(int x, int y, char *buffer, int font_nr, (centered ? font_width * (line_length - buffer_len) / 2 : 0); int final_cut_length = MAX(0, cut_length - offset_chars); int xx = x + offset_xsize; - int yy = y + current_line * font_height; + int yy = y + current_line * (font_height + line_spacing); buffer[final_cut_length] = '\0'; @@ -730,8 +768,8 @@ static void DrawTextBuffer_Flush(int x, int y, char *buffer, int font_nr, int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, int line_length, int cut_length, int max_lines, - int mask_mode, boolean autowrap, boolean centered, - boolean skip_comments) + int line_spacing, int mask_mode, boolean autowrap, + boolean centered, boolean parse_comments) { #if 0 int font_width = getFontWidth(font_nr); @@ -776,7 +814,7 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, text_buffer++; /* skip comments (lines directly beginning with '#') */ - if (line[0] == '#' && skip_comments) + if (line[0] == '#' && parse_comments) { char *token, *value; @@ -787,7 +825,7 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, if (buffer_len > 0 && current_line < max_lines) { DrawTextBuffer_Flush(x, y, buffer, font_nr, line_length, cut_length, - mask_mode, centered, current_line); + line_spacing, mask_mode, centered, current_line); current_line++; @@ -795,12 +833,14 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, buffer_len = 0; } - if (strEqual(token, ".autowrap")) + if (strEqual(token, ".font")) + font_nr = gfx.get_font_from_token_function(value); + else if (strEqual(token, ".autowrap")) autowrap = get_boolean_from_string(value); else if (strEqual(token, ".centered")) centered = get_boolean_from_string(value); - else if (strEqual(token, ".skip_comments")) - skip_comments = get_boolean_from_string(value); + else if (strEqual(token, ".parse_comments")) + parse_comments = get_boolean_from_string(value); } continue; @@ -853,7 +893,7 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, { #if 1 DrawTextBuffer_Flush(x, y, buffer, font_nr, line_length, cut_length, - mask_mode, centered, current_line); + line_spacing, mask_mode, centered, current_line); #else int offset_chars = (centered ? (line_length - buffer_len) / 2 : 0); int offset_xsize = @@ -884,7 +924,7 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, { #if 1 DrawTextBuffer_Flush(x, y, buffer, font_nr, line_length, cut_length, - mask_mode, centered, current_line); + line_spacing, mask_mode, centered, current_line); #else int offset_chars = (centered ? (line_length - buffer_len) / 2 : 0); int offset_xsize = @@ -909,14 +949,14 @@ int DrawTextBuffer(int x, int y, char *text_buffer, int font_nr, int DrawTextFile(int x, int y, char *filename, int font_nr, int line_length, int cut_length, int max_lines, - int mask_mode, boolean autowrap, boolean centered, - boolean skip_comments) + int line_spacing, int mask_mode, boolean autowrap, + boolean centered, boolean parse_comments) { char *text_buffer = GetTextBufferFromFile(filename, MAX_LINES_FROM_FILE); int num_lines_printed = DrawTextBuffer(x, y, text_buffer, font_nr, line_length, cut_length, max_lines, - mask_mode, autowrap, centered, - skip_comments); + line_spacing, mask_mode, autowrap, + centered, parse_comments); checked_free(text_buffer); return num_lines_printed;