| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2015 Google Inc. | 3 * Copyright 2015 Google Inc. |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 #include "GrAALinearizingConvexPathRenderer.h" | 9 #include "GrAALinearizingConvexPathRenderer.h" |
| 10 | 10 |
| (...skipping 246 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 257 sk_free(indices); | 257 sk_free(indices); |
| 258 } | 258 } |
| 259 | 259 |
| 260 SkSTArray<1, Geometry, true>* geoData() { return &fGeoData; } | 260 SkSTArray<1, Geometry, true>* geoData() { return &fGeoData; } |
| 261 | 261 |
| 262 AAFlatteningConvexPathBatch(const Geometry& geometry) : INHERITED(ClassID())
{ | 262 AAFlatteningConvexPathBatch(const Geometry& geometry) : INHERITED(ClassID())
{ |
| 263 fGeoData.push_back(geometry); | 263 fGeoData.push_back(geometry); |
| 264 | 264 |
| 265 // compute bounds | 265 // compute bounds |
| 266 fBounds = geometry.fPath.getBounds(); | 266 fBounds = geometry.fPath.getBounds(); |
| 267 SkScalar w = geometry.fStrokeWidth; |
| 268 if (w > 0) { |
| 269 w /= 2; |
| 270 // If the miter limit is < 1 then we effectively fallback to bevel j
oins. |
| 271 if (SkPaint::kMiter_Join == geometry.fJoin && w > 1.f) { |
| 272 w *= geometry.fMiterLimit; |
| 273 } |
| 274 fBounds.outset(w, w); |
| 275 } |
| 267 geometry.fViewMatrix.mapRect(&fBounds); | 276 geometry.fViewMatrix.mapRect(&fBounds); |
| 268 } | 277 } |
| 269 | 278 |
| 270 bool onCombineIfPossible(GrBatch* t, const GrCaps& caps) override { | 279 bool onCombineIfPossible(GrBatch* t, const GrCaps& caps) override { |
| 271 AAFlatteningConvexPathBatch* that = t->cast<AAFlatteningConvexPathBatch>
(); | 280 AAFlatteningConvexPathBatch* that = t->cast<AAFlatteningConvexPathBatch>
(); |
| 272 if (!GrPipeline::CanCombine(*this->pipeline(), this->bounds(), *that->pi
peline(), | 281 if (!GrPipeline::CanCombine(*this->pipeline(), this->bounds(), *that->pi
peline(), |
| 273 that->bounds(), caps)) { | 282 that->bounds(), caps)) { |
| 274 return false; | 283 return false; |
| 275 } | 284 } |
| 276 | 285 |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 338 DRAW_BATCH_TEST_DEFINE(AAFlatteningConvexPathBatch) { | 347 DRAW_BATCH_TEST_DEFINE(AAFlatteningConvexPathBatch) { |
| 339 AAFlatteningConvexPathBatch::Geometry geometry; | 348 AAFlatteningConvexPathBatch::Geometry geometry; |
| 340 geometry.fColor = GrRandomColor(random); | 349 geometry.fColor = GrRandomColor(random); |
| 341 geometry.fViewMatrix = GrTest::TestMatrixInvertible(random); | 350 geometry.fViewMatrix = GrTest::TestMatrixInvertible(random); |
| 342 geometry.fPath = GrTest::TestPathConvex(random); | 351 geometry.fPath = GrTest::TestPathConvex(random); |
| 343 | 352 |
| 344 return AAFlatteningConvexPathBatch::Create(geometry); | 353 return AAFlatteningConvexPathBatch::Create(geometry); |
| 345 } | 354 } |
| 346 | 355 |
| 347 #endif | 356 #endif |
| OLD | NEW |