/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkFontMgr_android_DEFINED
#define SkFontMgr_android_DEFINED
#include "SkTypes.h"
class SkFontMgr;
/**
* For test only -- this only affects the default factory.
* Load font config from given xml files, instead of those from Android system.
*/
SK_API void SkUseTestFontConfigFile(const char* mainconf, const char* fallbackconf,
const char* fontsdir);
struct SkFontMgr_Android_CustomFonts {
/** When specifying custom fonts, indicates how to use system fonts. */
enum SystemFontUse {
kOnlyCustom, /** Use only custom fonts. NDK compliant. */
kPreferCustom, /** Use custom fonts before system fonts. */
kPreferSystem /** Use system fonts before custom fonts. */
};
/** Whether or not to use system fonts. */
SystemFontUse fSystemFontUse;
/** Base path to resolve relative font file names. If a directory, should end with '/'. */
const char* fBasePath;
/** Optional custom configuration file to use. */
const char* fFontsXml;
/** Optional custom configuration file for fonts which provide fallback.
* In the new style (version > 21) fontsXml format is used, this should be NULL.
*/
const char* fFallbackFontsXml;
/** Optional custom flag. If set to true the SkFontMgr will acquire all requisite
* system IO resources on initialization.
*/
bool fIsolated;
};
/** Create a font manager for Android. If 'custom' is NULL, use only system fonts. */
SK_API SkFontMgr* SkFontMgr_New_Android(const SkFontMgr_Android_CustomFonts* custom);
#endif // SkFontMgr_android_DEFINED