blob: bf94c3cc143ccde95d03c158f846ad86f51a3baa [file] [log] [blame]
rileya@google.com589708b2012-07-26 20:04:23 +00001
2/*
3 * Copyright 2012 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
9 #ifndef SkTwoPointRadialGradient_DEFINED
10 #define SkTwoPointRadialGradient_DEFINED
11
12 #include "SkGradientShaderPriv.h"
13
14class SkTwoPointRadialGradient : public SkGradientShaderBase {
15public:
16 SkTwoPointRadialGradient(const SkPoint& start, SkScalar startRadius,
17 const SkPoint& end, SkScalar endRadius,
18 const SkColor colors[], const SkScalar pos[],
19 int colorCount, SkShader::TileMode mode,
20 SkUnitMapper* mapper);
21
22 virtual BitmapType asABitmap(SkBitmap* bitmap,
23 SkMatrix* matrix,
24 TileMode* xy) const SK_OVERRIDE;
25 virtual GradientType asAGradient(GradientInfo* info) const SK_OVERRIDE;
26 virtual GrCustomStage* asNewCustomStage(GrContext* context,
27 GrSamplerState* sampler) const SK_OVERRIDE;
28
29 virtual void shadeSpan(int x, int y, SkPMColor* dstCParam,
30 int count) SK_OVERRIDE;
31 virtual bool setContext(const SkBitmap& device,
32 const SkPaint& paint,
33 const SkMatrix& matrix) SK_OVERRIDE;
34
rileya@google.com1c6d64b2012-07-27 15:49:05 +000035 SkScalar getCenterX1() const { return fDiff.length(); }
36 SkScalar getStartRadius() const { return fStartRadius; }
37 SkScalar getDiffRadius() const { return fDiffRadius; }
38
rileya@google.com589708b2012-07-26 20:04:23 +000039 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkTwoPointRadialGradient)
40
41protected:
42 SkTwoPointRadialGradient(SkFlattenableReadBuffer& buffer);
43 virtual void flatten(SkFlattenableWriteBuffer& buffer) const SK_OVERRIDE;
44
45private:
46 typedef SkGradientShaderBase INHERITED;
47 const SkPoint fCenter1;
48 const SkPoint fCenter2;
49 const SkScalar fRadius1;
50 const SkScalar fRadius2;
51 SkPoint fDiff;
52 SkScalar fStartRadius, fDiffRadius, fSr2D2, fA, fOneOverTwoA;
53
54 void init();
55};
56
rileya@google.comd7cc6512012-07-27 14:00:39 +000057///////////////////////////////////////////////////////////////////////////////
58
59class GrGLRadial2Gradient;
60
61class GrRadial2Gradient : public GrGradientEffect {
62
63public:
64
65 GrRadial2Gradient(GrTexture* texture, GrScalar center, GrScalar radius, bool posRoot);
rileya@google.com1c6d64b2012-07-27 15:49:05 +000066 GrRadial2Gradient(GrContext* ctx, const SkTwoPointRadialGradient& shader,
67 GrSamplerState* sampler);
rileya@google.comd7cc6512012-07-27 14:00:39 +000068 virtual ~GrRadial2Gradient();
69
70 static const char* Name() { return "Two-Point Radial Gradient"; }
71 virtual const GrProgramStageFactory& getFactory() const SK_OVERRIDE;
72 virtual bool isEqual(const GrCustomStage&) const SK_OVERRIDE;
73
74 // The radial gradient parameters can collapse to a linear (instead of quadratic) equation.
75 bool isDegenerate() const { return GR_Scalar1 == fCenterX1; }
76 GrScalar center() const { return fCenterX1; }
77 GrScalar radius() const { return fRadius0; }
78 bool isPosRoot() const { return SkToBool(fPosRoot); }
79
80 typedef GrGLRadial2Gradient GLProgramStage;
81
82private:
83
84 // @{
85 // Cache of values - these can change arbitrarily, EXCEPT
86 // we shouldn't change between degenerate and non-degenerate?!
87
88 GrScalar fCenterX1;
89 GrScalar fRadius0;
90 SkBool8 fPosRoot;
91
92 // @}
93
94 typedef GrGradientEffect INHERITED;
95};
96
rileya@google.com589708b2012-07-26 20:04:23 +000097#endif
98