OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2006 The Android Open Source Project | 2 * Copyright 2006 The Android Open Source Project |
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 "SkDraw.h" | 8 #include "SkDraw.h" |
9 #include "SkBlitter.h" | 9 #include "SkBlitter.h" |
10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
(...skipping 799 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
810 | 810 |
811 // transform rect into devRect | 811 // transform rect into devRect |
812 matrix.mapPoints(rect_points(devRect), rect_points(rect), 2); | 812 matrix.mapPoints(rect_points(devRect), rect_points(rect), 2); |
813 devRect.sort(); | 813 devRect.sort(); |
814 | 814 |
815 // look for the quick exit, before we build a blitter | 815 // look for the quick exit, before we build a blitter |
816 SkIRect ir; | 816 SkIRect ir; |
817 devRect.roundOut(&ir); | 817 devRect.roundOut(&ir); |
818 if (paint.getStyle() != SkPaint::kFill_Style) { | 818 if (paint.getStyle() != SkPaint::kFill_Style) { |
819 // extra space for hairlines | 819 // extra space for hairlines |
820 ir.inset(-1, -1); | 820 if (paint.getStrokeWidth() == 0) { |
| 821 ir.outset(1, 1); |
| 822 } else { |
| 823 SkScalar radius = SkScalarHalf(paint.getStrokeWidth()); |
| 824 ir.outset(radius, radius); |
| 825 } |
821 } | 826 } |
822 if (fRC->quickReject(ir)) { | 827 if (fRC->quickReject(ir)) { |
823 return; | 828 return; |
824 } | 829 } |
825 | 830 |
826 SkDeviceLooper looper(*fBitmap, *fRC, ir, paint.isAntiAlias()); | 831 SkDeviceLooper looper(*fBitmap, *fRC, ir, paint.isAntiAlias()); |
827 while (looper.next()) { | 832 while (looper.next()) { |
828 SkRect localDevRect; | 833 SkRect localDevRect; |
829 looper.mapRect(&localDevRect, devRect); | 834 looper.mapRect(&localDevRect, devRect); |
830 SkMatrix localMatrix; | 835 SkMatrix localMatrix; |
(...skipping 1542 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2373 mask->fImage = SkMask::AllocImage(size); | 2378 mask->fImage = SkMask::AllocImage(size); |
2374 memset(mask->fImage, 0, mask->computeImageSize()); | 2379 memset(mask->fImage, 0, mask->computeImageSize()); |
2375 } | 2380 } |
2376 | 2381 |
2377 if (SkMask::kJustComputeBounds_CreateMode != mode) { | 2382 if (SkMask::kJustComputeBounds_CreateMode != mode) { |
2378 draw_into_mask(*mask, devPath, style); | 2383 draw_into_mask(*mask, devPath, style); |
2379 } | 2384 } |
2380 | 2385 |
2381 return true; | 2386 return true; |
2382 } | 2387 } |
OLD | NEW |