GrNonAAFillRectOp.cpp revision 25a880960a9a689a745a01071ecba3fe494b5940
19c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt/* 29c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt * Copyright 2015 Google Inc. 39c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt * 49c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt * Use of this source code is governed by a BSD-style license that can be 59c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt * found in the LICENSE file. 69c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt */ 79c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 8bcf33d5c06f7560039797b6023f14466c75598edjoshualitt#include "GrNonAAFillRectBatch.h" 99c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 107539856c1b9cbb1886a6a498cc534b77fc83ddb2bsalomon#include "GrBatchFlushState.h" 119c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#include "GrColor.h" 129c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#include "GrDefaultGeoProcFactory.h" 139c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#include "GrPrimitiveProcessor.h" 142244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt#include "GrResourceProvider.h" 15ae5b2c623b22b24ea7c0d6200298e5bc366faa63joshualitt#include "GrQuad.h" 1616b991390bb988b194a868ab8de66db4c21c7c13bsalomon#include "GrVertexBatch.h" 179c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 18a39667c848146d9070e1a45662fb292d8e6bb8fbreed#include "SkMatrixPriv.h" 19a39667c848146d9070e1a45662fb292d8e6bb8fbreed 2008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomonstatic const int kVertsPerInstance = 4; 2108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomonstatic const int kIndicesPerInstance = 6; 222244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 232244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt/** We always use per-vertex colors so that rects can be batched across color changes. Sometimes 242244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt we have explicit local coords and sometimes not. We *could* always provide explicit local 252244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt coords and just duplicate the positions when the caller hasn't provided a local coord rect, 262244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt but we haven't seen a use case which frequently switches between local rect and no local 272244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt rect draws. 282244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 292244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt The vertex attrib order is always pos, color, [local coords]. 302244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt */ 316abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillipsstatic sk_sp<GrGeometryProcessor> make_gp(bool readsCoverage) { 326abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips using namespace GrDefaultGeoProcFactory; 336abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips Color color(Color::kAttribute_Type); 346abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips Coverage coverage(readsCoverage ? Coverage::kSolid_Type : Coverage::kNone_Type); 356abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips 366abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips LocalCoords localCoords(LocalCoords::kHasExplicit_Type); 376abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips return GrDefaultGeoProcFactory::Make(color, coverage, localCoords, SkMatrix::I()); 386abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips} 396abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips 402244c27ea4db85df305fa09f664b7d75f637e7a9joshualittstatic void tesselate(intptr_t vertices, 412244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt size_t vertexStride, 422244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt GrColor color, 436abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips const SkMatrix* viewMatrix, 442244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt const SkRect& rect, 458cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt const GrQuad* localQuad) { 462244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt SkPoint* positions = reinterpret_cast<SkPoint*>(vertices); 472244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 482244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt positions->setRectFan(rect.fLeft, rect.fTop, 492244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt rect.fRight, rect.fBottom, vertexStride); 509c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 516abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips if (viewMatrix) { 52a39667c848146d9070e1a45662fb292d8e6bb8fbreed SkMatrixPriv::MapPointsWithStride(*viewMatrix, positions, vertexStride, kVertsPerInstance); 538cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt } 548cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt 558cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt // Setup local coords 562244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt // TODO we should only do this if local coords are being read 578cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt if (localQuad) { 582244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt static const int kLocalOffset = sizeof(SkPoint) + sizeof(GrColor); 5908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon for (int i = 0; i < kVertsPerInstance; i++) { 608cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt SkPoint* coords = reinterpret_cast<SkPoint*>(vertices + kLocalOffset + 618cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt i * vertexStride); 628cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt *coords = localQuad->point(i); 632244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt } 642244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt } 652244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 662244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt static const int kColorOffset = sizeof(SkPoint); 672244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt GrColor* vertColor = reinterpret_cast<GrColor*>(vertices + kColorOffset); 682244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt for (int j = 0; j < 4; ++j) { 692244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt *vertColor = color; 702244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt vertColor = (GrColor*) ((intptr_t) vertColor + vertexStride); 712244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt } 722244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt} 732244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 7408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomonclass NonAAFillRectBatch : public GrVertexBatch { 759c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualittpublic: 7625a880960a9a689a745a01071ecba3fe494b5940Brian Salomon DEFINE_OP_CLASS_ID 7708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 789d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon NonAAFillRectBatch(GrColor color, const SkMatrix& viewMatrix, const SkRect& rect, 799d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon const SkRect* localRect, const SkMatrix* localMatrix) 809d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon : INHERITED(ClassID()) { 819d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon SkASSERT(!viewMatrix.hasPerspective() && (!localMatrix || 829d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon !localMatrix->hasPerspective())); 839d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon RectInfo& info = fRects.push_back(); 849d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fColor = color; 859d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fViewMatrix = viewMatrix; 869d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fRect = rect; 879d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon if (localRect && localMatrix) { 889d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fLocalQuad.setFromMappedRect(*localRect, *localMatrix); 899d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon } else if (localRect) { 909d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fLocalQuad.set(*localRect); 919d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon } else if (localMatrix) { 929d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fLocalQuad.setFromMappedRect(rect, *localMatrix); 939d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon } else { 949d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fLocalQuad.set(rect); 959d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon } 9688cf17d099085b8085ab11571b5094163dbb2c84bsalomon this->setTransformedBounds(fRects[0].fRect, viewMatrix, HasAABloat::kNo, IsZeroArea::kNo); 979d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon } 9808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 99bc9b6a4239b797fe7fbdb876607053b18eba2380bsalomon const char* name() const override { return "NonAAFillRectBatch"; } 10008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 10108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon SkString dumpInfo() const override { 10208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon SkString str; 1039d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon str.appendf("# batched: %d\n", fRects.count()); 1049d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon for (int i = 0; i < fRects.count(); ++i) { 1059d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon const RectInfo& info = fRects[i]; 106bc9b6a4239b797fe7fbdb876607053b18eba2380bsalomon str.appendf("%d: Color: 0x%08x, Rect [L: %.2f, T: %.2f, R: %.2f, B: %.2f]\n", 1079d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon i, info.fColor, 1089d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon info.fRect.fLeft, info.fRect.fTop, info.fRect.fRight, info.fRect.fBottom); 10908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 1107c3e7180948766321c51d165737555e78910de51Brian Salomon str.append(DumpPipelineInfo(*this->pipeline())); 11108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon str.append(INHERITED::dumpInfo()); 11208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon return str; 11308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 11408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 11508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon void computePipelineOptimizations(GrInitInvariantOutput* color, 11608d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon GrInitInvariantOutput* coverage, 11708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon GrBatchToXPOverrides* overrides) const override { 11808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon // When this is called on a batch, there is only one geometry bundle 1199d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon color->setKnownFourComponents(fRects[0].fColor); 120bc9b6a4239b797fe7fbdb876607053b18eba2380bsalomon coverage->setKnownSingleComponent(0xff); 12108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 12208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 12308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon void initBatchTracker(const GrXPOverridesForBatch& overrides) override { 1249d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon overrides.getOverrideColorIfSet(&fRects[0].fColor); 12508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon fOverrides = overrides; 12608d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 12708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 12808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomonprivate: 12908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon NonAAFillRectBatch() : INHERITED(ClassID()) {} 13008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 13108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon void onPrepareDraws(Target* target) const override { 1326abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips sk_sp<GrGeometryProcessor> gp = make_gp(fOverrides.readsCoverage()); 13308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon if (!gp) { 13408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon SkDebugf("Couldn't create GrGeometryProcessor\n"); 13508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon return; 13608d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 137bc9b6a4239b797fe7fbdb876607053b18eba2380bsalomon SkASSERT(gp->getVertexStride() == 138bc9b6a4239b797fe7fbdb876607053b18eba2380bsalomon sizeof(GrDefaultGeoProcFactory::PositionColorLocalCoordAttr)); 13908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 14008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon size_t vertexStride = gp->getVertexStride(); 1419d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon int instanceCount = fRects.count(); 14208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 143144caf55ffc692bcda77703a73bb9a894f7d024fHal Canary sk_sp<const GrBuffer> indexBuffer(target->resourceProvider()->refQuadIndexBuffer()); 14408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon InstancedHelper helper; 14508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon void* vertices = helper.init(target, kTriangles_GrPrimitiveType, vertexStride, 146144caf55ffc692bcda77703a73bb9a894f7d024fHal Canary indexBuffer.get(), kVertsPerInstance, 14708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon kIndicesPerInstance, instanceCount); 14808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon if (!vertices || !indexBuffer) { 14908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon SkDebugf("Could not allocate vertices\n"); 15008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon return; 15108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 15208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 15308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon for (int i = 0; i < instanceCount; i++) { 15408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon intptr_t verts = reinterpret_cast<intptr_t>(vertices) + 15508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon i * kVertsPerInstance * vertexStride; 1566abd1d192e0b2698d19e0b03fe4c2a34fb604b8frobertphillips tesselate(verts, vertexStride, fRects[i].fColor, &fRects[i].fViewMatrix, 1579d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon fRects[i].fRect, &fRects[i].fLocalQuad); 15808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 15908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon helper.recordDraw(target, gp.get()); 16008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 16108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 16225a880960a9a689a745a01071ecba3fe494b5940Brian Salomon bool onCombineIfPossible(GrOp* t, const GrCaps& caps) override { 16308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon NonAAFillRectBatch* that = t->cast<NonAAFillRectBatch>(); 16408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon if (!GrPipeline::CanCombine(*this->pipeline(), this->bounds(), *that->pipeline(), 16508d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon that->bounds(), caps)) { 16608d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon return false; 16708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 16808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 16908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon // In the event of two batches, one who can tweak, one who cannot, we just fall back to 17008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon // not tweaking 17108d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon if (fOverrides.canTweakAlphaForCoverage() && !that->fOverrides.canTweakAlphaForCoverage()) { 17208d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon fOverrides = that->fOverrides; 17308d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 17408d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 1759d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon fRects.push_back_n(that->fRects.count(), that->fRects.begin()); 17688cf17d099085b8085ab11571b5094163dbb2c84bsalomon this->joinBounds(*that); 17708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon return true; 17808d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon } 17908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 1809d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon struct RectInfo { 1819d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon GrColor fColor; 1829d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon SkMatrix fViewMatrix; 1839d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon SkRect fRect; 1849d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon GrQuad fLocalQuad; 1859d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon }; 1869d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon 18708d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon GrXPOverridesForBatch fOverrides; 1889d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon SkSTArray<1, RectInfo, true> fRects; 18908d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon 19008d141534cb24a491edbf5db31cdc7b966ec8d72bsalomon typedef GrVertexBatch INHERITED; 1912244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt}; 1929c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 193b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomonnamespace GrNonAAFillRectBatch { 194b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomon 195b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomonGrDrawBatch* Create(GrColor color, 196b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomon const SkMatrix& viewMatrix, 197b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomon const SkRect& rect, 198b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomon const SkRect* localRect, 199b8cbd2098225ee2ec1bd96b3e2b1cf3f5164d2d8bsalomon const SkMatrix* localMatrix) { 2009d7f1849a88f5f2f6c7c00fe826d1d42a2df990fbsalomon return new NonAAFillRectBatch(color, viewMatrix, rect, localRect, localMatrix); 2013566d44d852b2fc1773e41e80c0c19610aa6d43bjoshualitt} 2028cce8f139e4b91783722f11ccb6ac9bbdf8327e7joshualitt 2039c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt}; 2049c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 2059c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt/////////////////////////////////////////////////////////////////////////////////////////////////// 2069c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 2079c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#ifdef GR_TEST_UTILS 2089c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 2099c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#include "GrBatchTest.h" 2109c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 211abd30f54b7ff1704a8930c4307ea242d09425d02bsalomonDRAW_BATCH_TEST_DEFINE(RectBatch) { 2122244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt GrColor color = GrRandomColor(random); 2132244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt SkRect rect = GrTest::TestRect(random); 2142244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt SkRect localRect = GrTest::TestRect(random); 2152244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt SkMatrix viewMatrix = GrTest::TestMatrixInvertible(random); 2162244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt SkMatrix localMatrix = GrTest::TestMatrix(random); 2172244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt 2182244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt bool hasLocalRect = random->nextBool(); 2192244c27ea4db85df305fa09f664b7d75f637e7a9joshualitt bool hasLocalMatrix = random->nextBool(); 220bcf33d5c06f7560039797b6023f14466c75598edjoshualitt return GrNonAAFillRectBatch::Create(color, viewMatrix, rect, 221bcf33d5c06f7560039797b6023f14466c75598edjoshualitt hasLocalRect ? &localRect : nullptr, 222bcf33d5c06f7560039797b6023f14466c75598edjoshualitt hasLocalMatrix ? &localMatrix : nullptr); 2239c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt} 2249c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt 2259c80b5ff592caf1c18b43e98c85bc8340b3ac531joshualitt#endif 226