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"
16 kDontDrawT = 0x80000000
19 float fCenterX, fCenterY;
20 float fDCenterX, fDCenterY;
27 void init(const SkPoint& center0, SkScalar rad0,
28 const SkPoint& center1, SkScalar rad1);
30 // used by setup and nextT
31 float fRelX, fRelY, fIncX, fIncY;
34 void setup(SkScalar fx, SkScalar fy, SkScalar dfx, SkScalar dfy);
37 static bool DontDrawT(SkFixed t) {
38 return kDontDrawT == (uint32_t)t;
43 class SkTwoPointConicalGradient : public SkGradientShaderBase {
48 SkTwoPointConicalGradient(const SkPoint& start, SkScalar startRadius,
49 const SkPoint& end, SkScalar endRadius,
50 const SkColor colors[], const SkScalar pos[],
51 int colorCount, SkShader::TileMode mode,
52 SkUnitMapper* mapper);
54 virtual void shadeSpan(int x, int y, SkPMColor* dstCParam,
55 int count) SK_OVERRIDE;
56 virtual bool setContext(const SkBitmap& device,
58 const SkMatrix& matrix) SK_OVERRIDE;
60 virtual BitmapType asABitmap(SkBitmap* bitmap,
63 virtual SkShader::GradientType asAGradient(GradientInfo* info) const SK_OVERRIDE;
64 virtual GrCustomStage* asNewCustomStage(GrContext* context,
65 GrSamplerState* sampler) const SK_OVERRIDE;
67 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkTwoPointConicalGradient)
70 SkTwoPointConicalGradient(SkFlattenableReadBuffer& buffer);
71 virtual void flatten(SkFlattenableWriteBuffer& buffer) const SK_OVERRIDE;
74 typedef SkGradientShaderBase INHERITED;
75 const SkPoint fCenter1;
76 const SkPoint fCenter2;
77 const SkScalar fRadius1;
78 const SkScalar fRadius2;
81 ///////////////////////////////////////////////////////////////////////////////
83 class GrGLConical2Gradient;
85 class GrConical2Gradient : public GrGradientEffect {
89 GrConical2Gradient(GrTexture* texture, GrScalar center, GrScalar radius, GrScalar diffRadius);
90 GrConical2Gradient(GrContext* ctx, const SkShader& shader,
91 GrSamplerState* sampler, SkScalar center,
92 SkScalar radius, SkScalar diffRadius);
93 virtual ~GrConical2Gradient();
95 static const char* Name() { return "Two-Point Conical Gradient"; }
96 virtual const GrProgramStageFactory& getFactory() const SK_OVERRIDE;
97 virtual bool isEqual(const GrCustomStage&) const SK_OVERRIDE;
99 // The radial gradient parameters can collapse to a linear (instead of quadratic) equation.
100 bool isDegenerate() const { return SkScalarAbs(fDiffRadius) == SkScalarAbs(fCenterX1); }
101 GrScalar center() const { return fCenterX1; }
102 GrScalar diffRadius() const { return fDiffRadius; }
103 GrScalar radius() const { return fRadius0; }
105 typedef GrGLConical2Gradient GLProgramStage;
110 // Cache of values - these can change arbitrarily, EXCEPT
111 // we shouldn't change between degenerate and non-degenerate?!
115 GrScalar fDiffRadius;
119 typedef GrGradientEffect INHERITED;