caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2013 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 7 | #include "SkOpContour.h" |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 8 | #include "SkOpTAllocator.h" |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 9 | #include "SkPathWriter.h" |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 10 | #include "SkReduceOrder.h" |
commit-bot@chromium.org | b76d3b6 | 2013-04-22 19:55:19 +0000 | [diff] [blame] | 11 | #include "SkTSort.h" |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 12 | |
caryclark | 27c015d | 2016-09-23 05:47:20 -0700 | [diff] [blame] | 13 | SkOpSegment* SkOpContour::addCurve(SkPath::Verb verb, const SkPoint pts[4], SkScalar weight) { |
caryclark | 55888e4 | 2016-07-18 10:01:36 -0700 | [diff] [blame] | 14 | SkChunkAlloc* allocator = this->globalState()->allocator(); |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 15 | switch (verb) { |
| 16 | case SkPath::kLine_Verb: { |
| 17 | SkPoint* ptStorage = SkOpTAllocator<SkPoint>::AllocateArray(allocator, 2); |
| 18 | memcpy(ptStorage, pts, sizeof(SkPoint) * 2); |
caryclark | 55888e4 | 2016-07-18 10:01:36 -0700 | [diff] [blame] | 19 | return appendSegment().addLine(ptStorage, this); |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 20 | } break; |
| 21 | case SkPath::kQuad_Verb: { |
| 22 | SkPoint* ptStorage = SkOpTAllocator<SkPoint>::AllocateArray(allocator, 3); |
| 23 | memcpy(ptStorage, pts, sizeof(SkPoint) * 3); |
caryclark | 55888e4 | 2016-07-18 10:01:36 -0700 | [diff] [blame] | 24 | return appendSegment().addQuad(ptStorage, this); |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 25 | } break; |
caryclark | 1049f12 | 2015-04-20 08:31:59 -0700 | [diff] [blame] | 26 | case SkPath::kConic_Verb: { |
caryclark | 27c015d | 2016-09-23 05:47:20 -0700 | [diff] [blame] | 27 | SkPoint* ptStorage = SkOpTAllocator<SkPoint>::AllocateArray(allocator, 3); |
| 28 | memcpy(ptStorage, pts, sizeof(SkPoint) * 3); |
| 29 | return appendSegment().addConic(ptStorage, weight, this); |
caryclark | 1049f12 | 2015-04-20 08:31:59 -0700 | [diff] [blame] | 30 | } break; |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 31 | case SkPath::kCubic_Verb: { |
| 32 | SkPoint* ptStorage = SkOpTAllocator<SkPoint>::AllocateArray(allocator, 4); |
| 33 | memcpy(ptStorage, pts, sizeof(SkPoint) * 4); |
caryclark | 55888e4 | 2016-07-18 10:01:36 -0700 | [diff] [blame] | 34 | return appendSegment().addCubic(ptStorage, this); |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 35 | } break; |
| 36 | default: |
| 37 | SkASSERT(0); |
caryclark@google.com | 7eaa53d | 2013-10-02 14:49:34 +0000 | [diff] [blame] | 38 | } |
halcanary | 96fcdcc | 2015-08-27 07:41:13 -0700 | [diff] [blame] | 39 | return nullptr; |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 40 | } |
| 41 | |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 42 | void SkOpContour::toPath(SkPathWriter* path) const { |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 43 | const SkOpSegment* segment = &fHead; |
| 44 | do { |
caryclark | ef784fb | 2015-10-30 12:03:06 -0700 | [diff] [blame] | 45 | SkAssertResult(segment->addCurveTo(segment->head(), segment->tail(), path)); |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 46 | } while ((segment = segment->next())); |
caryclark | eed356d | 2016-09-14 07:18:20 -0700 | [diff] [blame] | 47 | path->finishContour(); |
| 48 | path->assemble(); |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 49 | } |
| 50 | |
caryclark | 5b5ddd7 | 2015-05-18 05:12:56 -0700 | [diff] [blame] | 51 | void SkOpContour::toReversePath(SkPathWriter* path) const { |
caryclark | 5b5ddd7 | 2015-05-18 05:12:56 -0700 | [diff] [blame] | 52 | const SkOpSegment* segment = fTail; |
| 53 | do { |
caryclark | ef784fb | 2015-10-30 12:03:06 -0700 | [diff] [blame] | 54 | SkAssertResult(segment->addCurveTo(segment->tail(), segment->head(), path)); |
caryclark | 5b5ddd7 | 2015-05-18 05:12:56 -0700 | [diff] [blame] | 55 | } while ((segment = segment->prev())); |
caryclark | eed356d | 2016-09-14 07:18:20 -0700 | [diff] [blame] | 56 | path->finishContour(); |
| 57 | path->assemble(); |
caryclark | 5b5ddd7 | 2015-05-18 05:12:56 -0700 | [diff] [blame] | 58 | } |
| 59 | |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 60 | SkOpSegment* SkOpContour::undoneSegment(SkOpSpanBase** startPtr, SkOpSpanBase** endPtr) { |
| 61 | SkOpSegment* segment = &fHead; |
| 62 | do { |
| 63 | if (segment->done()) { |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 64 | continue; |
| 65 | } |
caryclark | 5435929 | 2015-03-26 07:52:43 -0700 | [diff] [blame] | 66 | segment->undoneSpan(startPtr, endPtr); |
| 67 | return segment; |
| 68 | } while ((segment = segment->next())); |
halcanary | 96fcdcc | 2015-08-27 07:41:13 -0700 | [diff] [blame] | 69 | return nullptr; |
caryclark@google.com | 07393ca | 2013-04-08 11:47:37 +0000 | [diff] [blame] | 70 | } |