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 #include "GrAtlasTextContext.h" | 7 #include "GrAtlasTextContext.h" |
8 | 8 |
9 #include "GrAtlas.h" | 9 #include "GrAtlas.h" |
10 #include "GrBatch.h" | 10 #include "GrBatch.h" |
(...skipping 763 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
774 | 774 |
775 subRun->fGlyphEndIndex++; | 775 subRun->fGlyphEndIndex++; |
776 subRun->fVertexEndIndex += vertexStride * kVerticesPerGlyph; | 776 subRun->fVertexEndIndex += vertexStride * kVerticesPerGlyph; |
777 } | 777 } |
778 | 778 |
779 class BitmapTextBatch : public GrBatch { | 779 class BitmapTextBatch : public GrBatch { |
780 public: | 780 public: |
781 typedef GrAtlasTextContext::BitmapTextBlob Blob; | 781 typedef GrAtlasTextContext::BitmapTextBlob Blob; |
782 typedef Blob::Run Run; | 782 typedef Blob::Run Run; |
783 typedef Run::SubRunInfo TextInfo; | 783 typedef Run::SubRunInfo TextInfo; |
784 struct Geometry { | 784 struct Geometry { |
bsalomon
2015/04/13 15:06:16
SubRunGeometry?
| |
785 Geometry() {} | 785 Blob* fBlob; |
786 Geometry(const Geometry& geometry) | |
787 : fBlob(SkRef(geometry.fBlob.get())) | |
788 , fRun(geometry.fRun) | |
789 , fSubRun(geometry.fSubRun) | |
790 , fColor(geometry.fColor) | |
791 , fTransX(geometry.fTransX) | |
792 , fTransY(geometry.fTransY) {} | |
793 SkAutoTUnref<Blob> fBlob; | |
794 int fRun; | 786 int fRun; |
795 int fSubRun; | 787 int fSubRun; |
796 GrColor fColor; | 788 GrColor fColor; |
797 SkScalar fTransX; | 789 SkScalar fTransX; |
798 SkScalar fTransY; | 790 SkScalar fTransY; |
799 }; | 791 }; |
800 | 792 |
801 static GrBatch* Create(const Geometry& geometry, GrMaskFormat maskFormat, | 793 static BitmapTextBatch* Create(GrMaskFormat maskFormat, int glyphCount, |
802 int glyphCount, GrBatchFontCache* fontCache) { | 794 GrBatchFontCache* fontCache) { |
803 return SkNEW_ARGS(BitmapTextBatch, (geometry, maskFormat, glyphCount, fo ntCache)); | 795 return SkNEW_ARGS(BitmapTextBatch, (maskFormat, glyphCount, fontCache)); |
804 } | 796 } |
805 | 797 |
806 const char* name() const override { return "BitmapTextBatch"; } | 798 const char* name() const override { return "BitmapTextBatch"; } |
807 | 799 |
808 void getInvariantOutputColor(GrInitInvariantOutput* out) const override { | 800 void getInvariantOutputColor(GrInitInvariantOutput* out) const override { |
809 if (kARGB_GrMaskFormat == fMaskFormat) { | 801 if (kARGB_GrMaskFormat == fMaskFormat) { |
810 out->setUnknownFourComponents(); | 802 out->setUnknownFourComponents(); |
811 } else { | 803 } else { |
812 out->setKnownFourComponents(fBatch.fColor); | 804 out->setKnownFourComponents(fBatch.fColor); |
813 } | 805 } |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
869 fMaskFormat, | 861 fMaskFormat, |
870 opaqueVertexColors, | 862 opaqueVertexColors, |
871 localMatrix)); | 863 localMatrix)); |
872 | 864 |
873 size_t vertexStride = gp->getVertexStride(); | 865 size_t vertexStride = gp->getVertexStride(); |
874 SkASSERT(vertexStride == get_vertex_stride(fMaskFormat)); | 866 SkASSERT(vertexStride == get_vertex_stride(fMaskFormat)); |
875 | 867 |
876 this->initDraw(batchTarget, gp, pipeline); | 868 this->initDraw(batchTarget, gp, pipeline); |
877 | 869 |
878 int glyphCount = this->numGlyphs(); | 870 int glyphCount = this->numGlyphs(); |
879 int instanceCount = fGeoData.count(); | 871 int instanceCount = fInstanceCount; |
880 const GrVertexBuffer* vertexBuffer; | 872 const GrVertexBuffer* vertexBuffer; |
881 int firstVertex; | 873 int firstVertex; |
882 | 874 |
883 void* vertices = batchTarget->vertexPool()->makeSpace(vertexStride, | 875 void* vertices = batchTarget->vertexPool()->makeSpace(vertexStride, |
884 glyphCount * kVert icesPerGlyph, | 876 glyphCount * kVert icesPerGlyph, |
885 &vertexBuffer, | 877 &vertexBuffer, |
886 &firstVertex); | 878 &firstVertex); |
887 if (!vertices) { | 879 if (!vertices) { |
888 SkDebugf("Could not allocate vertices\n"); | 880 SkDebugf("Could not allocate vertices\n"); |
889 return; | 881 return; |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1011 // now copy all vertices | 1003 // now copy all vertices |
1012 size_t byteCount = info.fVertexEndIndex - info.fVertexStartIndex; | 1004 size_t byteCount = info.fVertexEndIndex - info.fVertexStartIndex; |
1013 memcpy(currVertex, blob->fVertices + info.fVertexStartIndex, byteCou nt); | 1005 memcpy(currVertex, blob->fVertices + info.fVertexStartIndex, byteCou nt); |
1014 | 1006 |
1015 currVertex += byteCount; | 1007 currVertex += byteCount; |
1016 } | 1008 } |
1017 | 1009 |
1018 this->flush(batchTarget, &drawInfo, instancesToFlush, maxInstancesPerDra w); | 1010 this->flush(batchTarget, &drawInfo, instancesToFlush, maxInstancesPerDra w); |
1019 } | 1011 } |
1020 | 1012 |
1021 SkSTArray<1, Geometry, true>* geoData() { return &fGeoData; } | 1013 static const int kMinAllocated = 32; |
bsalomon
2015/04/13 15:06:16
min allocated for what? is it a count or a bytes?
| |
1014 size_t instanceCount() const { return fInstanceCount; } | |
bsalomon
2015/04/13 15:06:16
instances of what?
| |
1015 SkAutoSTMalloc<kMinAllocated, Geometry>* geoData() { return &fGeoData; } | |
1016 | |
1017 Geometry& geometry() { return fGeoData[0]; } | |
bsalomon
2015/04/13 15:06:16
comment about why we have a getter just for the fi
| |
1018 void init() { | |
1019 fBatch.fColor = fGeoData[0].fColor; | |
1020 fBatch.fViewMatrix = fGeoData[0].fBlob->fViewMatrix; | |
1021 } | |
1022 | 1022 |
1023 private: | 1023 private: |
1024 BitmapTextBatch(const Geometry& geometry, GrMaskFormat maskFormat, | 1024 BitmapTextBatch(GrMaskFormat maskFormat, |
1025 int glyphCount, GrBatchFontCache* fontCache) | 1025 int glyphCount, GrBatchFontCache* fontCache) |
1026 : fMaskFormat(maskFormat) | 1026 : fMaskFormat(maskFormat) |
1027 , fPixelConfig(fontCache->getPixelConfig(maskFormat)) | 1027 , fPixelConfig(fontCache->getPixelConfig(maskFormat)) |
1028 , fFontCache(fontCache) { | 1028 , fFontCache(fontCache) { |
1029 this->initClassID<BitmapTextBatch>(); | 1029 this->initClassID<BitmapTextBatch>(); |
1030 fGeoData.push_back(geometry); | |
1031 fBatch.fColor = geometry.fColor; | |
1032 fBatch.fViewMatrix = geometry.fBlob->fViewMatrix; | |
1033 fBatch.fNumGlyphs = glyphCount; | 1030 fBatch.fNumGlyphs = glyphCount; |
1031 fInstanceCount = 1; | |
1032 fAllocatedCount = kMinAllocated; | |
1033 } | |
1034 | |
1035 ~BitmapTextBatch() { | |
1036 for (size_t i = 0; i < fInstanceCount; i++) { | |
1037 fGeoData[i].fBlob->unref(); | |
1038 } | |
1034 } | 1039 } |
1035 | 1040 |
1036 void regenerateTextureCoords(GrGlyph* glyph, intptr_t vertex, size_t vertexS tride) { | 1041 void regenerateTextureCoords(GrGlyph* glyph, intptr_t vertex, size_t vertexS tride) { |
1037 int width = glyph->fBounds.width(); | 1042 int width = glyph->fBounds.width(); |
1038 int height = glyph->fBounds.height(); | 1043 int height = glyph->fBounds.height(); |
1039 int u0 = glyph->fAtlasLocation.fX; | 1044 int u0 = glyph->fAtlasLocation.fX; |
1040 int v0 = glyph->fAtlasLocation.fY; | 1045 int v0 = glyph->fAtlasLocation.fY; |
1041 int u1 = u0 + width; | 1046 int u1 = u0 + width; |
1042 int v1 = v0 + height; | 1047 int v1 = v0 + height; |
1043 | 1048 |
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1126 | 1131 |
1127 if (this->fMaskFormat != kA8_GrMaskFormat && this->color() != that->colo r()) { | 1132 if (this->fMaskFormat != kA8_GrMaskFormat && this->color() != that->colo r()) { |
1128 return false; | 1133 return false; |
1129 } | 1134 } |
1130 | 1135 |
1131 if (this->usesLocalCoords() && !this->viewMatrix().cheapEqualTo(that->vi ewMatrix())) { | 1136 if (this->usesLocalCoords() && !this->viewMatrix().cheapEqualTo(that->vi ewMatrix())) { |
1132 return false; | 1137 return false; |
1133 } | 1138 } |
1134 | 1139 |
1135 fBatch.fNumGlyphs += that->numGlyphs(); | 1140 fBatch.fNumGlyphs += that->numGlyphs(); |
1136 fGeoData.push_back_n(that->geoData()->count(), that->geoData()->begin()) ; | 1141 |
1142 // copy that->geoData(). We do this manually for performance reasons | |
1143 SkAutoSTMalloc<kMinAllocated, Geometry>* otherGeoData = that->geoData(); | |
1144 size_t otherInstanceCount = that->instanceCount(); | |
1145 size_t allocSize = otherInstanceCount + fInstanceCount; | |
1146 if (allocSize > fAllocatedCount) { | |
1147 while (allocSize > fAllocatedCount) { | |
1148 fAllocatedCount = fAllocatedCount << 1; | |
1149 } | |
1150 fGeoData.realloc(fAllocatedCount); | |
1151 } | |
1152 | |
1153 memcpy(&fGeoData[fInstanceCount], otherGeoData->get(), | |
1154 otherInstanceCount * sizeof(Geometry)); | |
1155 size_t total = fInstanceCount + otherInstanceCount; | |
1156 for (size_t i = fInstanceCount; i < total; i++) { | |
1157 fGeoData[i].fBlob->ref(); | |
1158 } | |
1159 fInstanceCount = total; | |
1137 return true; | 1160 return true; |
1138 } | 1161 } |
1139 | 1162 |
1140 struct BatchTracker { | 1163 struct BatchTracker { |
1141 GrColor fColor; | 1164 GrColor fColor; |
1142 SkMatrix fViewMatrix; | 1165 SkMatrix fViewMatrix; |
1143 bool fUsesLocalCoords; | 1166 bool fUsesLocalCoords; |
1144 bool fColorIgnored; | 1167 bool fColorIgnored; |
1145 bool fCoverageIgnored; | 1168 bool fCoverageIgnored; |
1146 int fNumGlyphs; | 1169 int fNumGlyphs; |
1147 }; | 1170 }; |
1148 | 1171 |
1149 BatchTracker fBatch; | 1172 BatchTracker fBatch; |
1150 SkSTArray<1, Geometry, true> fGeoData; | 1173 SkAutoSTMalloc<kMinAllocated, Geometry> fGeoData; |
1174 size_t fInstanceCount; | |
1175 size_t fAllocatedCount; | |
1176 //SkSTArray<1, Geometry, true> fGeoData; | |
1151 GrMaskFormat fMaskFormat; | 1177 GrMaskFormat fMaskFormat; |
1152 GrPixelConfig fPixelConfig; | 1178 GrPixelConfig fPixelConfig; |
1153 GrBatchFontCache* fFontCache; | 1179 GrBatchFontCache* fFontCache; |
1154 }; | 1180 }; |
1155 | 1181 |
1156 void GrAtlasTextContext::flushRunAsPaths(const SkTextBlob::RunIterator& it, cons t SkPaint& skPaint, | 1182 void GrAtlasTextContext::flushRunAsPaths(const SkTextBlob::RunIterator& it, cons t SkPaint& skPaint, |
1157 SkDrawFilter* drawFilter, const SkMatri x& viewMatrix, | 1183 SkDrawFilter* drawFilter, const SkMatri x& viewMatrix, |
1158 const SkIRect& clipBounds, SkScalar x, SkScalar y) { | 1184 const SkIRect& clipBounds, SkScalar x, SkScalar y) { |
1159 SkPaint runPaint = skPaint; | 1185 SkPaint runPaint = skPaint; |
1160 | 1186 |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1194 int glyphCount = info.fGlyphEndIndex - info.fGlyphStartIndex; | 1220 int glyphCount = info.fGlyphEndIndex - info.fGlyphStartIndex; |
1195 if (0 == glyphCount) { | 1221 if (0 == glyphCount) { |
1196 continue; | 1222 continue; |
1197 } | 1223 } |
1198 | 1224 |
1199 GrMaskFormat format = info.fMaskFormat; | 1225 GrMaskFormat format = info.fMaskFormat; |
1200 GrColor subRunColor = kARGB_GrMaskFormat == format ? | 1226 GrColor subRunColor = kARGB_GrMaskFormat == format ? |
1201 SkColorSetARGB(paintAlpha, paintAlpha, paintAlpha, paintAlpha) : | 1227 SkColorSetARGB(paintAlpha, paintAlpha, paintAlpha, paintAlpha) : |
1202 color; | 1228 color; |
1203 | 1229 |
1204 BitmapTextBatch::Geometry geometry; | 1230 SkAutoTUnref<BitmapTextBatch> batch(BitmapTextBatch::Create(format, glyp hCount, |
1205 geometry.fBlob.reset(SkRef(cacheBlob)); | 1231 fContext->getBatchFo ntCache())); |
1232 BitmapTextBatch::Geometry& geometry = batch->geometry(); | |
1233 geometry.fBlob = SkRef(cacheBlob); | |
1206 geometry.fRun = run; | 1234 geometry.fRun = run; |
1207 geometry.fSubRun = static_cast<int>(subRun); | 1235 geometry.fSubRun = static_cast<int>(subRun); |
1208 geometry.fColor = subRunColor; | 1236 geometry.fColor = subRunColor; |
1209 geometry.fTransX = transX; | 1237 geometry.fTransX = transX; |
1210 geometry.fTransY = transY; | 1238 geometry.fTransY = transY; |
1211 SkAutoTUnref<GrBatch> batch(BitmapTextBatch::Create(geometry, format, gl yphCount, | 1239 batch->init(); |
1212 fContext->getBatchFo ntCache())); | |
1213 | 1240 |
1214 target->drawBatch(pipelineBuilder, batch, &cacheBlob->fRuns[run].fVertex Bounds); | 1241 target->drawBatch(pipelineBuilder, batch, &cacheBlob->fRuns[run].fVertex Bounds); |
1215 } | 1242 } |
1216 } | 1243 } |
1217 | 1244 |
1218 inline void GrAtlasTextContext::flushBigGlyphs(BitmapTextBlob* cacheBlob, GrRend erTarget* rt, | 1245 inline void GrAtlasTextContext::flushBigGlyphs(BitmapTextBlob* cacheBlob, GrRend erTarget* rt, |
1219 const GrPaint& grPaint, const GrC lip& clip, | 1246 const GrPaint& grPaint, const GrC lip& clip, |
1220 SkScalar transX, SkScalar transY) { | 1247 SkScalar transX, SkScalar transY) { |
1221 for (int i = 0; i < cacheBlob->fBigGlyphs.count(); i++) { | 1248 for (int i = 0; i < cacheBlob->fBigGlyphs.count(); i++) { |
1222 BitmapTextBlob::BigGlyph& bigGlyph = cacheBlob->fBigGlyphs[i]; | 1249 BitmapTextBlob::BigGlyph& bigGlyph = cacheBlob->fBigGlyphs[i]; |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1278 | 1305 |
1279 GrColor color = grPaint.getColor(); | 1306 GrColor color = grPaint.getColor(); |
1280 uint8_t paintAlpha = skPaint.getAlpha(); | 1307 uint8_t paintAlpha = skPaint.getAlpha(); |
1281 for (int run = 0; run < cacheBlob->fRunCount; run++) { | 1308 for (int run = 0; run < cacheBlob->fRunCount; run++) { |
1282 this->flushRun(target, &pipelineBuilder, cacheBlob, run, color, paintAlp ha, 0, 0); | 1309 this->flushRun(target, &pipelineBuilder, cacheBlob, run, color, paintAlp ha, 0, 0); |
1283 } | 1310 } |
1284 | 1311 |
1285 // Now flush big glyphs | 1312 // Now flush big glyphs |
1286 this->flushBigGlyphs(cacheBlob, rt, grPaint, clip, 0, 0); | 1313 this->flushBigGlyphs(cacheBlob, rt, grPaint, clip, 0, 0); |
1287 } | 1314 } |
OLD | NEW |