1 /* 2 * Copyright 2011 Google Inc. 3 * 4 * Use of this source code is governed by a BSD-style license that can be 5 * found in the LICENSE file. 6 */ 7 8 9 #ifndef SkPDFFont_DEFINED 10 #define SkPDFFont_DEFINED 11 12 #include "SkAdvancedTypefaceMetrics.h" 13 #include "SkBitSet.h" 14 #include "SkPDFTypes.h" 15 #include "SkTDArray.h" 16 #include "SkTypeface.h" 17 18 class SkAutoGlyphCache; 19 class SkPDFCanon; 20 class SkPDFFont; 21 22 /** \class SkPDFFont 23 A PDF Object class representing a font. The font may have resources 24 attached to it in order to embed the font. SkPDFFonts are canonicalized 25 so that resource deduplication will only include one copy of a font. 26 This class uses the same pattern as SkPDFGraphicState, a static weak 27 reference to each instantiated class. 28 */ 29 class SkPDFFont : public SkPDFDict { 30 31 public: 32 ~SkPDFFont() override; 33 34 /** Returns the typeface represented by this class. Returns nullptr for the 35 * default typeface. 36 */ typeface()37 SkTypeface* typeface() const { return fTypeface.get(); } 38 39 /** Returns the font type represented in this font. For Type0 fonts, 40 * returns the type of the decendant font. 41 */ getType()42 SkAdvancedTypefaceMetrics::FontType getType() const { return fFontType; } 43 44 static SkAdvancedTypefaceMetrics::FontType FontType(const SkAdvancedTypefaceMetrics&); 45 IsMultiByte(SkAdvancedTypefaceMetrics::FontType type)46 static bool IsMultiByte(SkAdvancedTypefaceMetrics::FontType type) { 47 return type == SkAdvancedTypefaceMetrics::kType1CID_Font || 48 type == SkAdvancedTypefaceMetrics::kTrueType_Font; 49 } 50 51 static SkAutoGlyphCache MakeVectorCache(SkTypeface*, int* sizeOut); 52 53 /** Returns true if this font encoding supports glyph IDs above 255. 54 */ multiByteGlyphs()55 bool multiByteGlyphs() const { return SkPDFFont::IsMultiByte(this->getType()); } 56 57 /** Return true if this font has an encoding for the passed glyph id. 58 */ hasGlyph(SkGlyphID gid)59 bool hasGlyph(SkGlyphID gid) { 60 return (gid >= fFirstGlyphID && gid <= fLastGlyphID) || gid == 0; 61 } 62 63 /** Convert the input glyph ID into the font encoding. */ glyphToPDFFontEncoding(SkGlyphID gid)64 SkGlyphID glyphToPDFFontEncoding(SkGlyphID gid) const { 65 if (this->multiByteGlyphs() || gid == 0) { 66 return gid; 67 } 68 SkASSERT(gid >= fFirstGlyphID && gid <= fLastGlyphID); 69 SkASSERT(fFirstGlyphID > 0); 70 return gid - fFirstGlyphID + 1; 71 } 72 noteGlyphUsage(SkGlyphID glyph)73 void noteGlyphUsage(SkGlyphID glyph) { 74 SkASSERT(this->hasGlyph(glyph)); 75 fGlyphUsage.set(glyph); 76 } 77 78 /** Get the font resource for the passed typeface and glyphID. The 79 * reference count of the object is incremented and it is the caller's 80 * responsibility to unreference it when done. This is needed to 81 * accommodate the weak reference pattern used when the returned object 82 * is new and has no other references. 83 * @param typeface The typeface to find, not nullptr. 84 * @param glyphID Specify which section of a large font is of interest. 85 */ 86 static SkPDFFont* GetFontResource(SkPDFCanon* canon, 87 SkTypeface* typeface, 88 SkGlyphID glyphID); 89 90 /** Uses (kGlyphNames_PerGlyphInfo | kToUnicode_PerGlyphInfo) to get 91 * SkAdvancedTypefaceMetrics, and caches the result. 92 * @param typeface can not be nullptr. 93 * @return nullptr only when typeface is bad. 94 */ 95 static const SkAdvancedTypefaceMetrics* GetMetrics(SkTypeface* typeface, 96 SkPDFCanon* canon); 97 98 /** Subset the font based on current usage. 99 * Must be called before emitObject(). 100 */ 101 virtual void getFontSubset(SkPDFCanon*) = 0; 102 103 /** 104 * Return false iff the typeface has its NotEmbeddable flag set. 105 * typeface is not nullptr 106 */ 107 static bool CanEmbedTypeface(SkTypeface*, SkPDFCanon*); 108 109 protected: 110 // Common constructor to handle common members. 111 struct Info { 112 sk_sp<SkTypeface> fTypeface; 113 SkGlyphID fFirstGlyphID; 114 SkGlyphID fLastGlyphID; 115 SkAdvancedTypefaceMetrics::FontType fFontType; 116 }; 117 SkPDFFont(Info); 118 firstGlyphID()119 SkGlyphID firstGlyphID() const { return fFirstGlyphID; } lastGlyphID()120 SkGlyphID lastGlyphID() const { return fLastGlyphID; } glyphUsage()121 const SkBitSet& glyphUsage() const { return fGlyphUsage; } refTypeface()122 sk_sp<SkTypeface> refTypeface() const { return fTypeface; } 123 124 void drop() override; 125 126 private: 127 sk_sp<SkTypeface> fTypeface; 128 SkBitSet fGlyphUsage; 129 130 // The glyph IDs accessible with this font. For Type1 (non CID) fonts, 131 // this will be a subset if the font has more than 255 glyphs. 132 const SkGlyphID fFirstGlyphID; 133 const SkGlyphID fLastGlyphID; 134 const SkAdvancedTypefaceMetrics::FontType fFontType; 135 136 typedef SkPDFDict INHERITED; 137 }; 138 139 #endif 140