OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 "GrAAHairLinePathRenderer.h" | 8 #include "GrAAHairLinePathRenderer.h" |
9 | 9 |
10 #include "GrBatch.h" | 10 #include "GrBatch.h" |
(...skipping 877 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
888 const GrVertexBuffer* vertexBuffer; | 888 const GrVertexBuffer* vertexBuffer; |
889 int firstVertex; | 889 int firstVertex; |
890 | 890 |
891 size_t vertexStride = lineGP->getVertexStride(); | 891 size_t vertexStride = lineGP->getVertexStride(); |
892 int vertexCount = kLineSegNumVertices * lineCount; | 892 int vertexCount = kLineSegNumVertices * lineCount; |
893 void *vertices = batchTarget->vertexPool()->makeSpace(vertexStride, | 893 void *vertices = batchTarget->vertexPool()->makeSpace(vertexStride, |
894 vertexCount, | 894 vertexCount, |
895 &vertexBuffer, | 895 &vertexBuffer, |
896 &firstVertex); | 896 &firstVertex); |
897 | 897 |
| 898 if (!vertices) { |
| 899 SkDebugf("Could not allocate vertices\n"); |
| 900 return; |
| 901 } |
| 902 |
898 SkASSERT(lineGP->getVertexStride() == sizeof(LineVertex)); | 903 SkASSERT(lineGP->getVertexStride() == sizeof(LineVertex)); |
899 | 904 |
900 LineVertex* verts = reinterpret_cast<LineVertex*>(vertices); | 905 LineVertex* verts = reinterpret_cast<LineVertex*>(vertices); |
901 for (int i = 0; i < lineCount; ++i) { | 906 for (int i = 0; i < lineCount; ++i) { |
902 add_line(&lines[2*i], toSrc, this->coverage(), &verts); | 907 add_line(&lines[2*i], toSrc, this->coverage(), &verts); |
903 } | 908 } |
904 | 909 |
905 { | 910 { |
906 GrDrawTarget::DrawInfo info; | 911 GrDrawTarget::DrawInfo info; |
907 info.setVertexBuffer(vertexBuffer); | 912 info.setVertexBuffer(vertexBuffer); |
(...skipping 19 matching lines...) Expand all Loading... |
927 const GrVertexBuffer* vertexBuffer; | 932 const GrVertexBuffer* vertexBuffer; |
928 int firstVertex; | 933 int firstVertex; |
929 | 934 |
930 size_t vertexStride = sizeof(BezierVertex); | 935 size_t vertexStride = sizeof(BezierVertex); |
931 int vertexCount = kQuadNumVertices * quadCount + kQuadNumVertices * coni
cCount; | 936 int vertexCount = kQuadNumVertices * quadCount + kQuadNumVertices * coni
cCount; |
932 void *vertices = batchTarget->vertexPool()->makeSpace(vertexStride, | 937 void *vertices = batchTarget->vertexPool()->makeSpace(vertexStride, |
933 vertexCount, | 938 vertexCount, |
934 &vertexBuffer, | 939 &vertexBuffer, |
935 &firstVertex); | 940 &firstVertex); |
936 | 941 |
| 942 if (!vertices) { |
| 943 SkDebugf("Could not allocate vertices\n"); |
| 944 return; |
| 945 } |
| 946 |
937 // Setup vertices | 947 // Setup vertices |
938 BezierVertex* verts = reinterpret_cast<BezierVertex*>(vertices); | 948 BezierVertex* verts = reinterpret_cast<BezierVertex*>(vertices); |
939 | 949 |
940 int unsubdivQuadCnt = quads.count() / 3; | 950 int unsubdivQuadCnt = quads.count() / 3; |
941 for (int i = 0; i < unsubdivQuadCnt; ++i) { | 951 for (int i = 0; i < unsubdivQuadCnt; ++i) { |
942 SkASSERT(qSubdivs[i] >= 0); | 952 SkASSERT(qSubdivs[i] >= 0); |
943 add_quads(&quads[3*i], qSubdivs[i], toDevice, toSrc, &verts); | 953 add_quads(&quads[3*i], qSubdivs[i], toDevice, toSrc, &verts); |
944 } | 954 } |
945 | 955 |
946 // Start Conics | 956 // Start Conics |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1014 } | 1024 } |
1015 } | 1025 } |
1016 | 1026 |
1017 bool GrAAHairLinePathRenderer::onDrawPath(GrDrawTarget* target, | 1027 bool GrAAHairLinePathRenderer::onDrawPath(GrDrawTarget* target, |
1018 GrPipelineBuilder* pipelineBuilder, | 1028 GrPipelineBuilder* pipelineBuilder, |
1019 GrColor color, | 1029 GrColor color, |
1020 const SkMatrix& viewMatrix, | 1030 const SkMatrix& viewMatrix, |
1021 const SkPath& path, | 1031 const SkPath& path, |
1022 const SkStrokeRec& stroke, | 1032 const SkStrokeRec& stroke, |
1023 bool) { | 1033 bool) { |
| 1034 if (!fLinesIndexBuffer || !fQuadsIndexBuffer) { |
| 1035 SkDebugf("unable to allocate indices\n"); |
| 1036 return false; |
| 1037 } |
| 1038 |
1024 SkScalar hairlineCoverage; | 1039 SkScalar hairlineCoverage; |
1025 uint8_t newCoverage = 0xff; | 1040 uint8_t newCoverage = 0xff; |
1026 if (IsStrokeHairlineOrEquivalent(stroke, viewMatrix, &hairlineCoverage)) { | 1041 if (IsStrokeHairlineOrEquivalent(stroke, viewMatrix, &hairlineCoverage)) { |
1027 newCoverage = SkScalarRoundToInt(hairlineCoverage * 0xff); | 1042 newCoverage = SkScalarRoundToInt(hairlineCoverage * 0xff); |
1028 } | 1043 } |
1029 | 1044 |
1030 SkIRect devClipBounds; | 1045 SkIRect devClipBounds; |
1031 pipelineBuilder->clip().getConservativeBounds(pipelineBuilder->getRenderTarg
et(), | 1046 pipelineBuilder->clip().getConservativeBounds(pipelineBuilder->getRenderTarg
et(), |
1032 &devClipBounds); | 1047 &devClipBounds); |
1033 | 1048 |
(...skipping 10 matching lines...) Expand all Loading... |
1044 geometry.fPath = path; | 1059 geometry.fPath = path; |
1045 SkDEBUGCODE(geometry.fDevBounds = devRect;) | 1060 SkDEBUGCODE(geometry.fDevBounds = devRect;) |
1046 geometry.fDevClipBounds = devClipBounds; | 1061 geometry.fDevClipBounds = devClipBounds; |
1047 | 1062 |
1048 SkAutoTUnref<GrBatch> batch(AAHairlineBatch::Create(geometry, fLinesIndexBuf
fer, | 1063 SkAutoTUnref<GrBatch> batch(AAHairlineBatch::Create(geometry, fLinesIndexBuf
fer, |
1049 fQuadsIndexBuffer)); | 1064 fQuadsIndexBuffer)); |
1050 target->drawBatch(pipelineBuilder, batch, &devRect); | 1065 target->drawBatch(pipelineBuilder, batch, &devRect); |
1051 | 1066 |
1052 return true; | 1067 return true; |
1053 } | 1068 } |
OLD | NEW |