blob: 273d1c932ebf401d401cd3b383962d9d7259c0a9 [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;
bsalomon@google.com0ac6af42013-01-16 15:16:18 +000026 virtual GrEffectRef* asNewEffect(GrContext* context, const SkPaint&) const SK_OVERRIDE;
rileya@google.com589708b2012-07-26 20:04:23 +000027
28 virtual void shadeSpan(int x, int y, SkPMColor* dstCParam,
29 int count) SK_OVERRIDE;
30 virtual bool setContext(const SkBitmap& device,
31 const SkPaint& paint,
32 const SkMatrix& matrix) SK_OVERRIDE;
33
rileya@google.com1c6d64b2012-07-27 15:49:05 +000034 SkScalar getCenterX1() const { return fDiff.length(); }
35 SkScalar getStartRadius() const { return fStartRadius; }
36 SkScalar getDiffRadius() const { return fDiffRadius; }
37
robertphillips@google.com76f9e932013-01-15 20:17:47 +000038 SK_DEVELOPER_TO_STRING()
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.com589708b2012-07-26 20:04:23 +000057#endif
58