From 2737649cef4f4651fb05b5b437185b2c44d2b4bc Mon Sep 17 00:00:00 2001 From: Harry Jeffery Date: Thu, 19 Nov 2015 23:25:33 +0000 Subject: Use fontconfig to search for fonts --- Makefile | 2 +- doc/imv.1 | 6 +++++- src/main.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++---- 3 files changed, 54 insertions(+), 6 deletions(-) diff --git a/Makefile b/Makefile index 4c8f7c0..13d9921 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ prefix = /usr CFLAGS = -W -Wall -std=gnu11 `sdl2-config --cflags` -LDFLAGS = `sdl2-config --libs` -lfreeimage -lSDL2_ttf +LDFLAGS = `sdl2-config --libs` -lfreeimage -lSDL2_ttf -lfontconfig TARGET = imv BUILDDIR = build diff --git a/doc/imv.1 b/doc/imv.1 index eb358e3..3965c8b 100644 --- a/doc/imv.1 +++ b/doc/imv.1 @@ -3,7 +3,7 @@ imv \- image viewer .SH SYNOPSIS .nf -\fBimv\fP [-rfaudh] [-n NUM] [images...] +\fBimv\fP [-rfaudh] [-n NUM] [-b COLOR] [-e FONT:SIZE] [images...] .fi .sp .SH DESCRIPTION @@ -39,6 +39,10 @@ Start at picture number NUM. .TP .BI "-b " BG Set the background color. Either 'checks' or a hex color value. +.TP +.BI "-e " FONT:SIZE +Set the font used by the overlay. FONT can be any valid system font, such as +FreeSans, FreeMono, etc. Defaults to FreeMono:24. .SH CONTROLS .sp imv can be controlled using the mouse or keyboard. diff --git a/src/main.c b/src/main.c index e4c199e..8e7f6a1 100644 --- a/src/main.c +++ b/src/main.c @@ -20,6 +20,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include #include #include +#include #include #include @@ -44,13 +45,14 @@ struct { unsigned char bg_g; unsigned char bg_b; int overlay; -} g_options = {0,0,0,0,0,0,1,0,0,0,0}; + const char *font; +} g_options = {0,0,0,0,0,0,1,0,0,0,0,"FreeMono:24"}; void print_usage(const char* name) { fprintf(stdout, "imv %s\n" - "Usage: %s [-rfaudh] [-n NUM] [-b BG] [-] [images...]\n" + "Usage: %s [-rfaudh] [-n NUM] [-b BG] [-e FONT:SIZE] [-] [images...]\n" "\n" "Flags:\n" " -: Read paths from stdin. One path per line.\n" @@ -64,6 +66,7 @@ void print_usage(const char* name) "Options:\n" " -n NUM: Start at picture number NUM.\n" " -b BG: Set the background. Either 'checks' or a hex color value.\n" + " -e FONT:SIZE: Set the font used for the overlay. Defaults to FreeMono:24" "\n" "Mouse:\n" " Click+Drag to Pan\n" @@ -111,7 +114,7 @@ void parse_args(int argc, char** argv) char* end; int n; - while((o = getopt(argc, argv, "firaudhn:b:")) != -1) { + while((o = getopt(argc, argv, "firaudhn:b:e:")) != -1) { switch(o) { case 'f': g_options.fullscreen = 1; break; case 'i': @@ -143,6 +146,9 @@ void parse_args(int argc, char** argv) } } break; + case 'e': + g_options.font = optarg; + break; case '?': fprintf(stderr, "Unknown argument '%c'. Aborting.\n", optopt); exit(1); @@ -150,6 +156,44 @@ void parse_args(int argc, char** argv) } } +TTF_Font *load_font(const char *font_spec) +{ + int font_size; + char *font_name; + + /* figure out font size from name, or default to 24 */ + char *sep = strchr(font_spec, ':'); + if(sep) { + font_name = strndup(font_spec, sep - font_spec); + font_size = strtol(sep+1, NULL, 10); + } else { + font_name = strdup(font_spec); + font_size = 24; + } + + + FcConfig *cfg = FcInitLoadConfigAndFonts(); + FcPattern *pattern = FcNameParse((const FcChar8*)font_name); + FcConfigSubstitute(cfg, pattern, FcMatchPattern); + FcDefaultSubstitute(pattern); + + TTF_Font *ret = NULL; + + FcResult result = FcResultNoMatch; + FcPattern* font = FcFontMatch(cfg, pattern, &result); + if (font) { + FcChar8 *path = NULL; + if (FcPatternGetString(font, FC_FILE, 0, &path) == FcResultMatch) { + ret = TTF_OpenFont((char*)path, font_size); + } + FcPatternDestroy(font); + } + FcPatternDestroy(pattern); + + free(font_name); + return ret; +} + int main(int argc, char** argv) { if(argc < 2) { @@ -222,7 +266,7 @@ int main(int argc, char** argv) SDL_Texture *chequered_tex = create_chequered(renderer); TTF_Init(); - TTF_Font *font = TTF_OpenFont("/usr/share/fonts/TTF/FreeSerif.ttf", 24); + TTF_Font *font = load_font(g_options.font); if(!font) { fprintf(stderr, "Error loading font: %s\n", TTF_GetError()); } -- cgit v1.2.3