1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2023 Google LLC 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef FontToolUtils_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define FontToolUtils_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkColor.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkFontStyle.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkRefCnt.h" 14*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkString.h" 15*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkTypeface.h" 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker class SkBitmap; 18*c8dee2aaSAndroid Build Coastguard Worker class SkImage; 19*c8dee2aaSAndroid Build Coastguard Worker class SkFont; 20*c8dee2aaSAndroid Build Coastguard Worker class SkFontMgr; 21*c8dee2aaSAndroid Build Coastguard Worker 22*c8dee2aaSAndroid Build Coastguard Worker namespace ToolUtils { 23*c8dee2aaSAndroid Build Coastguard Worker /** 24*c8dee2aaSAndroid Build Coastguard Worker * Returns a font that has a non-empty typeface. This could change, so don't depend on things like 25*c8dee2aaSAndroid Build Coastguard Worker * how it looks, font metrics, etc. 26*c8dee2aaSAndroid Build Coastguard Worker */ 27*c8dee2aaSAndroid Build Coastguard Worker SkFont DefaultPortableFont(); 28*c8dee2aaSAndroid Build Coastguard Worker 29*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> DefaultPortableTypeface(); 30*c8dee2aaSAndroid Build Coastguard Worker 31*c8dee2aaSAndroid Build Coastguard Worker /** 32*c8dee2aaSAndroid Build Coastguard Worker * Returns a platform-independent text renderer. 33*c8dee2aaSAndroid Build Coastguard Worker */ 34*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> CreatePortableTypeface(const char* name, SkFontStyle style); 35*c8dee2aaSAndroid Build Coastguard Worker 36*c8dee2aaSAndroid Build Coastguard Worker /* Return a color emoji typeface with planets to scale if available. */ 37*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> PlanetTypeface(); 38*c8dee2aaSAndroid Build Coastguard Worker 39*c8dee2aaSAndroid Build Coastguard Worker enum class EmojiFontFormat { 40*c8dee2aaSAndroid Build Coastguard Worker Cbdt, 41*c8dee2aaSAndroid Build Coastguard Worker Sbix, 42*c8dee2aaSAndroid Build Coastguard Worker ColrV0, 43*c8dee2aaSAndroid Build Coastguard Worker Test, 44*c8dee2aaSAndroid Build Coastguard Worker Svg 45*c8dee2aaSAndroid Build Coastguard Worker }; 46*c8dee2aaSAndroid Build Coastguard Worker 47*c8dee2aaSAndroid Build Coastguard Worker struct EmojiTestSample { 48*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> typeface = nullptr; 49*c8dee2aaSAndroid Build Coastguard Worker const char* sampleText = ""; 50*c8dee2aaSAndroid Build Coastguard Worker }; 51*c8dee2aaSAndroid Build Coastguard Worker 52*c8dee2aaSAndroid Build Coastguard Worker /** Return a color emoji typeface if available. */ 53*c8dee2aaSAndroid Build Coastguard Worker EmojiTestSample EmojiSample(); 54*c8dee2aaSAndroid Build Coastguard Worker 55*c8dee2aaSAndroid Build Coastguard Worker /** Return a color emoji typeface of a specific color font format if available. */ 56*c8dee2aaSAndroid Build Coastguard Worker EmojiTestSample EmojiSample(EmojiFontFormat format); 57*c8dee2aaSAndroid Build Coastguard Worker 58*c8dee2aaSAndroid Build Coastguard Worker /** Return a string representation of the requeste format. Useful for suffixing test names. */ 59*c8dee2aaSAndroid Build Coastguard Worker SkString NameForFontFormat(EmojiFontFormat format); 60*c8dee2aaSAndroid Build Coastguard Worker 61*c8dee2aaSAndroid Build Coastguard Worker /** A simple SkUserTypeface for testing. */ 62*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> SampleUserTypeface(); 63*c8dee2aaSAndroid Build Coastguard Worker 64*c8dee2aaSAndroid Build Coastguard Worker SkBitmap CreateStringBitmap(int w, int h, SkColor c, int x, int y, int textSize, const char* str); 65*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkImage> CreateStringImage(int w, int h, SkColor c, int x, int y, int textSize, const char* str); 66*c8dee2aaSAndroid Build Coastguard Worker 67*c8dee2aaSAndroid Build Coastguard Worker // This returns the SkFontMgr that has been compiled in and configured (e.g. via CLI flag) 68*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkFontMgr> TestFontMgr(); 69*c8dee2aaSAndroid Build Coastguard Worker 70*c8dee2aaSAndroid Build Coastguard Worker // Must be called before the first call to TestFontMgr to have any effect. 71*c8dee2aaSAndroid Build Coastguard Worker void UsePortableFontMgr(); 72*c8dee2aaSAndroid Build Coastguard Worker 73*c8dee2aaSAndroid Build Coastguard Worker // Returns true if this platform is Windows and this binary is being configured to run 74*c8dee2aaSAndroid Build Coastguard Worker // with the GDI font manager. 75*c8dee2aaSAndroid Build Coastguard Worker bool FontMgrIsGDI(); 76*c8dee2aaSAndroid Build Coastguard Worker 77*c8dee2aaSAndroid Build Coastguard Worker // This returns the default SkTypeface returned by the TestFontMgr(). If there was no default 78*c8dee2aaSAndroid Build Coastguard Worker // Typeface, DefaultPortableTypeface() is returned instead. 79*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> DefaultTypeface(); 80*c8dee2aaSAndroid Build Coastguard Worker 81*c8dee2aaSAndroid Build Coastguard Worker // Returns a Typeface matching the given criteria as returned by TestFontMgr(). This may be different 82*c8dee2aaSAndroid Build Coastguard Worker // on different platforms. 83*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> CreateTestTypeface(const char* name, SkFontStyle style); 84*c8dee2aaSAndroid Build Coastguard Worker 85*c8dee2aaSAndroid Build Coastguard Worker // Load the resource with the provided name as a Typeface using TestFontMgr(). 86*c8dee2aaSAndroid Build Coastguard Worker sk_sp<SkTypeface> CreateTypefaceFromResource(const char* resource, int ttcIndex = 0); 87*c8dee2aaSAndroid Build Coastguard Worker 88*c8dee2aaSAndroid Build Coastguard Worker // This returns a font using DefaultTypeface() 89*c8dee2aaSAndroid Build Coastguard Worker SkFont DefaultFont(); 90*c8dee2aaSAndroid Build Coastguard Worker 91*c8dee2aaSAndroid Build Coastguard Worker } // namespace ToolUtils 92*c8dee2aaSAndroid Build Coastguard Worker 93*c8dee2aaSAndroid Build Coastguard Worker #endif 94