mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-25 16:37:00 +00:00
Merge pull request #300 from dulsi/master
Add optional fontconfig support.
This commit is contained in:
commit
c03e9cfeb4
4
Makefile
4
Makefile
@ -102,6 +102,10 @@ ifeq (${TOOLCHAIN},mingw)
|
|||||||
CXXFLAGS_EARLY += -Wno-invalid-offsetof
|
CXXFLAGS_EARLY += -Wno-invalid-offsetof
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq (${FONTCONFIG},1)
|
||||||
|
CXXFLAGS_EARLY += -DFONTCONFIG `pkg-config --cflags fontconfig`
|
||||||
|
LDFLAGS_EARLY += `pkg-config --libs fontconfig`
|
||||||
|
endif
|
||||||
|
|
||||||
## We have now finished OS-specific and TOOLCHAIN-specific computations.
|
## We have now finished OS-specific and TOOLCHAIN-specific computations.
|
||||||
## Begin customization points for user-specifiable HYPERROGUE_USE_XXX macros.
|
## Begin customization points for user-specifiable HYPERROGUE_USE_XXX macros.
|
||||||
|
@ -6,6 +6,10 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "hyper.h"
|
#include "hyper.h"
|
||||||
|
#ifdef FONTCONFIG
|
||||||
|
#include <fontconfig/fontconfig.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace hr {
|
namespace hr {
|
||||||
|
|
||||||
#if HDR
|
#if HDR
|
||||||
@ -216,12 +220,43 @@ EX void present_screen() {
|
|||||||
|
|
||||||
#if CAP_SDLTTF
|
#if CAP_SDLTTF
|
||||||
|
|
||||||
EX string fontpath = ISWEB ? "sans-serif" : HYPERFONTPATH "DejaVuSans-Bold.ttf";
|
string fontdefault = "DejaVuSans-Bold.ttf";
|
||||||
|
EX string fontpath = ISWEB ? "sans-serif" : string(HYPERFONTPATH) + fontdefault;
|
||||||
|
|
||||||
|
string findfont() {
|
||||||
|
string answer = fontpath;
|
||||||
|
#ifdef FONTCONFIG
|
||||||
|
if ((answer.length() < fontdefault.length()) || (0 != answer.compare(answer.length() - fontdefault.length(), fontdefault.length(), fontdefault))) {
|
||||||
|
return answer;
|
||||||
|
}
|
||||||
|
FcPattern *pat;
|
||||||
|
FcResult result;
|
||||||
|
if (!FcInit()) {
|
||||||
|
return answer;
|
||||||
|
}
|
||||||
|
pat = FcNameParse((FcChar8 *)fontdefault.c_str());
|
||||||
|
FcConfigSubstitute(0, pat, FcMatchPattern);
|
||||||
|
FcDefaultSubstitute(pat);
|
||||||
|
|
||||||
|
FcPattern *match;
|
||||||
|
match = FcFontMatch(0, pat, &result);
|
||||||
|
if (match) {
|
||||||
|
FcChar8 *file;
|
||||||
|
if (FcPatternGetString(match, FC_FILE, 0, &file) == FcResultMatch) {
|
||||||
|
answer = (const char *)file;
|
||||||
|
}
|
||||||
|
FcPatternDestroy(match);
|
||||||
|
}
|
||||||
|
FcPatternDestroy(pat);
|
||||||
|
FcFini();
|
||||||
|
#endif
|
||||||
|
return answer;
|
||||||
|
}
|
||||||
|
|
||||||
void loadfont(int siz) {
|
void loadfont(int siz) {
|
||||||
fix_font_size(siz);
|
fix_font_size(siz);
|
||||||
if(!font[siz]) {
|
if(!font[siz]) {
|
||||||
font[siz] = TTF_OpenFont(fontpath.c_str(), siz);
|
font[siz] = TTF_OpenFont(findfont().c_str(), siz);
|
||||||
// Destination set by ./configure (in the GitHub repository)
|
// Destination set by ./configure (in the GitHub repository)
|
||||||
#ifdef FONTDESTDIR
|
#ifdef FONTDESTDIR
|
||||||
if (font[siz] == NULL) {
|
if (font[siz] == NULL) {
|
||||||
|
Loading…
Reference in New Issue
Block a user