3 * Copyright 2012 Google Inc.
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
9 #ifndef SkTwoPointConicalGradient_DEFINED
10 #define SkTwoPointConicalGradient_DEFINED
12 #include "SkGradientShaderPriv.h"
14 // TODO(dominikg): Worth making it truly immutable (i.e. set values in constructor)?
15 // Should only be initialized once via init(). Immutable afterwards.
18 kDontDrawT = 0x80000000
21 float fCenterX, fCenterY;
22 float fDCenterX, fDCenterY;
30 void init(const SkPoint& center0, SkScalar rad0,
31 const SkPoint& center1, SkScalar rad1,
34 static bool DontDrawT(SkFixed t) {
35 return kDontDrawT == (uint32_t)t;
40 class SkTwoPointConicalGradient : public SkGradientShaderBase {
45 SkTwoPointConicalGradient(const SkPoint& start, SkScalar startRadius,
46 const SkPoint& end, SkScalar endRadius,
47 bool flippedGrad, const Descriptor&);
50 virtual SkShader::Context* createContext(const SkBitmap&, const SkPaint&, const SkMatrix&,
51 void* storage) const SK_OVERRIDE;
52 virtual size_t contextSize() const SK_OVERRIDE;
54 class TwoPointConicalGradientContext : public SkGradientShaderBase::GradientShaderBaseContext {
56 TwoPointConicalGradientContext(const SkTwoPointConicalGradient& shader,
57 const SkBitmap& device,
59 const SkMatrix& matrix);
60 ~TwoPointConicalGradientContext() {}
62 virtual void shadeSpan(int x, int y, SkPMColor dstC[], int count) SK_OVERRIDE;
65 typedef SkGradientShaderBase::GradientShaderBaseContext INHERITED;
68 virtual BitmapType asABitmap(SkBitmap* bitmap,
71 virtual SkShader::GradientType asAGradient(GradientInfo* info) const SK_OVERRIDE;
72 virtual GrEffectRef* asNewEffect(GrContext* context, const SkPaint& paint) const SK_OVERRIDE;
73 virtual bool isOpaque() const SK_OVERRIDE;
75 SkScalar getCenterX1() const { return SkPoint::Distance(fCenter1, fCenter2); }
76 SkScalar getStartRadius() const { return fRadius1; }
77 SkScalar getDiffRadius() const { return fRadius2 - fRadius1; }
78 const SkPoint& getStartCenter() const { return fCenter1; }
79 const SkPoint& getEndCenter() const { return fCenter2; }
80 SkScalar getEndRadius() const { return fRadius2; }
81 bool isFlippedGrad() const { return fFlippedGrad; }
83 SK_TO_STRING_OVERRIDE()
84 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkTwoPointConicalGradient)
87 SkTwoPointConicalGradient(SkReadBuffer& buffer);
88 virtual void flatten(SkWriteBuffer& buffer) const SK_OVERRIDE;
97 typedef SkGradientShaderBase INHERITED;