| 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 "SkGpuDevice.h" | 8 #include "SkGpuDevice.h" |
| 9 | 9 |
| 10 #include "GrBlurUtils.h" | 10 #include "GrBlurUtils.h" |
| (...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 274 | 274 |
| 275 GrPaint grPaint; | 275 GrPaint grPaint; |
| 276 if (!SkPaintToGrPaint(this->context(), fDrawContext.get(), paint, *draw.fMat
rix, &grPaint)) { | 276 if (!SkPaintToGrPaint(this->context(), fDrawContext.get(), paint, *draw.fMat
rix, &grPaint)) { |
| 277 return; | 277 return; |
| 278 } | 278 } |
| 279 | 279 |
| 280 fDrawContext->drawPaint(fClip, grPaint, *draw.fMatrix); | 280 fDrawContext->drawPaint(fClip, grPaint, *draw.fMatrix); |
| 281 } | 281 } |
| 282 | 282 |
| 283 // must be in SkCanvas::PointMode order | 283 // must be in SkCanvas::PointMode order |
| 284 static const GrPrimitiveType gPointMode2PrimtiveType[] = { | 284 static const GrPrimitiveType gPointMode2PrimitiveType[] = { |
| 285 kPoints_GrPrimitiveType, | 285 kPoints_GrPrimitiveType, |
| 286 kLines_GrPrimitiveType, | 286 kLines_GrPrimitiveType, |
| 287 kLineStrip_GrPrimitiveType | 287 kLineStrip_GrPrimitiveType |
| 288 }; | 288 }; |
| 289 | 289 |
| 290 // suppress antialiasing on axis-aligned integer-coordinate lines | 290 // suppress antialiasing on axis-aligned integer-coordinate lines |
| 291 static bool needs_antialiasing(SkCanvas::PointMode mode, size_t count, const SkP
oint pts[]) { | 291 static bool needs_antialiasing(SkCanvas::PointMode mode, size_t count, const SkP
oint pts[]) { |
| 292 if (mode == SkCanvas::PointMode::kPoints_PointMode) { | 292 if (mode == SkCanvas::PointMode::kPoints_PointMode) { |
| 293 return false; | 293 return false; |
| 294 } | 294 } |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 328 return; | 328 return; |
| 329 } | 329 } |
| 330 SkPath path; | 330 SkPath path; |
| 331 path.setIsVolatile(true); | 331 path.setIsVolatile(true); |
| 332 path.moveTo(pts[0]); | 332 path.moveTo(pts[0]); |
| 333 path.lineTo(pts[1]); | 333 path.lineTo(pts[1]); |
| 334 fDrawContext->drawPath(fClip, grPaint, *draw.fMatrix, path, style); | 334 fDrawContext->drawPath(fClip, grPaint, *draw.fMatrix, path, style); |
| 335 return; | 335 return; |
| 336 } | 336 } |
| 337 | 337 |
| 338 SkScalar scales[2]; |
| 339 bool isHairline = (0 == width) || (1 == width && draw.fMatrix->getMinMaxScal
es(scales) && |
| 340 SkScalarNearlyEqual(scales[0], 1.f) && |
| 341 SkScalarNearlyEqual(scales[1], 1.f)); |
| 338 // we only handle non-antialiased hairlines and paints without path effects
or mask filters, | 342 // we only handle non-antialiased hairlines and paints without path effects
or mask filters, |
| 339 // else we let the SkDraw call our drawPath() | 343 // else we let the SkDraw call our drawPath() |
| 340 if (width > 0 || paint.getPathEffect() || paint.getMaskFilter() || | 344 if (!isHairline || paint.getPathEffect() || paint.getMaskFilter() || |
| 341 (paint.isAntiAlias() && needs_antialiasing(mode, count, pts))) { | 345 (paint.isAntiAlias() && needs_antialiasing(mode, count, pts))) { |
| 342 draw.drawPoints(mode, count, pts, paint, true); | 346 draw.drawPoints(mode, count, pts, paint, true); |
| 343 return; | 347 return; |
| 344 } | 348 } |
| 345 | 349 |
| 350 GrPrimitiveType primitiveType = gPointMode2PrimitiveType[mode]; |
| 351 |
| 352 const SkMatrix* viewMatrix = draw.fMatrix; |
| 353 #ifdef SK_BUILD_FOR_ANDROID_FRAMEWORK |
| 354 // This offsetting in device space matches the expectations of the Android f
ramework for non-AA |
| 355 // points and lines. |
| 356 SkMatrix tempMatrix; |
| 357 if (GrIsPrimTypeLines(primitiveType) || kPoints_GrPrimitiveType == primitive
Type) { |
| 358 tempMatrix = *viewMatrix; |
| 359 static const SkScalar kOffset = 0.063f; // Just greater than 1/16. |
| 360 tempMatrix.postTranslate(kOffset, kOffset); |
| 361 viewMatrix = &tempMatrix; |
| 362 } |
| 363 #endif |
| 364 |
| 346 GrPaint grPaint; | 365 GrPaint grPaint; |
| 347 if (!SkPaintToGrPaint(this->context(), fDrawContext.get(), paint, *draw.fMat
rix, &grPaint)) { | 366 if (!SkPaintToGrPaint(this->context(), fDrawContext.get(), paint, *viewMatri
x, &grPaint)) { |
| 348 return; | 367 return; |
| 349 } | 368 } |
| 350 | 369 |
| 351 fDrawContext->drawVertices(fClip, | 370 fDrawContext->drawVertices(fClip, |
| 352 grPaint, | 371 grPaint, |
| 353 *draw.fMatrix, | 372 *viewMatrix, |
| 354 gPointMode2PrimtiveType[mode], | 373 primitiveType, |
| 355 SkToS32(count), | 374 SkToS32(count), |
| 356 (SkPoint*)pts, | 375 (SkPoint*)pts, |
| 357 nullptr, | 376 nullptr, |
| 358 nullptr, | 377 nullptr, |
| 359 nullptr, | 378 nullptr, |
| 360 0); | 379 0); |
| 361 } | 380 } |
| 362 | 381 |
| 363 /////////////////////////////////////////////////////////////////////////////// | 382 /////////////////////////////////////////////////////////////////////////////// |
| 364 | 383 |
| (...skipping 1433 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1798 } | 1817 } |
| 1799 | 1818 |
| 1800 SkImageFilterCache* SkGpuDevice::getImageFilterCache() { | 1819 SkImageFilterCache* SkGpuDevice::getImageFilterCache() { |
| 1801 ASSERT_SINGLE_OWNER | 1820 ASSERT_SINGLE_OWNER |
| 1802 // We always return a transient cache, so it is freed after each | 1821 // We always return a transient cache, so it is freed after each |
| 1803 // filter traversal. | 1822 // filter traversal. |
| 1804 return SkImageFilterCache::Create(kDefaultImageFilterCacheSize); | 1823 return SkImageFilterCache::Create(kDefaultImageFilterCacheSize); |
| 1805 } | 1824 } |
| 1806 | 1825 |
| 1807 #endif | 1826 #endif |
| OLD | NEW |