| Index: src/gpu/GrAtlasTextContext.cpp
|
| diff --git a/src/gpu/GrAtlasTextContext.cpp b/src/gpu/GrAtlasTextContext.cpp
|
| index 3de0ef875347ee7eff231832e80b02c4faf7afdd..337813801bf899930cdbb26779bb60a60f786f8e 100644
|
| --- a/src/gpu/GrAtlasTextContext.cpp
|
| +++ b/src/gpu/GrAtlasTextContext.cpp
|
| @@ -96,10 +96,9 @@ static inline GrColor skcolor_to_grcolor_nopremultiply(SkColor c) {
|
|
|
| };
|
|
|
| -GrAtlasTextContext::GrAtlasTextContext(GrContext* context,
|
| - GrDrawContext* drawContext,
|
| - const SkSurfaceProps& surfaceProps)
|
| - : INHERITED(context, drawContext, surfaceProps), fDistanceAdjustTable(new DistanceAdjustTable) {
|
| +GrAtlasTextContext::GrAtlasTextContext(GrContext* context, const SkSurfaceProps& surfaceProps)
|
| + : INHERITED(context, surfaceProps)
|
| + , fDistanceAdjustTable(new DistanceAdjustTable) {
|
| // We overallocate vertices in our textblobs based on the assumption that A8 has the greatest
|
| // vertexStride
|
| static_assert(kGrayTextVASize >= kColorTextVASize && kGrayTextVASize >= kLCDTextVASize,
|
| @@ -191,9 +190,8 @@ void GrAtlasTextContext::DistanceAdjustTable::buildDistanceAdjustTable() {
|
| }
|
|
|
| GrAtlasTextContext* GrAtlasTextContext::Create(GrContext* context,
|
| - GrDrawContext* drawContext,
|
| const SkSurfaceProps& surfaceProps) {
|
| - return new GrAtlasTextContext(context, drawContext, surfaceProps);
|
| + return new GrAtlasTextContext(context, surfaceProps);
|
| }
|
|
|
| bool GrAtlasTextContext::canDraw(const GrRenderTarget*,
|
| @@ -341,7 +339,7 @@ inline SkGlyphCache* GrAtlasTextContext::setupCache(GrAtlasTextBlob::Run* run,
|
| return SkGlyphCache::DetachCache(run->fTypeface, run->fDescriptor.getDesc());
|
| }
|
|
|
| -void GrAtlasTextContext::drawTextBlob(GrRenderTarget* rt,
|
| +void GrAtlasTextContext::drawTextBlob(GrDrawContext* dc, GrRenderTarget* rt,
|
| const GrClip& clip, const SkPaint& skPaint,
|
| const SkMatrix& viewMatrix, const SkTextBlob* blob,
|
| SkScalar x, SkScalar y,
|
| @@ -439,7 +437,7 @@ void GrAtlasTextContext::drawTextBlob(GrRenderTarget* rt,
|
| blob, x, y, drawFilter, clipRect, rt, clip);
|
| }
|
|
|
| - this->flush(blob, cacheBlob, rt, skPaint, grPaint, drawFilter,
|
| + this->flush(blob, cacheBlob, dc, rt, skPaint, grPaint, drawFilter,
|
| clip, viewMatrix, clipBounds, x, y, transX, transY);
|
| }
|
|
|
| @@ -789,7 +787,7 @@ GrAtlasTextContext::createDrawPosTextBlob(GrRenderTarget* rt, const GrClip& clip
|
| return blob;
|
| }
|
|
|
| -void GrAtlasTextContext::onDrawText(GrRenderTarget* rt,
|
| +void GrAtlasTextContext::onDrawText(GrDrawContext* dc, GrRenderTarget* rt,
|
| const GrClip& clip,
|
| const GrPaint& paint, const SkPaint& skPaint,
|
| const SkMatrix& viewMatrix,
|
| @@ -798,10 +796,10 @@ void GrAtlasTextContext::onDrawText(GrRenderTarget* rt,
|
| SkAutoTUnref<GrAtlasTextBlob> blob(
|
| this->createDrawTextBlob(rt, clip, paint, skPaint, viewMatrix,
|
| text, byteLength, x, y, regionClipBounds));
|
| - this->flush(blob, rt, skPaint, paint, clip, regionClipBounds);
|
| + this->flush(blob, dc, rt, skPaint, paint, clip, regionClipBounds);
|
| }
|
|
|
| -void GrAtlasTextContext::onDrawPosText(GrRenderTarget* rt,
|
| +void GrAtlasTextContext::onDrawPosText(GrDrawContext* dc, GrRenderTarget* rt,
|
| const GrClip& clip,
|
| const GrPaint& paint, const SkPaint& skPaint,
|
| const SkMatrix& viewMatrix,
|
| @@ -814,7 +812,7 @@ void GrAtlasTextContext::onDrawPosText(GrRenderTarget* rt,
|
| pos, scalarsPerPosition,
|
| offset, regionClipBounds));
|
|
|
| - this->flush(blob, rt, skPaint, paint, clip, regionClipBounds);
|
| + this->flush(blob, dc, rt, skPaint, paint, clip, regionClipBounds);
|
| }
|
|
|
| void GrAtlasTextContext::internalDrawBMPText(GrAtlasTextBlob* blob, int runIndex,
|
| @@ -1479,7 +1477,7 @@ public:
|
| }
|
|
|
| static TextBatch* CreateDistanceField(int glyphCount, GrBatchFontCache* fontCache,
|
| - DistanceAdjustTable* distanceAdjustTable,
|
| + const DistanceAdjustTable* distanceAdjustTable,
|
| SkColor filteredColor, bool isLCD,
|
| bool useBGR) {
|
| TextBatch* batch = new TextBatch;
|
| @@ -2054,7 +2052,8 @@ private:
|
| SkColor fFilteredColor;
|
| };
|
|
|
| -void GrAtlasTextContext::flushRunAsPaths(GrRenderTarget* rt, const SkTextBlob::RunIterator& it,
|
| +void GrAtlasTextContext::flushRunAsPaths(GrDrawContext* dc, GrRenderTarget* rt,
|
| + const SkTextBlob::RunIterator& it,
|
| const GrClip& clip, const SkPaint& skPaint,
|
| SkDrawFilter* drawFilter, const SkMatrix& viewMatrix,
|
| const SkIRect& clipBounds, SkScalar x, SkScalar y) {
|
| @@ -2073,18 +2072,18 @@ void GrAtlasTextContext::flushRunAsPaths(GrRenderTarget* rt, const SkTextBlob::R
|
|
|
| switch (it.positioning()) {
|
| case SkTextBlob::kDefault_Positioning:
|
| - this->drawTextAsPath(rt, clip, runPaint, viewMatrix,
|
| + this->drawTextAsPath(dc, rt, clip, runPaint, viewMatrix,
|
| (const char *)it.glyphs(),
|
| textLen, x + offset.x(), y + offset.y(), clipBounds);
|
| break;
|
| case SkTextBlob::kHorizontal_Positioning:
|
| - this->drawPosTextAsPath(rt, clip, runPaint, viewMatrix,
|
| + this->drawPosTextAsPath(dc, rt, clip, runPaint, viewMatrix,
|
| (const char*)it.glyphs(),
|
| textLen, it.pos(), 1, SkPoint::Make(x, y + offset.y()),
|
| clipBounds);
|
| break;
|
| case SkTextBlob::kFull_Positioning:
|
| - this->drawPosTextAsPath(rt, clip, runPaint, viewMatrix,
|
| + this->drawPosTextAsPath(dc, rt, clip, runPaint, viewMatrix,
|
| (const char*)it.glyphs(),
|
| textLen, it.pos(), 2, SkPoint::Make(x, y), clipBounds);
|
| break;
|
| @@ -2133,7 +2132,7 @@ GrAtlasTextContext::createBatch(GrAtlasTextBlob* cacheBlob, const PerSubRunInfo&
|
| return batch;
|
| }
|
|
|
| -inline void GrAtlasTextContext::flushRun(GrPipelineBuilder* pipelineBuilder,
|
| +inline void GrAtlasTextContext::flushRun(GrDrawContext* dc, GrPipelineBuilder* pipelineBuilder,
|
| GrAtlasTextBlob* cacheBlob, int run, GrColor color,
|
| SkScalar transX, SkScalar transY,
|
| const SkPaint& skPaint) {
|
| @@ -2147,11 +2146,12 @@ inline void GrAtlasTextContext::flushRun(GrPipelineBuilder* pipelineBuilder,
|
| SkAutoTUnref<GrDrawBatch> batch(this->createBatch(cacheBlob, info, glyphCount, run,
|
| subRun, color, transX, transY,
|
| skPaint));
|
| - fDrawContext->drawBatch(pipelineBuilder, batch);
|
| + dc->drawBatch(pipelineBuilder, batch);
|
| }
|
| }
|
|
|
| -inline void GrAtlasTextContext::flushBigGlyphs(GrAtlasTextBlob* cacheBlob, GrRenderTarget* rt,
|
| +inline void GrAtlasTextContext::flushBigGlyphs(GrAtlasTextBlob* cacheBlob,
|
| + GrDrawContext* dc, GrRenderTarget* rt,
|
| const GrClip& clip, const SkPaint& skPaint,
|
| SkScalar transX, SkScalar transY,
|
| const SkIRect& clipBounds) {
|
| @@ -2170,13 +2170,14 @@ inline void GrAtlasTextContext::flushBigGlyphs(GrAtlasTextBlob* cacheBlob, GrRen
|
| ctm.postConcat(cacheBlob->fViewMatrix);
|
| }
|
|
|
| - GrBlurUtils::drawPathWithMaskFilter(fContext, fDrawContext, rt, clip, bigGlyph.fPath,
|
| + GrBlurUtils::drawPathWithMaskFilter(fContext, dc, rt, clip, bigGlyph.fPath,
|
| skPaint, ctm, nullptr, clipBounds, false);
|
| }
|
| }
|
|
|
| void GrAtlasTextContext::flush(const SkTextBlob* blob,
|
| GrAtlasTextBlob* cacheBlob,
|
| + GrDrawContext* dc,
|
| GrRenderTarget* rt,
|
| const SkPaint& skPaint,
|
| const GrPaint& grPaint,
|
| @@ -2195,20 +2196,21 @@ void GrAtlasTextContext::flush(const SkTextBlob* blob,
|
| SkTextBlob::RunIterator it(blob);
|
| for (int run = 0; !it.done(); it.next(), run++) {
|
| if (cacheBlob->fRuns[run].fDrawAsPaths) {
|
| - this->flushRunAsPaths(rt, it, clip, skPaint,
|
| + this->flushRunAsPaths(dc, rt, it, clip, skPaint,
|
| drawFilter, viewMatrix, clipBounds, x, y);
|
| continue;
|
| }
|
| cacheBlob->fRuns[run].fVertexBounds.offset(transX, transY);
|
| - this->flushRun(&pipelineBuilder, cacheBlob, run, color,
|
| + this->flushRun(dc, &pipelineBuilder, cacheBlob, run, color,
|
| transX, transY, skPaint);
|
| }
|
|
|
| // Now flush big glyphs
|
| - this->flushBigGlyphs(cacheBlob, rt, clip, skPaint, transX, transY, clipBounds);
|
| + this->flushBigGlyphs(cacheBlob, dc, rt, clip, skPaint, transX, transY, clipBounds);
|
| }
|
|
|
| void GrAtlasTextContext::flush(GrAtlasTextBlob* cacheBlob,
|
| + GrDrawContext* dc,
|
| GrRenderTarget* rt,
|
| const SkPaint& skPaint,
|
| const GrPaint& grPaint,
|
| @@ -2218,11 +2220,11 @@ void GrAtlasTextContext::flush(GrAtlasTextBlob* cacheBlob,
|
|
|
| GrColor color = grPaint.getColor();
|
| for (int run = 0; run < cacheBlob->fRunCount; run++) {
|
| - this->flushRun(&pipelineBuilder, cacheBlob, run, color, 0, 0, skPaint);
|
| + this->flushRun(dc, &pipelineBuilder, cacheBlob, run, color, 0, 0, skPaint);
|
| }
|
|
|
| // Now flush big glyphs
|
| - this->flushBigGlyphs(cacheBlob, rt, clip, skPaint, 0, 0, clipBounds);
|
| + this->flushBigGlyphs(cacheBlob, dc, rt, clip, skPaint, 0, 0, clipBounds);
|
| }
|
|
|
| ///////////////////////////////////////////////////////////////////////////////////////////////////
|
| @@ -2241,9 +2243,7 @@ DRAW_BATCH_TEST_DEFINE(TextBlobBatch) {
|
| // We don't yet test the fall back to paths in the GrTextContext base class. This is mostly
|
| // because we don't really want to have a gpu device here.
|
| // We enable distance fields by twiddling a knob on the paint
|
| - GrDrawContext* drawContext = context->drawContext(&gSurfaceProps);
|
| -
|
| - gTextContext = GrAtlasTextContext::Create(context, drawContext, gSurfaceProps);
|
| + gTextContext = GrAtlasTextContext::Create(context, gSurfaceProps);
|
| }
|
|
|
| // create dummy render target
|
|
|