| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "GrBatchFontCache.h" | 8 #include "GrBatchFontCache.h" |
| 9 #include "GrContext.h" | 9 #include "GrContext.h" |
| 10 #include "GrGpu.h" | 10 #include "GrGpu.h" |
| 11 #include "GrRectanizer.h" | 11 #include "GrRectanizer.h" |
| 12 #include "GrResourceProvider.h" | 12 #include "GrResourceProvider.h" |
| 13 #include "GrSurfacePriv.h" | 13 #include "GrSurfacePriv.h" |
| 14 #include "SkString.h" | 14 #include "SkString.h" |
| 15 | 15 |
| 16 #include "SkDistanceFieldGen.h" | 16 #include "SkDistanceFieldGen.h" |
| 17 #include "GrDistanceFieldGenFromVector.h" | |
| 18 | 17 |
| 19 bool GrBatchFontCache::initAtlas(GrMaskFormat format) { | 18 bool GrBatchFontCache::initAtlas(GrMaskFormat format) { |
| 20 int index = MaskFormatToAtlasIndex(format); | 19 int index = MaskFormatToAtlasIndex(format); |
| 21 if (!fAtlases[index]) { | 20 if (!fAtlases[index]) { |
| 22 GrPixelConfig config = MaskFormatToPixelConfig(format, *fContext->caps()
); | 21 GrPixelConfig config = MaskFormatToPixelConfig(format, *fContext->caps()
); |
| 23 int width = fAtlasConfigs[index].fWidth; | 22 int width = fAtlasConfigs[index].fWidth; |
| 24 int height = fAtlasConfigs[index].fHeight; | 23 int height = fAtlasConfigs[index].fHeight; |
| 25 int numPlotsX = fAtlasConfigs[index].numPlotsX(); | 24 int numPlotsX = fAtlasConfigs[index].numPlotsX(); |
| 26 int numPlotsY = fAtlasConfigs[index].numPlotsY(); | 25 int numPlotsY = fAtlasConfigs[index].numPlotsY(); |
| 27 | 26 |
| (...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 263 dst = (char*)dst + dstRB; | 262 dst = (char*)dst + dstRB; |
| 264 } | 263 } |
| 265 } | 264 } |
| 266 return true; | 265 return true; |
| 267 } | 266 } |
| 268 | 267 |
| 269 static bool get_packed_glyph_df_image(SkGlyphCache* cache, const SkGlyph& glyph, | 268 static bool get_packed_glyph_df_image(SkGlyphCache* cache, const SkGlyph& glyph, |
| 270 int width, int height, void* dst) { | 269 int width, int height, void* dst) { |
| 271 SkASSERT(glyph.fWidth + 2*SK_DistanceFieldPad == width); | 270 SkASSERT(glyph.fWidth + 2*SK_DistanceFieldPad == width); |
| 272 SkASSERT(glyph.fHeight + 2*SK_DistanceFieldPad == height); | 271 SkASSERT(glyph.fHeight + 2*SK_DistanceFieldPad == height); |
| 273 const SkPath* path = cache->findPath(glyph); | 272 const void* image = cache->findImage(glyph); |
| 274 if (nullptr == path) { | 273 if (nullptr == image) { |
| 274 return false; |
| 275 } |
| 276 // now generate the distance field |
| 277 SkASSERT(dst); |
| 278 SkMask::Format maskFormat = static_cast<SkMask::Format>(glyph.fMaskFormat); |
| 279 if (SkMask::kA8_Format == maskFormat) { |
| 280 // make the distance field from the image |
| 281 SkGenerateDistanceFieldFromA8Image((unsigned char*)dst, |
| 282 (unsigned char*)image, |
| 283 glyph.fWidth, glyph.fHeight, |
| 284 glyph.rowBytes()); |
| 285 } else if (SkMask::kBW_Format == maskFormat) { |
| 286 // make the distance field from the image |
| 287 SkGenerateDistanceFieldFromBWImage((unsigned char*)dst, |
| 288 (unsigned char*)image, |
| 289 glyph.fWidth, glyph.fHeight, |
| 290 glyph.rowBytes()); |
| 291 } else { |
| 275 return false; | 292 return false; |
| 276 } | 293 } |
| 277 | 294 |
| 278 // now generate the distance field | 295 return true; |
| 279 SkASSERT(dst); | |
| 280 SkMatrix drawMatrix; | |
| 281 drawMatrix.setTranslate((SkScalar)-glyph.fLeft, (SkScalar)-glyph.fTop); | |
| 282 | |
| 283 // Generate signed distance field directly from SkPath | |
| 284 return GrGenerateDistanceFieldFromPath((unsigned char*)dst, | |
| 285 *path, drawMatrix, | |
| 286 width, height, width * sizeof(unsigne
d char)); | |
| 287 } | 296 } |
| 288 | 297 |
| 289 /////////////////////////////////////////////////////////////////////////////// | 298 /////////////////////////////////////////////////////////////////////////////// |
| 290 | 299 |
| 291 /* | 300 /* |
| 292 The text strike is specific to a given font/style/matrix setup, which is | 301 The text strike is specific to a given font/style/matrix setup, which is |
| 293 represented by the GrHostFontScaler object we are given in getGlyph(). | 302 represented by the GrHostFontScaler object we are given in getGlyph(). |
| 294 | 303 |
| 295 We map a 32bit glyphID to a GrGlyph record, which in turn points to a | 304 We map a 32bit glyphID to a GrGlyph record, which in turn points to a |
| 296 atlas and a position within that texture. | 305 atlas and a position within that texture. |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 372 | 381 |
| 373 bool success = fBatchFontCache->addToAtlas(this, &glyph->fID, target, expect
edMaskFormat, | 382 bool success = fBatchFontCache->addToAtlas(this, &glyph->fID, target, expect
edMaskFormat, |
| 374 glyph->width(), glyph->height(), | 383 glyph->width(), glyph->height(), |
| 375 storage.get(), &glyph->fAtlasLoca
tion); | 384 storage.get(), &glyph->fAtlasLoca
tion); |
| 376 if (success) { | 385 if (success) { |
| 377 SkASSERT(GrBatchAtlas::kInvalidAtlasID != glyph->fID); | 386 SkASSERT(GrBatchAtlas::kInvalidAtlasID != glyph->fID); |
| 378 fAtlasedGlyphs++; | 387 fAtlasedGlyphs++; |
| 379 } | 388 } |
| 380 return success; | 389 return success; |
| 381 } | 390 } |
| OLD | NEW |