| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 "SkLinearGradient.h" | 8 #include "SkLinearGradient.h" |
| 9 | 9 |
| 10 static inline int repeat_bits(int x, const int bits) { | 10 static inline int repeat_bits(int x, const int bits) { |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 53 /////////////////////////////////////////////////////////////////////////////// | 53 /////////////////////////////////////////////////////////////////////////////// |
| 54 | 54 |
| 55 SkLinearGradient::SkLinearGradient(const SkPoint pts[2], const Descriptor& desc) | 55 SkLinearGradient::SkLinearGradient(const SkPoint pts[2], const Descriptor& desc) |
| 56 : SkGradientShaderBase(desc) | 56 : SkGradientShaderBase(desc) |
| 57 , fStart(pts[0]) | 57 , fStart(pts[0]) |
| 58 , fEnd(pts[1]) | 58 , fEnd(pts[1]) |
| 59 { | 59 { |
| 60 pts_to_unit_matrix(pts, &fPtsToUnit); | 60 pts_to_unit_matrix(pts, &fPtsToUnit); |
| 61 } | 61 } |
| 62 | 62 |
| 63 #ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING |
| 63 SkLinearGradient::SkLinearGradient(SkReadBuffer& buffer) | 64 SkLinearGradient::SkLinearGradient(SkReadBuffer& buffer) |
| 64 : INHERITED(buffer) | 65 : INHERITED(buffer) |
| 65 , fStart(buffer.readPoint()) | 66 , fStart(buffer.readPoint()) |
| 66 , fEnd(buffer.readPoint()) { | 67 , fEnd(buffer.readPoint()) { |
| 67 } | 68 } |
| 69 #endif |
| 70 |
| 71 SkFlattenable* SkLinearGradient::CreateProc(SkReadBuffer& buffer) { |
| 72 DescriptorScope desc; |
| 73 if (!desc.unflatten(buffer)) { |
| 74 return NULL; |
| 75 } |
| 76 SkPoint pts[2]; |
| 77 pts[0] = buffer.readPoint(); |
| 78 pts[1] = buffer.readPoint(); |
| 79 return SkGradientShader::CreateLinear(pts, desc.fColors, desc.fPos, desc.fCo
unt, |
| 80 desc.fTileMode, desc.fGradFlags, desc.
fLocalMatrix); |
| 81 } |
| 68 | 82 |
| 69 void SkLinearGradient::flatten(SkWriteBuffer& buffer) const { | 83 void SkLinearGradient::flatten(SkWriteBuffer& buffer) const { |
| 70 this->INHERITED::flatten(buffer); | 84 this->INHERITED::flatten(buffer); |
| 71 buffer.writePoint(fStart); | 85 buffer.writePoint(fStart); |
| 72 buffer.writePoint(fEnd); | 86 buffer.writePoint(fEnd); |
| 73 } | 87 } |
| 74 | 88 |
| 75 size_t SkLinearGradient::contextSize() const { | 89 size_t SkLinearGradient::contextSize() const { |
| 76 return sizeof(LinearGradientContext); | 90 return sizeof(LinearGradientContext); |
| 77 } | 91 } |
| (...skipping 514 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 592 str->append("SkLinearGradient ("); | 606 str->append("SkLinearGradient ("); |
| 593 | 607 |
| 594 str->appendf("start: (%f, %f)", fStart.fX, fStart.fY); | 608 str->appendf("start: (%f, %f)", fStart.fX, fStart.fY); |
| 595 str->appendf(" end: (%f, %f) ", fEnd.fX, fEnd.fY); | 609 str->appendf(" end: (%f, %f) ", fEnd.fX, fEnd.fY); |
| 596 | 610 |
| 597 this->INHERITED::toString(str); | 611 this->INHERITED::toString(str); |
| 598 | 612 |
| 599 str->append(")"); | 613 str->append(")"); |
| 600 } | 614 } |
| 601 #endif | 615 #endif |
| OLD | NEW |