fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2014 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 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 8 | /* Generated by tools/bookmaker from include/core/SkTextBlob.h and docs/SkTextBlob_Reference.bmh |
| 9 | on 2018-08-10 12:59:44. Additional documentation and examples can be found at: |
| 10 | https://skia.org/user/api/SkTextBlob_Reference |
| 11 | |
| 12 | You may edit either file directly. Structural changes to public interfaces require |
| 13 | editing both files. After editing docs/SkTextBlob_Reference.bmh, run: |
| 14 | bookmaker -b docs -i include/core/SkTextBlob.h -p |
| 15 | to create an updated version of this file. |
| 16 | */ |
| 17 | |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 18 | #ifndef SkTextBlob_DEFINED |
| 19 | #define SkTextBlob_DEFINED |
| 20 | |
bungeman | bf521ff | 2016-02-17 13:13:44 -0800 | [diff] [blame] | 21 | #include "../private/SkTemplates.h" |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 22 | #include "SkFont.h" |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 23 | #include "SkPaint.h" |
halcanary | 4f0a23a | 2016-08-30 11:58:33 -0700 | [diff] [blame] | 24 | #include "SkString.h" |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 25 | #include "SkRefCnt.h" |
Hal Canary | c2d0fb1 | 2018-09-19 10:28:59 -0400 | [diff] [blame] | 26 | |
Mike Klein | 015c899 | 2018-08-09 12:23:19 -0400 | [diff] [blame] | 27 | #include <atomic> |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 28 | |
Mike Reed | 8e74cbc | 2017-12-08 13:20:01 -0500 | [diff] [blame] | 29 | struct SkSerialProcs; |
| 30 | struct SkDeserialProcs; |
| 31 | |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 32 | /** \class SkTextBlob |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 33 | SkTextBlob combines multiple text runs into an immutable container. Each text |
| 34 | run consists of glyphs, SkPaint, and position. Only parts of SkPaint related to |
| 35 | fonts and text rendering are used by run. |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 36 | */ |
Mike Klein | 408ef21 | 2018-10-30 15:23:00 +0000 | [diff] [blame] | 37 | class SK_API SkTextBlob final : public SkNVRefCnt<SkTextBlob> { |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 38 | public: |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 39 | |
| 40 | /** Returns conservative bounding box. Uses SkPaint associated with each glyph to |
| 41 | determine glyph bounds, and unions all bounds. Returned bounds may be |
| 42 | larger than the bounds of all glyphs in runs. |
| 43 | |
| 44 | @return conservative bounding box |
| 45 | */ |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 46 | const SkRect& bounds() const { return fBounds; } |
| 47 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 48 | /** Returns a non-zero value unique among all text blobs. |
| 49 | |
| 50 | @return identifier for SkTextBlob |
| 51 | */ |
joshualitt | 2af8583 | 2015-03-25 13:40:13 -0700 | [diff] [blame] | 52 | uint32_t uniqueID() const { return fUniqueID; } |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 53 | |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 54 | /** Creates SkTextBlob with a single run. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 55 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 56 | font contains attributes used to define the run text. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 57 | |
| 58 | @param text character code points or glyphs drawn |
| 59 | @param byteLength byte length of text array |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 60 | @param font text size, typeface, text scale, and so on, used to draw |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 61 | @return SkTextBlob constructed from one run |
| 62 | */ |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 63 | static sk_sp<SkTextBlob> MakeFromText(const void* text, size_t byteLength, const SkFont& font, |
Mike Reed | 97f3cc2 | 2018-12-03 09:45:17 -0500 | [diff] [blame] | 64 | SkTextEncoding encoding = kUTF8_SkTextEncoding); |
Herb Derby | 4b3a515 | 2018-07-17 16:10:30 -0400 | [diff] [blame] | 65 | |
Mike Reed | 97f3cc2 | 2018-12-03 09:45:17 -0500 | [diff] [blame] | 66 | /** Creates SkTextBlob with a single run. string meaning depends on SkTextEncoding; |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 67 | by default, string is encoded as UTF-8. |
| 68 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 69 | font contains attributes used to define the run text. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 70 | |
| 71 | @param string character code points or glyphs drawn |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 72 | @param font text size, typeface, text scale, and so on, used to draw |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 73 | @return SkTextBlob constructed from one run |
| 74 | */ |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 75 | static sk_sp<SkTextBlob> MakeFromString(const char* string, const SkFont& font, |
Mike Reed | 97f3cc2 | 2018-12-03 09:45:17 -0500 | [diff] [blame] | 76 | SkTextEncoding encoding = kUTF8_SkTextEncoding) { |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 77 | if (!string) { |
| 78 | return nullptr; |
| 79 | } |
Mike Reed | 3185f90 | 2018-10-26 16:33:00 -0400 | [diff] [blame] | 80 | return MakeFromText(string, strlen(string), font, encoding); |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 81 | } |
| 82 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 83 | /** Writes data to allow later reconstruction of SkTextBlob. memory points to storage |
| 84 | to receive the encoded data, and memory_size describes the size of storage. |
| 85 | Returns bytes used if provided storage is large enough to hold all data; |
| 86 | otherwise, returns zero. |
| 87 | |
| 88 | procs.fTypefaceProc permits supplying a custom function to encode SkTypeface. |
| 89 | If procs.fTypefaceProc is nullptr, default encoding is used. procs.fTypefaceCtx |
| 90 | may be used to provide user context to procs.fTypefaceProc; procs.fTypefaceProc |
| 91 | is called with a pointer to SkTypeface and user context. |
| 92 | |
Cary Clark | 8245649 | 2018-10-31 10:54:50 -0400 | [diff] [blame] | 93 | @param procs custom serial data encoders; may be nullptr |
| 94 | @param memory storage for data |
| 95 | @param memory_size size of storage |
| 96 | @return bytes written, or zero if required storage is larger than memory_size |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 97 | */ |
Khushal | 42f8bc4 | 2018-04-03 17:51:40 -0700 | [diff] [blame] | 98 | size_t serialize(const SkSerialProcs& procs, void* memory, size_t memory_size) const; |
| 99 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 100 | /** Returns storage containing SkData describing SkTextBlob, using optional custom |
| 101 | encoders. |
| 102 | |
| 103 | procs.fTypefaceProc permits supplying a custom function to encode SkTypeface. |
| 104 | If procs.fTypefaceProc is nullptr, default encoding is used. procs.fTypefaceCtx |
| 105 | may be used to provide user context to procs.fTypefaceProc; procs.fTypefaceProc |
| 106 | is called with a pointer to SkTypeface and user context. |
| 107 | |
| 108 | @param procs custom serial data encoders; may be nullptr |
| 109 | @return storage containing serialized SkTextBlob |
| 110 | */ |
Cary Clark | 785586a | 2018-07-19 10:07:01 -0400 | [diff] [blame] | 111 | sk_sp<SkData> serialize(const SkSerialProcs& procs) const; |
Mike Reed | aaa3056 | 2017-07-21 11:53:23 -0400 | [diff] [blame] | 112 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 113 | /** Recreates SkTextBlob that was serialized into data. Returns constructed SkTextBlob |
| 114 | if successful; otherwise, returns nullptr. Fails if size is smaller than |
| 115 | required data length, or if data does not permit constructing valid SkTextBlob. |
| 116 | |
| 117 | procs.fTypefaceProc permits supplying a custom function to decode SkTypeface. |
| 118 | If procs.fTypefaceProc is nullptr, default decoding is used. procs.fTypefaceCtx |
| 119 | may be used to provide user context to procs.fTypefaceProc; procs.fTypefaceProc |
| 120 | is called with a pointer to SkTypeface data, data byte length, and user context. |
| 121 | |
| 122 | @param data pointer for serial data |
| 123 | @param size size of data |
| 124 | @param procs custom serial data decoders; may be nullptr |
| 125 | @return SkTextBlob constructed from data in memory |
| 126 | */ |
Cary Clark | 785586a | 2018-07-19 10:07:01 -0400 | [diff] [blame] | 127 | static sk_sp<SkTextBlob> Deserialize(const void* data, size_t size, |
| 128 | const SkDeserialProcs& procs); |
Mike Reed | 8e74cbc | 2017-12-08 13:20:01 -0500 | [diff] [blame] | 129 | |
halcanary | 3377975 | 2015-10-27 14:01:05 -0700 | [diff] [blame] | 130 | private: |
Mike Klein | 408ef21 | 2018-10-30 15:23:00 +0000 | [diff] [blame] | 131 | friend class SkNVRefCnt<SkTextBlob>; |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 132 | class RunRecord; |
| 133 | |
Florin Malita | ab54e73 | 2018-07-27 09:47:15 -0400 | [diff] [blame] | 134 | enum GlyphPositioning : uint8_t; |
| 135 | |
Florin Malita | 3a9a7a3 | 2017-03-13 09:03:24 -0400 | [diff] [blame] | 136 | explicit SkTextBlob(const SkRect& bounds); |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 137 | |
mtklein | b47cd4b | 2016-08-09 12:20:04 -0700 | [diff] [blame] | 138 | ~SkTextBlob(); |
bsalomon | 0728031 | 2014-11-20 08:02:46 -0800 | [diff] [blame] | 139 | |
| 140 | // Memory for objects of this class is created with sk_malloc rather than operator new and must |
| 141 | // be freed with sk_free. |
Yong-Hwan Baek | 688a8e5 | 2018-07-09 14:14:26 +0900 | [diff] [blame] | 142 | void operator delete(void* p); |
| 143 | void* operator new(size_t); |
| 144 | void* operator new(size_t, void* p); |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 145 | |
fmalita | b742517 | 2014-08-26 07:56:44 -0700 | [diff] [blame] | 146 | static unsigned ScalarsPerGlyph(GlyphPositioning pos); |
| 147 | |
Florin Malita | 4a01ac9 | 2017-03-13 16:45:28 -0400 | [diff] [blame] | 148 | // Call when this blob is part of the key to a cache entry. This allows the cache |
| 149 | // to know automatically those entries can be purged when this SkTextBlob is deleted. |
Jim Van Verth | 474d687 | 2017-12-14 13:00:05 -0500 | [diff] [blame] | 150 | void notifyAddedToCache(uint32_t cacheID) const { |
| 151 | fCacheID.store(cacheID); |
Florin Malita | 4a01ac9 | 2017-03-13 16:45:28 -0400 | [diff] [blame] | 152 | } |
| 153 | |
Herb Derby | 8a6348e | 2018-07-12 15:30:35 -0400 | [diff] [blame] | 154 | friend class SkGlyphRunList; |
Florin Malita | 4a01ac9 | 2017-03-13 16:45:28 -0400 | [diff] [blame] | 155 | friend class GrTextBlobCache; |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 156 | friend class SkTextBlobBuilder; |
Cary Clark | 53c8769 | 2018-07-17 08:59:34 -0400 | [diff] [blame] | 157 | friend class SkTextBlobPriv; |
halcanary | 3377975 | 2015-10-27 14:01:05 -0700 | [diff] [blame] | 158 | friend class SkTextBlobRunIterator; |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 159 | |
Mike Klein | 015c899 | 2018-08-09 12:23:19 -0400 | [diff] [blame] | 160 | const SkRect fBounds; |
| 161 | const uint32_t fUniqueID; |
| 162 | mutable std::atomic<uint32_t> fCacheID; |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 163 | |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 164 | SkDEBUGCODE(size_t fStorageSize;) |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 165 | |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 166 | // The actual payload resides in externally-managed storage, following the object. |
| 167 | // (see the .cpp for more details) |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 168 | |
| 169 | typedef SkRefCnt INHERITED; |
| 170 | }; |
| 171 | |
| 172 | /** \class SkTextBlobBuilder |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 173 | Helper class for constructing SkTextBlob. |
| 174 | */ |
jbroman | 3053dfa | 2014-08-25 06:22:12 -0700 | [diff] [blame] | 175 | class SK_API SkTextBlobBuilder { |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 176 | public: |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 177 | |
| 178 | /** Constructs empty SkTextBlobBuilder. By default, SkTextBlobBuilder has no runs. |
| 179 | |
| 180 | @return empty SkTextBlobBuilder |
| 181 | */ |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 182 | SkTextBlobBuilder(); |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 183 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 184 | /** Deletes data allocated internally by SkTextBlobBuilder. |
| 185 | */ |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 186 | ~SkTextBlobBuilder(); |
| 187 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 188 | /** Returns SkTextBlob built from runs of glyphs added by builder. Returned |
| 189 | SkTextBlob is immutable; it may be copied, but its contents may not be altered. |
| 190 | Returns nullptr if no runs of glyphs were added by builder. |
| 191 | |
| 192 | Resets SkTextBlobBuilder to its initial empty state, allowing it to be |
| 193 | reused to build a new set of runs. |
| 194 | |
| 195 | @return SkTextBlob or nullptr |
| 196 | */ |
reed | 2ab9057 | 2016-08-10 14:16:41 -0700 | [diff] [blame] | 197 | sk_sp<SkTextBlob> make(); |
| 198 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 199 | /** \struct SkTextBlobBuilder::RunBuffer |
| 200 | RunBuffer supplies storage for glyphs and positions within a run. |
| 201 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 202 | A run is a sequence of glyphs sharing font metrics and positioning. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 203 | Each run may position its glyphs in one of three ways: |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 204 | by specifying where the first glyph is drawn, and allowing font metrics to |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 205 | determine the advance to subsequent glyphs; by specifying a baseline, and |
| 206 | the position on that baseline for each glyph in run; or by providing SkPoint |
| 207 | array, one per glyph. |
| 208 | */ |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 209 | struct RunBuffer { |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 210 | SkGlyphID* glyphs; //!< storage for glyphs in run |
| 211 | SkScalar* pos; //!< storage for positions in run |
| 212 | char* utf8text; //!< reserved for future use |
| 213 | uint32_t* clusters; //!< reserved for future use |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 214 | }; |
| 215 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 216 | /** Returns run with storage for glyphs. Caller must write count glyphs to |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 217 | RunBuffer::glyphs before next call to SkTextBlobBuilder. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 218 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 219 | RunBuffer::utf8text, and RunBuffer::clusters should be ignored. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 220 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 221 | Glyphs share metrics in font. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 222 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 223 | Glyphs are positioned on a baseline at (x, y), using font metrics to |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 224 | determine their relative placement. |
| 225 | |
| 226 | bounds defines an optional bounding box, used to suppress drawing when SkTextBlob |
| 227 | bounds does not intersect SkSurface bounds. If bounds is nullptr, SkTextBlob bounds |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 228 | is computed from (x, y) and RunBuffer::glyphs metrics. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 229 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 230 | @param font SkFont used for this run |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 231 | @param count number of glyphs |
| 232 | @param x horizontal offset within the blob |
| 233 | @param y vertical offset within the blob |
| 234 | @param bounds optional run bounding box |
| 235 | @return writable glyph buffer |
| 236 | */ |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 237 | const RunBuffer& allocRun(const SkFont& font, int count, SkScalar x, SkScalar y, |
| 238 | const SkRect* bounds = nullptr); |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 239 | |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 240 | /** Returns run with storage for glyphs and positions along baseline. Caller must |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 241 | write count glyphs to RunBuffer::glyphs, and count scalars to RunBuffer::pos; |
| 242 | before next call to SkTextBlobBuilder. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 243 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 244 | RunBuffer::utf8text, and RunBuffer::clusters should be ignored. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 245 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 246 | Glyphs share metrics in font. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 247 | |
| 248 | Glyphs are positioned on a baseline at y, using x-axis positions written by |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 249 | caller to RunBuffer::pos. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 250 | |
| 251 | bounds defines an optional bounding box, used to suppress drawing when SkTextBlob |
| 252 | bounds does not intersect SkSurface bounds. If bounds is nullptr, SkTextBlob bounds |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 253 | is computed from y, RunBuffer::pos, and RunBuffer::glyphs metrics. |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 254 | |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 255 | @param font SkFont used for this run |
Cary Clark | af04551 | 2018-08-10 13:11:06 -0400 | [diff] [blame] | 256 | @param count number of glyphs |
| 257 | @param y vertical offset within the blob |
| 258 | @param bounds optional run bounding box |
| 259 | @return writable glyph buffer and x-axis position buffer |
| 260 | */ |
Cary Clark | 77b3f3a | 2018-11-07 14:59:03 -0500 | [diff] [blame] | 261 | const RunBuffer& allocRunPosH(const SkFont& font, int count, SkScalar y, |
| 262 | const SkRect* bounds = nullptr); |
| 263 | |
| 264 | /** Returns run with storage for glyphs and SkPoint positions. Caller must |
| 265 | write count glyphs to RunBuffer::glyphs, and count SkPoint to RunBuffer::pos; |
| 266 | before next call to SkTextBlobBuilder. |
| 267 | |
| 268 | RunBuffer::utf8text, and RunBuffer::clusters should be ignored. |
| 269 | |
| 270 | Glyphs share metrics in font. |
| 271 | |
| 272 | Glyphs are positioned using SkPoint written by caller to RunBuffer::pos, using |
| 273 | two scalar values for each SkPoint. |
| 274 | |
| 275 | bounds defines an optional bounding box, used to suppress drawing when SkTextBlob |
| 276 | bounds does not intersect SkSurface bounds. If bounds is nullptr, SkTextBlob bounds |
| 277 | is computed from RunBuffer::pos, and RunBuffer::glyphs metrics. |
| 278 | |
| 279 | @param font SkFont used for this run |
| 280 | @param count number of glyphs |
| 281 | @param bounds optional run bounding box |
| 282 | @return writable glyph buffer and SkPoint buffer |
| 283 | */ |
| 284 | const RunBuffer& allocRunPos(const SkFont& font, int count, |
| 285 | const SkRect* bounds = nullptr); |
| 286 | |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 287 | private: |
Mike Reed | 6d59568 | 2018-12-05 17:28:14 -0500 | [diff] [blame^] | 288 | const RunBuffer& allocRunText(const SkFont& font, |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 289 | int count, |
| 290 | SkScalar x, |
| 291 | SkScalar y, |
| 292 | int textByteCount, |
| 293 | SkString lang, |
| 294 | const SkRect* bounds = nullptr); |
Mike Reed | 6d59568 | 2018-12-05 17:28:14 -0500 | [diff] [blame^] | 295 | const RunBuffer& allocRunTextPosH(const SkFont& font, int count, SkScalar y, |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 296 | int textByteCount, SkString lang, |
| 297 | const SkRect* bounds = nullptr); |
Mike Reed | 6d59568 | 2018-12-05 17:28:14 -0500 | [diff] [blame^] | 298 | const RunBuffer& allocRunTextPos(const SkFont& font, int count, |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 299 | int textByteCount, SkString lang, |
| 300 | const SkRect* bounds = nullptr); |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 301 | void reserve(size_t size); |
Mike Reed | b3f4aac | 2018-12-05 15:40:29 -0500 | [diff] [blame] | 302 | void allocInternal(const SkFont& font, SkTextBlob::GlyphPositioning positioning, |
halcanary | 4f0a23a | 2016-08-30 11:58:33 -0700 | [diff] [blame] | 303 | int count, int textBytes, SkPoint offset, const SkRect* bounds); |
Mike Reed | b3f4aac | 2018-12-05 15:40:29 -0500 | [diff] [blame] | 304 | bool mergeRun(const SkFont& font, SkTextBlob::GlyphPositioning positioning, |
Florin Malita | d923a71 | 2017-11-22 10:11:12 -0500 | [diff] [blame] | 305 | uint32_t count, SkPoint offset); |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 306 | void updateDeferredBounds(); |
| 307 | |
fmalita | 3dc40ac | 2015-01-28 10:56:06 -0800 | [diff] [blame] | 308 | static SkRect ConservativeRunBounds(const SkTextBlob::RunRecord&); |
| 309 | static SkRect TightRunBounds(const SkTextBlob::RunRecord&); |
| 310 | |
Cary Clark | e12a090 | 2018-08-09 10:07:33 -0400 | [diff] [blame] | 311 | friend class SkTextBlobPriv; |
| 312 | friend class SkTextBlobBuilderPriv; |
| 313 | |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 314 | SkAutoTMalloc<uint8_t> fStorage; |
| 315 | size_t fStorageSize; |
| 316 | size_t fStorageUsed; |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 317 | |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 318 | SkRect fBounds; |
| 319 | int fRunCount; |
| 320 | bool fDeferredBounds; |
| 321 | size_t fLastRun; // index into fStorage |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 322 | |
fmalita | 3c196de | 2014-09-20 05:40:22 -0700 | [diff] [blame] | 323 | RunBuffer fCurrentRunBuffer; |
fmalita | 00d5c2c | 2014-08-21 08:53:26 -0700 | [diff] [blame] | 324 | }; |
| 325 | |
| 326 | #endif // SkTextBlob_DEFINED |