blob: 01024c6bd72e1913027a34b1a19a9f562b97ab57 [file] [log] [blame]
joshualitta751c972015-11-20 13:37:32 -08001/*
2 * Copyright 2015 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
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "src/gpu/ops/GrAtlasTextOp.h"
Robert Phillipse4fda6c2018-02-21 12:10:41 -05009
Mike Kleinc0bd9f92019-04-23 12:05:21 -050010#include "include/core/SkPoint3.h"
11#include "include/private/GrRecordingContext.h"
12#include "src/core/SkMathPriv.h"
13#include "src/core/SkMatrixPriv.h"
14#include "src/core/SkStrikeCache.h"
15#include "src/gpu/GrCaps.h"
16#include "src/gpu/GrMemoryPool.h"
17#include "src/gpu/GrOpFlushState.h"
18#include "src/gpu/GrRecordingContextPriv.h"
19#include "src/gpu/GrResourceProvider.h"
20#include "src/gpu/effects/GrBitmapTextGeoProc.h"
21#include "src/gpu/effects/GrDistanceFieldGeoProc.h"
Robert Phillips3968fcb2019-12-05 16:40:31 -050022#include "src/gpu/ops/GrSimpleMeshDrawOpHelper.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050023#include "src/gpu/text/GrAtlasManager.h"
Robert Phillips841c9a52020-03-27 12:41:31 -040024#include "src/gpu/text/GrDistanceFieldAdjustTable.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050025#include "src/gpu/text/GrStrikeCache.h"
joshualitta751c972015-11-20 13:37:32 -080026
joshualitt60ce86d2015-11-23 13:08:22 -080027///////////////////////////////////////////////////////////////////////////////////////////////////
28
Robert Phillipsb97da532019-02-12 15:24:12 -050029std::unique_ptr<GrAtlasTextOp> GrAtlasTextOp::MakeBitmap(GrRecordingContext* context,
Robert Phillips7c525e62018-06-12 10:11:12 -040030 GrPaint&& paint,
31 GrMaskFormat maskFormat,
32 int glyphCount,
33 bool needsTransform) {
Robert Phillips9da87e02019-02-04 13:26:26 -050034 GrOpMemoryPool* pool = context->priv().opMemoryPool();
Robert Phillipsc994a932018-06-19 13:09:54 -040035
36 std::unique_ptr<GrAtlasTextOp> op = pool->allocate<GrAtlasTextOp>(std::move(paint));
Robert Phillips7c525e62018-06-12 10:11:12 -040037
38 switch (maskFormat) {
39 case kA8_GrMaskFormat:
40 op->fMaskType = kGrayscaleCoverageMask_MaskType;
41 break;
42 case kA565_GrMaskFormat:
43 op->fMaskType = kLCDCoverageMask_MaskType;
44 break;
45 case kARGB_GrMaskFormat:
46 op->fMaskType = kColorBitmapMask_MaskType;
47 break;
48 }
49 op->fNumGlyphs = glyphCount;
50 op->fGeoCount = 1;
51 op->fLuminanceColor = 0;
52 op->fNeedsGlyphTransform = needsTransform;
53 return op;
54 }
55
56std::unique_ptr<GrAtlasTextOp> GrAtlasTextOp::MakeDistanceField(
Robert Phillipsb97da532019-02-12 15:24:12 -050057 GrRecordingContext* context,
Robert Phillips7c525e62018-06-12 10:11:12 -040058 GrPaint&& paint,
59 int glyphCount,
Robert Phillips7c525e62018-06-12 10:11:12 -040060 bool useGammaCorrectDistanceTable,
61 SkColor luminanceColor,
62 const SkSurfaceProps& props,
63 bool isAntiAliased,
64 bool useLCD) {
Robert Phillips9da87e02019-02-04 13:26:26 -050065 GrOpMemoryPool* pool = context->priv().opMemoryPool();
Robert Phillipsc994a932018-06-19 13:09:54 -040066
67 std::unique_ptr<GrAtlasTextOp> op = pool->allocate<GrAtlasTextOp>(std::move(paint));
Robert Phillips7c525e62018-06-12 10:11:12 -040068
69 bool isBGR = SkPixelGeometryIsBGR(props.pixelGeometry());
70 bool isLCD = useLCD && SkPixelGeometryIsH(props.pixelGeometry());
71 op->fMaskType = !isAntiAliased ? kAliasedDistanceField_MaskType
72 : isLCD ? (isBGR ? kLCDBGRDistanceField_MaskType
73 : kLCDDistanceField_MaskType)
74 : kGrayscaleDistanceField_MaskType;
Robert Phillips7c525e62018-06-12 10:11:12 -040075 op->fUseGammaCorrectDistanceTable = useGammaCorrectDistanceTable;
76 op->fLuminanceColor = luminanceColor;
77 op->fNumGlyphs = glyphCount;
78 op->fGeoCount = 1;
79 return op;
80 }
81
joshualitta751c972015-11-20 13:37:32 -080082static const int kDistanceAdjustLumShift = 5;
83
Brian Salomon5c6ac642017-12-19 11:09:32 -050084void GrAtlasTextOp::init() {
85 const Geometry& geo = fGeoData[0];
Brian Salomon5c6ac642017-12-19 11:09:32 -050086 if (this->usesDistanceFields()) {
87 bool isLCD = this->isLCD();
88
Herb Derby1c5be7b2019-12-13 12:03:06 -050089 const SkMatrix& drawMatrix = geo.fDrawMatrix;
Brian Salomon5c6ac642017-12-19 11:09:32 -050090
Herb Derby1c5be7b2019-12-13 12:03:06 -050091 fDFGPFlags = drawMatrix.isSimilarity() ? kSimilarity_DistanceFieldEffectFlag : 0;
92 fDFGPFlags |= drawMatrix.isScaleTranslate() ? kScaleOnly_DistanceFieldEffectFlag : 0;
93 fDFGPFlags |= drawMatrix.hasPerspective() ? kPerspective_DistanceFieldEffectFlag : 0;
Brian Salomon5c6ac642017-12-19 11:09:32 -050094 fDFGPFlags |= fUseGammaCorrectDistanceTable ? kGammaCorrect_DistanceFieldEffectFlag : 0;
95 fDFGPFlags |= (kAliasedDistanceField_MaskType == fMaskType)
96 ? kAliased_DistanceFieldEffectFlag
97 : 0;
98
99 if (isLCD) {
100 fDFGPFlags |= kUseLCD_DistanceFieldEffectFlag;
101 fDFGPFlags |=
102 (kLCDBGRDistanceField_MaskType == fMaskType) ? kBGR_DistanceFieldEffectFlag : 0;
103 }
Jim Van Verthb515ae72018-05-23 16:44:55 -0400104
105 fNeedsGlyphTransform = true;
Brian Salomon5c6ac642017-12-19 11:09:32 -0500106 }
Jim Van Verth70276912018-06-01 13:46:46 -0400107
108 SkRect bounds;
Herb Derby5bf5b042019-12-12 16:37:03 -0500109 geo.fBlob->computeSubRunBounds(
110 &bounds, *geo.fSubRunPtr, geo.fDrawMatrix, geo.fDrawOrigin, fNeedsGlyphTransform);
Jim Van Verth70276912018-06-01 13:46:46 -0400111 // We don't have tight bounds on the glyph paths in device space. For the purposes of bounds
112 // we treat this as a set of non-AA rects rendered with a texture.
Greg Daniel5faf4742019-10-01 15:14:44 -0400113 this->setBounds(bounds, HasAABloat::kNo, IsHairline::kNo);
Brian Salomon5c6ac642017-12-19 11:09:32 -0500114}
115
Chris Dalton1706cbf2019-05-21 19:35:29 -0600116void GrAtlasTextOp::visitProxies(const VisitProxyFunc& func) const {
Robert Phillipse4fda6c2018-02-21 12:10:41 -0500117 fProcessors.visitProxies(func);
Robert Phillipse4fda6c2018-02-21 12:10:41 -0500118}
119
Brian Osman9a390ac2018-11-12 09:47:48 -0500120#ifdef SK_DEBUG
Brian Salomon344ec422016-12-15 10:58:41 -0500121SkString GrAtlasTextOp::dumpInfo() const {
joshualitta751c972015-11-20 13:37:32 -0800122 SkString str;
123
124 for (int i = 0; i < fGeoCount; ++i) {
Herb Derby1b8dcd12019-11-15 15:21:15 -0500125 str.appendf("%d: Color: 0x%08x Trans: %.2f,%.2f\n",
joshualitta751c972015-11-20 13:37:32 -0800126 i,
Brian Osmancf860852018-10-31 14:04:39 -0400127 fGeoData[i].fColor.toBytes_RGBA(),
Herb Derby5bf5b042019-12-12 16:37:03 -0500128 fGeoData[i].fDrawOrigin.x(),
129 fGeoData[i].fDrawOrigin.y());
joshualitta751c972015-11-20 13:37:32 -0800130 }
131
Brian Salomon44acb5b2017-07-18 19:59:24 -0400132 str += fProcessors.dumpProcessors();
133 str += INHERITED::dumpInfo();
joshualitta751c972015-11-20 13:37:32 -0800134 return str;
135}
Brian Osman9a390ac2018-11-12 09:47:48 -0500136#endif
joshualitta751c972015-11-20 13:37:32 -0800137
Brian Salomon44acb5b2017-07-18 19:59:24 -0400138GrDrawOp::FixedFunctionFlags GrAtlasTextOp::fixedFunctionFlags() const {
139 return FixedFunctionFlags::kNone;
140}
141
Chris Dalton6ce447a2019-06-23 18:07:38 -0600142GrProcessorSet::Analysis GrAtlasTextOp::finalize(
143 const GrCaps& caps, const GrAppliedClip* clip, bool hasMixedSampledCoverage,
144 GrClampType clampType) {
Brian Salomon44acb5b2017-07-18 19:59:24 -0400145 GrProcessorAnalysisCoverage coverage;
146 GrProcessorAnalysisColor color;
joshualitta751c972015-11-20 13:37:32 -0800147 if (kColorBitmapMask_MaskType == fMaskType) {
Brian Salomon44acb5b2017-07-18 19:59:24 -0400148 color.setToUnknown();
joshualitta751c972015-11-20 13:37:32 -0800149 } else {
Brian Osman09068252018-01-03 09:57:29 -0500150 color.setToConstant(this->color());
joshualitta751c972015-11-20 13:37:32 -0800151 }
joshualitta751c972015-11-20 13:37:32 -0800152 switch (fMaskType) {
joshualitta751c972015-11-20 13:37:32 -0800153 case kGrayscaleCoverageMask_MaskType:
Jim Van Verth90e89b32017-07-06 16:36:55 -0400154 case kAliasedDistanceField_MaskType:
155 case kGrayscaleDistanceField_MaskType:
Brian Salomon44acb5b2017-07-18 19:59:24 -0400156 coverage = GrProcessorAnalysisCoverage::kSingleChannel;
joshualitta751c972015-11-20 13:37:32 -0800157 break;
158 case kLCDCoverageMask_MaskType:
159 case kLCDDistanceField_MaskType:
Jim Van Verth90e89b32017-07-06 16:36:55 -0400160 case kLCDBGRDistanceField_MaskType:
Brian Salomon44acb5b2017-07-18 19:59:24 -0400161 coverage = GrProcessorAnalysisCoverage::kLCD;
joshualitta751c972015-11-20 13:37:32 -0800162 break;
163 case kColorBitmapMask_MaskType:
Brian Salomon44acb5b2017-07-18 19:59:24 -0400164 coverage = GrProcessorAnalysisCoverage::kNone;
Brian Salomonc0b642c2017-03-27 13:09:36 -0400165 break;
joshualitta751c972015-11-20 13:37:32 -0800166 }
Chris Daltonb8fff0d2019-03-05 10:11:58 -0700167 auto analysis = fProcessors.finalize(
Chris Dalton6ce447a2019-06-23 18:07:38 -0600168 color, coverage, clip, &GrUserStencilSettings::kUnused, hasMixedSampledCoverage, caps,
169 clampType, &fGeoData[0].fColor);
Brian Salomon44acb5b2017-07-18 19:59:24 -0400170 fUsesLocalCoords = analysis.usesLocalCoords();
Chris Dalton4b62aed2019-01-15 11:53:00 -0700171 return analysis;
joshualitta751c972015-11-20 13:37:32 -0800172}
173
Brian Salomon18923f92017-11-06 16:26:02 -0500174static void clip_quads(const SkIRect& clipRect, char* currVertex, const char* blobVertices,
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400175 size_t vertexStride, int glyphCount) {
176 for (int i = 0; i < glyphCount; ++i) {
Brian Salomon18923f92017-11-06 16:26:02 -0500177 const SkPoint* blobPositionLT = reinterpret_cast<const SkPoint*>(blobVertices);
178 const SkPoint* blobPositionRB =
179 reinterpret_cast<const SkPoint*>(blobVertices + 3 * vertexStride);
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400180
Jim Van Verth328a33f2017-10-20 12:14:22 -0400181 // positions for bitmap glyphs are pixel boundary aligned
Brian Osman7ca90d22017-11-10 15:31:27 -0500182 SkIRect positionRect = SkIRect::MakeLTRB(SkScalarRoundToInt(blobPositionLT->fX),
183 SkScalarRoundToInt(blobPositionLT->fY),
184 SkScalarRoundToInt(blobPositionRB->fX),
185 SkScalarRoundToInt(blobPositionRB->fY));
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400186 if (clipRect.contains(positionRect)) {
187 memcpy(currVertex, blobVertices, 4 * vertexStride);
188 currVertex += 4 * vertexStride;
189 } else {
190 // Pull out some more data that we'll need.
191 // In the LCD case the color will be garbage, but we'll overwrite it with the texcoords
192 // and it avoids a lot of conditionals.
Brian Salomon18923f92017-11-06 16:26:02 -0500193 auto color = *reinterpret_cast<const SkColor*>(blobVertices + sizeof(SkPoint));
Jim Van Verth2f2c77a2020-01-24 15:48:23 +0000194 size_t coordOffset = vertexStride - 2*sizeof(uint16_t);
195 auto* blobCoordsLT = reinterpret_cast<const uint16_t*>(blobVertices + coordOffset);
196 auto* blobCoordsRB = reinterpret_cast<const uint16_t*>(blobVertices + 3 * vertexStride +
Brian Salomon18923f92017-11-06 16:26:02 -0500197 coordOffset);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400198 // Pull out the texel coordinates and texture index bits
Jim Van Verthfb395102020-02-03 10:11:19 -0500199 uint16_t coordsRectL = blobCoordsLT[0];
200 uint16_t coordsRectT = blobCoordsLT[1];
201 uint16_t coordsRectR = blobCoordsRB[0];
202 uint16_t coordsRectB = blobCoordsRB[1];
203 int index0, index1;
204 std::tie(coordsRectL, coordsRectT, index0) =
205 GrDrawOpAtlas::UnpackIndexFromTexCoords(coordsRectL, coordsRectT);
206 std::tie(coordsRectR, coordsRectB, index1) =
207 GrDrawOpAtlas::UnpackIndexFromTexCoords(coordsRectR, coordsRectB);
208 SkASSERT(index0 == index1);
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400209
Jim Van Verth328a33f2017-10-20 12:14:22 -0400210 int positionRectWidth = positionRect.width();
211 int positionRectHeight = positionRect.height();
212 SkASSERT(positionRectWidth == (coordsRectR - coordsRectL));
213 SkASSERT(positionRectHeight == (coordsRectB - coordsRectT));
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400214
215 // Clip position and texCoords to the clipRect
Jim Van Verth328a33f2017-10-20 12:14:22 -0400216 unsigned int delta;
Brian Osman788b9162020-02-07 10:36:46 -0500217 delta = std::min(std::max(clipRect.fLeft - positionRect.fLeft, 0), positionRectWidth);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400218 coordsRectL += delta;
219 positionRect.fLeft += delta;
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400220
Brian Osman788b9162020-02-07 10:36:46 -0500221 delta = std::min(std::max(clipRect.fTop - positionRect.fTop, 0), positionRectHeight);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400222 coordsRectT += delta;
223 positionRect.fTop += delta;
224
Brian Osman788b9162020-02-07 10:36:46 -0500225 delta = std::min(std::max(positionRect.fRight - clipRect.fRight, 0), positionRectWidth);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400226 coordsRectR -= delta;
227 positionRect.fRight -= delta;
228
Brian Osman788b9162020-02-07 10:36:46 -0500229 delta = std::min(std::max(positionRect.fBottom - clipRect.fBottom, 0), positionRectHeight);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400230 coordsRectB -= delta;
231 positionRect.fBottom -= delta;
232
233 // Repack texel coordinates and index
Jim Van Verthfb395102020-02-03 10:11:19 -0500234 std::tie(coordsRectL, coordsRectT) =
235 GrDrawOpAtlas::PackIndexInTexCoords(coordsRectL, coordsRectT, index0);
236 std::tie(coordsRectR, coordsRectB) =
237 GrDrawOpAtlas::PackIndexInTexCoords(coordsRectR, coordsRectB, index1);
Jim Van Verth328a33f2017-10-20 12:14:22 -0400238
239 // Set new positions and coords
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400240 SkPoint* currPosition = reinterpret_cast<SkPoint*>(currVertex);
241 currPosition->fX = positionRect.fLeft;
242 currPosition->fY = positionRect.fTop;
243 *(reinterpret_cast<SkColor*>(currVertex + sizeof(SkPoint))) = color;
Jim Van Verth328a33f2017-10-20 12:14:22 -0400244 uint16_t* currCoords = reinterpret_cast<uint16_t*>(currVertex + coordOffset);
245 currCoords[0] = coordsRectL;
246 currCoords[1] = coordsRectT;
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400247 currVertex += vertexStride;
248
249 currPosition = reinterpret_cast<SkPoint*>(currVertex);
250 currPosition->fX = positionRect.fLeft;
251 currPosition->fY = positionRect.fBottom;
252 *(reinterpret_cast<SkColor*>(currVertex + sizeof(SkPoint))) = color;
Jim Van Verth328a33f2017-10-20 12:14:22 -0400253 currCoords = reinterpret_cast<uint16_t*>(currVertex + coordOffset);
254 currCoords[0] = coordsRectL;
255 currCoords[1] = coordsRectB;
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400256 currVertex += vertexStride;
257
258 currPosition = reinterpret_cast<SkPoint*>(currVertex);
259 currPosition->fX = positionRect.fRight;
260 currPosition->fY = positionRect.fTop;
261 *(reinterpret_cast<SkColor*>(currVertex + sizeof(SkPoint))) = color;
Jim Van Verth328a33f2017-10-20 12:14:22 -0400262 currCoords = reinterpret_cast<uint16_t*>(currVertex + coordOffset);
263 currCoords[0] = coordsRectR;
264 currCoords[1] = coordsRectT;
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400265 currVertex += vertexStride;
266
267 currPosition = reinterpret_cast<SkPoint*>(currVertex);
268 currPosition->fX = positionRect.fRight;
269 currPosition->fY = positionRect.fBottom;
270 *(reinterpret_cast<SkColor*>(currVertex + sizeof(SkPoint))) = color;
Jim Van Verth328a33f2017-10-20 12:14:22 -0400271 currCoords = reinterpret_cast<uint16_t*>(currVertex + coordOffset);
272 currCoords[0] = coordsRectR;
273 currCoords[1] = coordsRectB;
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400274 currVertex += vertexStride;
275 }
276
277 blobVertices += 4 * vertexStride;
278 }
279}
280
Brian Salomon91326c32017-08-09 16:02:19 -0400281void GrAtlasTextOp::onPrepareDraws(Target* target) {
Robert Phillips4bc70112018-03-01 10:24:02 -0500282 auto resourceProvider = target->resourceProvider();
283
joshualitta751c972015-11-20 13:37:32 -0800284 // if we have RGB, then we won't have any SkShaders so no need to use a localmatrix.
285 // TODO actually only invert if we don't have RGBA
286 SkMatrix localMatrix;
Herb Derby1c5be7b2019-12-13 12:03:06 -0500287 if (this->usesLocalCoords() && !fGeoData[0].fDrawMatrix.invert(&localMatrix)) {
joshualitta751c972015-11-20 13:37:32 -0800288 return;
289 }
290
Robert Phillips5a66efb2018-03-07 15:13:18 -0500291 GrAtlasManager* atlasManager = target->atlasManager();
Mike Klein99e002f2020-01-16 16:45:03 +0000292
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400293 GrMaskFormat maskFormat = this->maskFormat();
294
Greg Daniel9715b6c2019-12-10 15:03:10 -0500295 unsigned int numActiveViews;
296 const GrSurfaceProxyView* views = atlasManager->getViews(maskFormat, &numActiveViews);
297 if (!views) {
joshualitta751c972015-11-20 13:37:32 -0800298 SkDebugf("Could not allocate backing texture for atlas\n");
299 return;
300 }
Greg Daniel9715b6c2019-12-10 15:03:10 -0500301 SkASSERT(views[0].proxy());
joshualitta751c972015-11-20 13:37:32 -0800302
Brian Salomon7eae3e02018-08-07 14:02:38 +0000303 static constexpr int kMaxTextures = GrBitmapTextGeoProc::kMaxTextures;
Brian Salomon4dea72a2019-12-18 10:43:10 -0500304 static_assert(GrDistanceFieldA8TextGeoProc::kMaxTextures == kMaxTextures);
305 static_assert(GrDistanceFieldLCDTextGeoProc::kMaxTextures == kMaxTextures);
Brian Salomon7eae3e02018-08-07 14:02:38 +0000306
Chris Dalton304e14d2020-03-17 14:29:06 -0600307 auto primProcProxies = target->allocPrimProcProxyPtrs(kMaxTextures);
Greg Daniel9715b6c2019-12-10 15:03:10 -0500308 for (unsigned i = 0; i < numActiveViews; ++i) {
Chris Dalton304e14d2020-03-17 14:29:06 -0600309 primProcProxies[i] = views[i].proxy();
Greg Danielb20d7e52019-09-03 13:54:39 -0400310 // This op does not know its atlas proxies when it is added to a GrOpsTasks, so the proxies
311 // don't get added during the visitProxies call. Thus we add them here.
Greg Daniel9715b6c2019-12-10 15:03:10 -0500312 target->sampledProxyArray()->push_back(views[i].proxy());
Brian Salomon7eae3e02018-08-07 14:02:38 +0000313 }
Brian Salomon49348902018-06-26 09:12:38 -0400314
315 FlushInfo flushInfo;
Chris Dalton304e14d2020-03-17 14:29:06 -0600316 flushInfo.fPrimProcProxies = primProcProxies;
Brian Salomon49348902018-06-26 09:12:38 -0400317
Herb Derby1c5be7b2019-12-13 12:03:06 -0500318 bool vmPerspective = fGeoData[0].fDrawMatrix.hasPerspective();
joshualittd9d30f72015-12-08 10:47:55 -0800319 if (this->usesDistanceFields()) {
Robert Phillips7cd0bfe2019-11-20 16:08:10 -0500320 flushInfo.fGeometryProcessor = this->setupDfProcessor(target->allocator(),
321 *target->caps().shaderCaps(),
Greg Daniel9715b6c2019-12-10 15:03:10 -0500322 views, numActiveViews);
joshualitta751c972015-11-20 13:37:32 -0800323 } else {
Brian Salomonccb61422020-01-09 10:46:36 -0500324 auto filter = fNeedsGlyphTransform ? GrSamplerState::Filter::kBilerp
325 : GrSamplerState::Filter::kNearest;
326 flushInfo.fGeometryProcessor = GrBitmapTextGeoProc::Make(
327 target->allocator(), *target->caps().shaderCaps(), this->color(), false, views,
328 numActiveViews, filter, maskFormat, localMatrix, vmPerspective);
joshualitta751c972015-11-20 13:37:32 -0800329 }
330
Herb Derby23f29762020-01-10 16:26:14 -0500331 int vertexStride = (int)flushInfo.fGeometryProcessor->vertexStride();
joshualitta751c972015-11-20 13:37:32 -0800332
Brian Salomon43cbd722020-01-03 22:09:12 -0500333 // Ensure we don't request an insanely large contiguous vertex allocation.
Herb Derby23f29762020-01-10 16:26:14 -0500334 static const int kMaxVertexBytes = GrBufferAllocPool::kDefaultBufferSize;
335 const int quadSize = vertexStride * kVerticesPerGlyph;
336 const int maxQuadsPerBuffer = kMaxVertexBytes / quadSize;
337
338 // Where the quad buffer begins and ends relative to totalGlyphsRegened.
339 int quadBufferBegin = 0;
340 int quadBufferEnd = std::min(this->numGlyphs(), maxQuadsPerBuffer);
341
Robert Phillipsee08d522019-10-28 16:34:44 -0400342 flushInfo.fIndexBuffer = resourceProvider->refNonAAQuadIndexBuffer();
Herb Derby23f29762020-01-10 16:26:14 -0500343 void* vertices = target->makeVertexSpace(
344 vertexStride,
345 kVerticesPerGlyph * (quadBufferEnd - quadBufferBegin),
346 &flushInfo.fVertexBuffer,
347 &flushInfo.fVertexOffset);
joshualitta751c972015-11-20 13:37:32 -0800348 if (!vertices || !flushInfo.fVertexBuffer) {
349 SkDebugf("Could not allocate vertices\n");
350 return;
351 }
352
Herb Derby23f29762020-01-10 16:26:14 -0500353 // totalGlyphsRegened is all the glyphs for the op [0, this->numGlyphs()). The subRun glyph and
354 // quad buffer indices are calculated from this.
355 int totalGlyphsRegened = 0;
joshualitta751c972015-11-20 13:37:32 -0800356 for (int i = 0; i < fGeoCount; i++) {
joshualitt144c3c82015-11-30 12:30:13 -0800357 const Geometry& args = fGeoData[i];
Herb Derby23f29762020-01-10 16:26:14 -0500358 auto subRun = args.fSubRunPtr;
359 SkASSERT((int)subRun->vertexStride() == vertexStride);
360
Herb Derby62b12fe2020-01-14 17:57:24 -0500361 subRun->updateVerticesColorIfNeeded(args.fColor.toBytes_RGBA());
362 subRun->translateVerticesIfNeeded(args.fDrawMatrix, args.fDrawOrigin);
363
Brian Osman1be2b7c2018-10-29 16:07:15 -0400364 // TODO4F: Preserve float colors
Herb Derby86240592018-05-24 16:12:31 -0400365 GrTextBlob::VertexRegenerator regenerator(
Herb Derby5ddc34c2020-02-01 20:38:30 -0500366 resourceProvider, args.fSubRunPtr, target->deferredUploadTarget(), atlasManager);
Herb Derby23f29762020-01-10 16:26:14 -0500367
368 // Where the subRun begins and ends relative to totalGlyphsRegened.
369 int subRunBegin = totalGlyphsRegened;
Robert Phillips1576e4e2020-04-01 12:49:45 -0400370 int subRunEnd = subRunBegin + subRun->fGlyphs.count();
Herb Derby23f29762020-01-10 16:26:14 -0500371
372 // Draw all the glyphs in the subRun.
373 while (totalGlyphsRegened < subRunEnd) {
374 // drawBegin and drawEnd are indices for the subRun on the
375 // interval [0, subRun->fGlyphs.size()).
376 int drawBegin = totalGlyphsRegened - subRunBegin;
377 // drawEnd is either the end of the subRun or the end of the current quad buffer.
378 int drawEnd = std::min(subRunEnd, quadBufferEnd) - subRunBegin;
379 auto[ok, glyphsRegenerated] = regenerator.regenerate(drawBegin, drawEnd);
380
381 // There was a problem allocating the glyph in the atlas. Bail.
Robert Phillips1576e4e2020-04-01 12:49:45 -0400382 if (!ok) {
383 return;
384 }
Herb Derby23f29762020-01-10 16:26:14 -0500385
386 // Update all the vertices for glyphsRegenerate glyphs.
387 if (glyphsRegenerated > 0) {
388 int quadBufferIndex = totalGlyphsRegened - quadBufferBegin;
389 int subRunIndex = totalGlyphsRegened - subRunBegin;
390 auto regeneratedQuadBuffer =
391 SkTAddOffset<char>(vertices, subRun->quadOffset(quadBufferIndex));
Brian Salomon43cbd722020-01-03 22:09:12 -0500392 if (args.fClipRect.isEmpty()) {
Herb Derby23f29762020-01-10 16:26:14 -0500393 memcpy(regeneratedQuadBuffer,
394 subRun->quadStart(subRunIndex),
395 glyphsRegenerated * quadSize);
Brian Salomon43cbd722020-01-03 22:09:12 -0500396 } else {
397 SkASSERT(!vmPerspective);
Herb Derby23f29762020-01-10 16:26:14 -0500398 clip_quads(args.fClipRect,
399 regeneratedQuadBuffer,
400 subRun->quadStart(subRunIndex),
401 vertexStride,
402 glyphsRegenerated);
Brian Salomon43cbd722020-01-03 22:09:12 -0500403 }
404 if (fNeedsGlyphTransform && !args.fDrawMatrix.isIdentity()) {
405 // We always do the distance field view matrix transformation after copying
406 // rather than during blob vertex generation time in the blob as handling
407 // successive arbitrary transformations would be complicated and accumulate
408 // error.
409 if (args.fDrawMatrix.hasPerspective()) {
Herb Derby23f29762020-01-10 16:26:14 -0500410 auto* pos = reinterpret_cast<SkPoint3*>(regeneratedQuadBuffer);
411 SkMatrixPriv::MapHomogeneousPointsWithStride(
412 args.fDrawMatrix, pos,
413 vertexStride, pos,
414 vertexStride,
415 glyphsRegenerated * kVerticesPerGlyph);
Brian Salomon43cbd722020-01-03 22:09:12 -0500416 } else {
Herb Derby23f29762020-01-10 16:26:14 -0500417 auto* pos = reinterpret_cast<SkPoint*>(regeneratedQuadBuffer);
Brian Salomon43cbd722020-01-03 22:09:12 -0500418 SkMatrixPriv::MapPointsWithStride(args.fDrawMatrix, pos, vertexStride,
Herb Derby23f29762020-01-10 16:26:14 -0500419 glyphsRegenerated * kVerticesPerGlyph);
Brian Salomon43cbd722020-01-03 22:09:12 -0500420 }
421 }
Robert Phillipsd2e9f762018-03-07 11:54:37 -0500422 }
Herb Derby23f29762020-01-10 16:26:14 -0500423
424 totalGlyphsRegened += glyphsRegenerated;
425 flushInfo.fGlyphsToFlush += glyphsRegenerated;
426
427 // regenerate() has stopped part way through a SubRun. This means that either the atlas
428 // or the quad buffer is full or both. There is a case were the flow through
429 // the loop is strange. If we run out of quad buffer space at the same time the
430 // SubRun ends, then this is not triggered which is the right result for the last
431 // SubRun. But, if this is not the last SubRun, then advance to the next SubRun which
432 // will process no glyphs, and return to this point where the quad buffer will be
433 // expanded.
434 if (totalGlyphsRegened != subRunEnd) {
435 // Flush if not all glyphs drawn because either the quad buffer is full or the
436 // atlas is out of space.
Herb Derby4513cdd2020-01-31 13:28:49 -0500437 this->createDrawForGeneratedGlyphs(target, &flushInfo);
Herb Derby23f29762020-01-10 16:26:14 -0500438 if (totalGlyphsRegened == quadBufferEnd) {
439 // Quad buffer is full. Get more buffer.
440 quadBufferBegin = totalGlyphsRegened;
441 int quadBufferSize =
442 std::min(maxQuadsPerBuffer, this->numGlyphs() - totalGlyphsRegened);
443 quadBufferEnd = quadBufferBegin + quadBufferSize;
444
445 vertices = target->makeVertexSpace(
446 vertexStride,
447 kVerticesPerGlyph * quadBufferSize,
448 &flushInfo.fVertexBuffer,
449 &flushInfo.fVertexOffset);
450 if (!vertices || !flushInfo.fVertexBuffer) {
451 SkDebugf("Could not allocate vertices\n");
452 return;
453 }
454 }
455 }
456 }
Herb Derby5f6f8512020-01-10 12:50:35 -0500457 } // for all geometries
Herb Derby4513cdd2020-01-31 13:28:49 -0500458 this->createDrawForGeneratedGlyphs(target, &flushInfo);
joshualitta751c972015-11-20 13:37:32 -0800459}
460
Chris Dalton07cdcfc92019-02-26 11:13:22 -0700461void GrAtlasTextOp::onExecute(GrOpFlushState* flushState, const SkRect& chainBounds) {
Robert Phillips3968fcb2019-12-05 16:40:31 -0500462 auto pipeline = GrSimpleMeshDrawOpHelper::CreatePipeline(flushState,
463 std::move(fProcessors),
464 GrPipeline::InputFlags::kNone);
465
466 flushState->executeDrawsAndUploadsForMeshDrawOp(this, chainBounds, pipeline);
Chris Dalton07cdcfc92019-02-26 11:13:22 -0700467}
468
Herb Derby4513cdd2020-01-31 13:28:49 -0500469void GrAtlasTextOp::createDrawForGeneratedGlyphs(
470 GrMeshDrawOp::Target* target, FlushInfo* flushInfo) const {
Robert Phillipsd2e9f762018-03-07 11:54:37 -0500471 if (!flushInfo->fGlyphsToFlush) {
472 return;
473 }
474
Robert Phillips5a66efb2018-03-07 15:13:18 -0500475 auto atlasManager = target->atlasManager();
Robert Phillipsc4039ea2018-03-01 11:36:45 -0500476
Robert Phillips7cd0bfe2019-11-20 16:08:10 -0500477 GrGeometryProcessor* gp = flushInfo->fGeometryProcessor;
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400478 GrMaskFormat maskFormat = this->maskFormat();
Robert Phillipsf3690dd2018-02-20 15:18:59 -0500479
Greg Daniel9715b6c2019-12-10 15:03:10 -0500480 unsigned int numActiveViews;
481 const GrSurfaceProxyView* views = atlasManager->getViews(maskFormat, &numActiveViews);
482 SkASSERT(views);
Jim Van Verth9f2516f2019-11-22 14:58:37 -0500483 // Something has gone terribly wrong, bail
Greg Daniel9715b6c2019-12-10 15:03:10 -0500484 if (!views || 0 == numActiveViews) {
Jim Van Verth9f2516f2019-11-22 14:58:37 -0500485 return;
486 }
Greg Daniel9715b6c2019-12-10 15:03:10 -0500487 if (gp->numTextureSamplers() != (int) numActiveViews) {
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400488 // During preparation the number of atlas pages has increased.
489 // Update the proxies used in the GP to match.
Greg Daniel9715b6c2019-12-10 15:03:10 -0500490 for (unsigned i = gp->numTextureSamplers(); i < numActiveViews; ++i) {
Chris Dalton304e14d2020-03-17 14:29:06 -0600491 flushInfo->fPrimProcProxies[i] = views[i].proxy();
Greg Danielb20d7e52019-09-03 13:54:39 -0400492 // This op does not know its atlas proxies when it is added to a GrOpsTasks, so the
493 // proxies don't get added during the visitProxies call. Thus we add them here.
Greg Daniel9715b6c2019-12-10 15:03:10 -0500494 target->sampledProxyArray()->push_back(views[i].proxy());
Brian Salomon43cbd722020-01-03 22:09:12 -0500495 // These will get unreffed when the previously recorded draws destruct.
496 for (int d = 0; d < flushInfo->fNumDraws; ++d) {
Chris Dalton304e14d2020-03-17 14:29:06 -0600497 flushInfo->fPrimProcProxies[i]->ref();
Brian Salomon43cbd722020-01-03 22:09:12 -0500498 }
Brian Salomon7eae3e02018-08-07 14:02:38 +0000499 }
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400500 if (this->usesDistanceFields()) {
501 if (this->isLCD()) {
Greg Daniel9715b6c2019-12-10 15:03:10 -0500502 reinterpret_cast<GrDistanceFieldLCDTextGeoProc*>(gp)->addNewViews(
Brian Salomonccb61422020-01-09 10:46:36 -0500503 views, numActiveViews, GrSamplerState::Filter::kBilerp);
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400504 } else {
Greg Daniel9715b6c2019-12-10 15:03:10 -0500505 reinterpret_cast<GrDistanceFieldA8TextGeoProc*>(gp)->addNewViews(
Brian Salomonccb61422020-01-09 10:46:36 -0500506 views, numActiveViews, GrSamplerState::Filter::kBilerp);
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400507 }
508 } else {
Brian Salomonccb61422020-01-09 10:46:36 -0500509 auto filter = fNeedsGlyphTransform ? GrSamplerState::Filter::kBilerp
510 : GrSamplerState::Filter::kNearest;
511 reinterpret_cast<GrBitmapTextGeoProc*>(gp)->addNewViews(views, numActiveViews, filter);
Jim Van Vertheafa64b2017-09-18 10:05:00 -0400512 }
513 }
Brian Salomondbf70722019-02-07 11:31:24 -0500514 int maxGlyphsPerDraw = static_cast<int>(flushInfo->fIndexBuffer->size() / sizeof(uint16_t) / 6);
Chris Daltoneb694b72020-03-16 09:25:50 -0600515 GrSimpleMesh* mesh = target->allocMesh();
Chris Dalton37c7bdd2020-03-13 09:21:12 -0600516 mesh->setIndexedPatterned(flushInfo->fIndexBuffer, kIndicesPerGlyph, flushInfo->fGlyphsToFlush,
517 maxGlyphsPerDraw, flushInfo->fVertexBuffer, kVerticesPerGlyph,
518 flushInfo->fVertexOffset);
Chris Dalton304e14d2020-03-17 14:29:06 -0600519 target->recordDraw(flushInfo->fGeometryProcessor, mesh, 1, flushInfo->fPrimProcProxies,
Chris Dalton3bf2f3a2020-03-17 11:48:23 -0600520 GrPrimitiveType::kTriangles);
joshualitta751c972015-11-20 13:37:32 -0800521 flushInfo->fVertexOffset += kVerticesPerGlyph * flushInfo->fGlyphsToFlush;
522 flushInfo->fGlyphsToFlush = 0;
Brian Salomon43cbd722020-01-03 22:09:12 -0500523 ++flushInfo->fNumDraws;
joshualitta751c972015-11-20 13:37:32 -0800524}
525
Michael Ludwig28b0c5d2019-12-19 14:51:00 -0500526GrOp::CombineResult GrAtlasTextOp::onCombineIfPossible(GrOp* t, GrRecordingContext::Arenas*,
527 const GrCaps& caps) {
Brian Salomon344ec422016-12-15 10:58:41 -0500528 GrAtlasTextOp* that = t->cast<GrAtlasTextOp>();
Brian Salomon44acb5b2017-07-18 19:59:24 -0400529 if (fProcessors != that->fProcessors) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000530 return CombineResult::kCannotCombine;
Brian Salomon44acb5b2017-07-18 19:59:24 -0400531 }
532
joshualitta751c972015-11-20 13:37:32 -0800533 if (fMaskType != that->fMaskType) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000534 return CombineResult::kCannotCombine;
joshualitta751c972015-11-20 13:37:32 -0800535 }
536
Herb Derby1c5be7b2019-12-13 12:03:06 -0500537 const SkMatrix& thisFirstMatrix = fGeoData[0].fDrawMatrix;
538 const SkMatrix& thatFirstMatrix = that->fGeoData[0].fDrawMatrix;
Brian Salomon5c6ac642017-12-19 11:09:32 -0500539
Mike Reed2c383152019-12-18 16:47:47 -0500540 if (this->usesLocalCoords() && !SkMatrixPriv::CheapEqual(thisFirstMatrix, thatFirstMatrix)) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000541 return CombineResult::kCannotCombine;
Brian Salomon5c6ac642017-12-19 11:09:32 -0500542 }
543
Jim Van Verthb515ae72018-05-23 16:44:55 -0400544 if (fNeedsGlyphTransform != that->fNeedsGlyphTransform) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000545 return CombineResult::kCannotCombine;
Jim Van Verthb515ae72018-05-23 16:44:55 -0400546 }
547
548 if (fNeedsGlyphTransform &&
549 (thisFirstMatrix.hasPerspective() != thatFirstMatrix.hasPerspective())) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000550 return CombineResult::kCannotCombine;
Jim Van Verthb515ae72018-05-23 16:44:55 -0400551 }
552
Brian Salomon5c6ac642017-12-19 11:09:32 -0500553 if (this->usesDistanceFields()) {
554 if (fDFGPFlags != that->fDFGPFlags) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000555 return CombineResult::kCannotCombine;
joshualitta751c972015-11-20 13:37:32 -0800556 }
557
Jim Van Verthbc2cdd12017-06-08 11:14:35 -0400558 if (fLuminanceColor != that->fLuminanceColor) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000559 return CombineResult::kCannotCombine;
joshualitta751c972015-11-20 13:37:32 -0800560 }
Brian Salomon5c6ac642017-12-19 11:09:32 -0500561 } else {
562 if (kColorBitmapMask_MaskType == fMaskType && this->color() != that->color()) {
Brian Salomon7eae3e02018-08-07 14:02:38 +0000563 return CombineResult::kCannotCombine;
Brian Salomon5c6ac642017-12-19 11:09:32 -0500564 }
joshualitta751c972015-11-20 13:37:32 -0800565 }
566
Brian Salomon344ec422016-12-15 10:58:41 -0500567 fNumGlyphs += that->numGlyphs();
joshualitta751c972015-11-20 13:37:32 -0800568
Jim Van Verth56c37142017-10-31 14:44:25 -0400569 // Reallocate space for geo data if necessary and then import that geo's data.
joshualitta751c972015-11-20 13:37:32 -0800570 int newGeoCount = that->fGeoCount + fGeoCount;
joshualitta751c972015-11-20 13:37:32 -0800571
Jim Van Verthc8a65e32017-10-25 14:25:27 -0400572 // We reallocate at a rate of 1.5x to try to get better total memory usage
573 if (newGeoCount > fGeoDataAllocSize) {
Jim Van Verth56c37142017-10-31 14:44:25 -0400574 int newAllocSize = fGeoDataAllocSize + fGeoDataAllocSize / 2;
Jim Van Verthc8a65e32017-10-25 14:25:27 -0400575 while (newAllocSize < newGeoCount) {
576 newAllocSize += newAllocSize / 2;
577 }
joshualitta751c972015-11-20 13:37:32 -0800578 fGeoData.realloc(newAllocSize);
Jim Van Verthc8a65e32017-10-25 14:25:27 -0400579 fGeoDataAllocSize = newAllocSize;
joshualitta751c972015-11-20 13:37:32 -0800580 }
581
Brian Salomon344ec422016-12-15 10:58:41 -0500582 // We steal the ref on the blobs from the other AtlasTextOp and set its count to 0 so that
joshualitta751c972015-11-20 13:37:32 -0800583 // it doesn't try to unref them.
Brian Salomon344ec422016-12-15 10:58:41 -0500584 memcpy(&fGeoData[fGeoCount], that->fGeoData.get(), that->fGeoCount * sizeof(Geometry));
joshualitta751c972015-11-20 13:37:32 -0800585#ifdef SK_DEBUG
586 for (int i = 0; i < that->fGeoCount; ++i) {
Herb Derbyc514e7d2019-12-11 17:00:31 -0500587 that->fGeoData.get()[i].fBlob = (GrTextBlob*)0x1;
joshualitta751c972015-11-20 13:37:32 -0800588 }
589#endif
590 that->fGeoCount = 0;
591 fGeoCount = newGeoCount;
592
Brian Salomon7eae3e02018-08-07 14:02:38 +0000593 return CombineResult::kMerged;
joshualitta751c972015-11-20 13:37:32 -0800594}
595
joshualitta751c972015-11-20 13:37:32 -0800596// TODO trying to figure out why lcd is so whack
Herb Derby26cbe512018-05-24 14:39:01 -0400597// (see comments in GrTextContext::ComputeCanonicalColor)
Robert Phillips7cd0bfe2019-11-20 16:08:10 -0500598GrGeometryProcessor* GrAtlasTextOp::setupDfProcessor(SkArenaAlloc* arena,
599 const GrShaderCaps& caps,
Greg Daniel9715b6c2019-12-10 15:03:10 -0500600 const GrSurfaceProxyView* views,
601 unsigned int numActiveViews) const {
joshualitta751c972015-11-20 13:37:32 -0800602 bool isLCD = this->isLCD();
Brian Salomon5c6ac642017-12-19 11:09:32 -0500603
604 SkMatrix localMatrix = SkMatrix::I();
605 if (this->usesLocalCoords()) {
606 // If this fails we'll just use I().
Herb Derby1c5be7b2019-12-13 12:03:06 -0500607 bool result = fGeoData[0].fDrawMatrix.invert(&localMatrix);
Brian Salomon5c6ac642017-12-19 11:09:32 -0500608 (void)result;
609 }
joshualitta751c972015-11-20 13:37:32 -0800610
Robert Phillips841c9a52020-03-27 12:41:31 -0400611 auto dfAdjustTable = GrDistanceFieldAdjustTable::Get();
612
joshualitta751c972015-11-20 13:37:32 -0800613 // see if we need to create a new effect
614 if (isLCD) {
Robert Phillips841c9a52020-03-27 12:41:31 -0400615 float redCorrection = dfAdjustTable->getAdjustment(
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400616 SkColorGetR(fLuminanceColor) >> kDistanceAdjustLumShift,
Brian Salomon344ec422016-12-15 10:58:41 -0500617 fUseGammaCorrectDistanceTable);
Robert Phillips841c9a52020-03-27 12:41:31 -0400618 float greenCorrection = dfAdjustTable->getAdjustment(
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400619 SkColorGetG(fLuminanceColor) >> kDistanceAdjustLumShift,
Brian Salomon344ec422016-12-15 10:58:41 -0500620 fUseGammaCorrectDistanceTable);
Robert Phillips841c9a52020-03-27 12:41:31 -0400621 float blueCorrection = dfAdjustTable->getAdjustment(
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400622 SkColorGetB(fLuminanceColor) >> kDistanceAdjustLumShift,
Brian Salomon344ec422016-12-15 10:58:41 -0500623 fUseGammaCorrectDistanceTable);
joshualitta751c972015-11-20 13:37:32 -0800624 GrDistanceFieldLCDTextGeoProc::DistanceAdjust widthAdjust =
Brian Salomon344ec422016-12-15 10:58:41 -0500625 GrDistanceFieldLCDTextGeoProc::DistanceAdjust::Make(
626 redCorrection, greenCorrection, blueCorrection);
Greg Daniel9715b6c2019-12-10 15:03:10 -0500627 return GrDistanceFieldLCDTextGeoProc::Make(arena, caps, views, numActiveViews,
Brian Salomonccb61422020-01-09 10:46:36 -0500628 GrSamplerState::Filter::kBilerp, widthAdjust,
Brian Osman09068252018-01-03 09:57:29 -0500629 fDFGPFlags, localMatrix);
joshualitta751c972015-11-20 13:37:32 -0800630 } else {
joshualitta751c972015-11-20 13:37:32 -0800631#ifdef SK_GAMMA_APPLY_TO_A8
Jim Van Verth90e89b32017-07-06 16:36:55 -0400632 float correction = 0;
633 if (kAliasedDistanceField_MaskType != fMaskType) {
Jim Van Verth58c3cce2017-10-19 15:50:24 -0400634 U8CPU lum = SkColorSpaceLuminance::computeLuminance(SK_GAMMA_EXPONENT,
635 fLuminanceColor);
Robert Phillips841c9a52020-03-27 12:41:31 -0400636 correction = dfAdjustTable->getAdjustment(lum >> kDistanceAdjustLumShift,
637 fUseGammaCorrectDistanceTable);
Jim Van Verth90e89b32017-07-06 16:36:55 -0400638 }
Greg Daniel9715b6c2019-12-10 15:03:10 -0500639 return GrDistanceFieldA8TextGeoProc::Make(arena, caps, views, numActiveViews,
Brian Salomonccb61422020-01-09 10:46:36 -0500640 GrSamplerState::Filter::kBilerp, correction,
641 fDFGPFlags, localMatrix);
joshualitta751c972015-11-20 13:37:32 -0800642#else
Greg Daniel9715b6c2019-12-10 15:03:10 -0500643 return GrDistanceFieldA8TextGeoProc::Make(arena, caps, views, numActiveViews,
Brian Salomonccb61422020-01-09 10:46:36 -0500644 GrSamplerState::Filter::kBilerp,
Brian Salomon5c6ac642017-12-19 11:09:32 -0500645 fDFGPFlags, localMatrix);
joshualitta751c972015-11-20 13:37:32 -0800646#endif
647 }
joshualitta751c972015-11-20 13:37:32 -0800648}
joshualittddd22d82016-02-16 06:47:52 -0800649