2008-12-17 15:59:43 +00:00
|
|
|
/*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Copyright 2006 The Android Open Source Project
|
2008-12-17 15:59:43 +00:00
|
|
|
*
|
2011-07-28 14:26:00 +00:00
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
2008-12-17 15:59:43 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkGradientShader_DEFINED
|
|
|
|
#define SkGradientShader_DEFINED
|
|
|
|
|
|
|
|
#include "SkShader.h"
|
|
|
|
|
|
|
|
/** \class SkGradientShader
|
|
|
|
|
|
|
|
SkGradientShader hosts factories for creating subclasses of SkShader that
|
|
|
|
render linear and radial gradients.
|
|
|
|
*/
|
2011-03-15 21:27:08 +00:00
|
|
|
class SK_API SkGradientShader {
|
2008-12-17 15:59:43 +00:00
|
|
|
public:
|
2013-05-24 14:58:44 +00:00
|
|
|
enum Flags {
|
|
|
|
/** By default gradients will interpolate their colors in unpremul space
|
|
|
|
* and then premultiply each of the results. By setting this flag, the
|
|
|
|
* gradients will premultiply their colors first, and then interpolate
|
|
|
|
* between them.
|
|
|
|
*/
|
|
|
|
kInterpolateColorsInPremul_Flag = 1 << 0,
|
|
|
|
};
|
|
|
|
|
2016-09-27 10:33:12 +00:00
|
|
|
/** Returns a shader that generates a linear gradient between the two specified points.
|
2008-12-17 15:59:43 +00:00
|
|
|
<p />
|
2016-09-27 10:33:12 +00:00
|
|
|
@param pts The start and end points for the gradient.
|
2008-12-17 15:59:43 +00:00
|
|
|
@param colors The array[count] of colors, to be distributed between the two points
|
|
|
|
@param pos May be NULL. array[count] of SkScalars, or NULL, of the relative position of
|
|
|
|
each corresponding color in the colors array. If this is NULL,
|
|
|
|
the the colors are distributed evenly between the start and end point.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
2012-08-23 18:09:54 +00:00
|
|
|
@param count Must be >=2. The number of colors (and pos if not NULL) entries.
|
2008-12-17 15:59:43 +00:00
|
|
|
@param mode The tiling mode
|
|
|
|
*/
|
2016-03-09 02:50:00 +00:00
|
|
|
static sk_sp<SkShader> MakeLinear(const SkPoint pts[2],
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
|
|
|
SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeLinear(const SkPoint pts[2],
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
|
|
|
SkShader::TileMode mode) {
|
2017-08-28 14:34:05 +00:00
|
|
|
return MakeLinear(pts, colors, pos, count, mode, 0, nullptr);
|
2014-05-19 15:46:09 +00:00
|
|
|
}
|
|
|
|
|
2016-09-28 18:27:28 +00:00
|
|
|
/** Returns a shader that generates a linear gradient between the two specified points.
|
|
|
|
<p />
|
|
|
|
@param pts The start and end points for the gradient.
|
|
|
|
@param colors The array[count] of colors, to be distributed between the two points
|
|
|
|
@param pos May be NULL. array[count] of SkScalars, or NULL, of the relative position of
|
|
|
|
each corresponding color in the colors array. If this is NULL,
|
|
|
|
the the colors are distributed evenly between the start and end point.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
|
|
|
@param count Must be >=2. The number of colors (and pos if not NULL) entries.
|
|
|
|
@param mode The tiling mode
|
|
|
|
*/
|
|
|
|
static sk_sp<SkShader> MakeLinear(const SkPoint pts[2],
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count, SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeLinear(const SkPoint pts[2],
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count, SkShader::TileMode mode) {
|
2017-08-28 14:34:05 +00:00
|
|
|
return MakeLinear(pts, colors, std::move(colorSpace), pos, count, mode, 0, nullptr);
|
2016-09-28 18:27:28 +00:00
|
|
|
}
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** Returns a shader that generates a radial gradient given the center and radius.
|
|
|
|
<p />
|
|
|
|
@param center The center of the circle for this gradient
|
|
|
|
@param radius Must be positive. The radius of the circle for this gradient
|
|
|
|
@param colors The array[count] of colors, to be distributed between the center and edge of the circle
|
|
|
|
@param pos May be NULL. The array[count] of SkScalars, or NULL, of the relative position of
|
|
|
|
each corresponding color in the colors array. If this is NULL,
|
|
|
|
the the colors are distributed evenly between the center and edge of the circle.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
|
|
|
@param count Must be >= 2. The number of colors (and pos if not NULL) entries
|
|
|
|
@param mode The tiling mode
|
|
|
|
*/
|
2016-03-09 02:50:00 +00:00
|
|
|
static sk_sp<SkShader> MakeRadial(const SkPoint& center, SkScalar radius,
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
|
|
|
SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeRadial(const SkPoint& center, SkScalar radius,
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
|
|
|
SkShader::TileMode mode) {
|
2017-08-28 14:34:05 +00:00
|
|
|
return MakeRadial(center, radius, colors, pos, count, mode, 0, nullptr);
|
2014-05-19 15:46:09 +00:00
|
|
|
}
|
|
|
|
|
2016-09-28 18:27:28 +00:00
|
|
|
/** Returns a shader that generates a radial gradient given the center and radius.
|
|
|
|
<p />
|
|
|
|
@param center The center of the circle for this gradient
|
|
|
|
@param radius Must be positive. The radius of the circle for this gradient
|
|
|
|
@param colors The array[count] of colors, to be distributed between the center and edge of the circle
|
|
|
|
@param pos May be NULL. The array[count] of SkScalars, or NULL, of the relative position of
|
|
|
|
each corresponding color in the colors array. If this is NULL,
|
|
|
|
the the colors are distributed evenly between the center and edge of the circle.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
|
|
|
@param count Must be >= 2. The number of colors (and pos if not NULL) entries
|
|
|
|
@param mode The tiling mode
|
|
|
|
*/
|
|
|
|
static sk_sp<SkShader> MakeRadial(const SkPoint& center, SkScalar radius,
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count, SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeRadial(const SkPoint& center, SkScalar radius,
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count, SkShader::TileMode mode) {
|
2017-08-28 14:34:05 +00:00
|
|
|
return MakeRadial(center, radius, colors, std::move(colorSpace), pos, count, mode,
|
|
|
|
0, nullptr);
|
2016-09-28 18:27:28 +00:00
|
|
|
}
|
|
|
|
|
2012-06-06 20:31:56 +00:00
|
|
|
/**
|
|
|
|
* Returns a shader that generates a conical gradient given two circles, or
|
|
|
|
* returns NULL if the inputs are invalid. The gradient interprets the
|
|
|
|
* two circles according to the following HTML spec.
|
|
|
|
* http://dev.w3.org/html5/2dcontext/#dom-context-2d-createradialgradient
|
|
|
|
*/
|
2016-03-09 02:50:00 +00:00
|
|
|
static sk_sp<SkShader> MakeTwoPointConical(const SkPoint& start, SkScalar startRadius,
|
|
|
|
const SkPoint& end, SkScalar endRadius,
|
|
|
|
const SkColor colors[], const SkScalar pos[],
|
|
|
|
int count, SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeTwoPointConical(const SkPoint& start, SkScalar startRadius,
|
|
|
|
const SkPoint& end, SkScalar endRadius,
|
|
|
|
const SkColor colors[], const SkScalar pos[],
|
|
|
|
int count, SkShader::TileMode mode) {
|
|
|
|
return MakeTwoPointConical(start, startRadius, end, endRadius, colors, pos, count, mode,
|
2017-08-28 14:34:05 +00:00
|
|
|
0, nullptr);
|
2014-05-19 15:46:09 +00:00
|
|
|
}
|
|
|
|
|
2016-09-28 18:27:28 +00:00
|
|
|
/**
|
|
|
|
* Returns a shader that generates a conical gradient given two circles, or
|
|
|
|
* returns NULL if the inputs are invalid. The gradient interprets the
|
|
|
|
* two circles according to the following HTML spec.
|
|
|
|
* http://dev.w3.org/html5/2dcontext/#dom-context-2d-createradialgradient
|
|
|
|
*/
|
|
|
|
static sk_sp<SkShader> MakeTwoPointConical(const SkPoint& start, SkScalar startRadius,
|
|
|
|
const SkPoint& end, SkScalar endRadius,
|
|
|
|
const SkColor4f colors[],
|
|
|
|
sk_sp<SkColorSpace> colorSpace, const SkScalar pos[],
|
|
|
|
int count, SkShader::TileMode mode,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
|
|
|
static sk_sp<SkShader> MakeTwoPointConical(const SkPoint& start, SkScalar startRadius,
|
|
|
|
const SkPoint& end, SkScalar endRadius,
|
|
|
|
const SkColor4f colors[],
|
|
|
|
sk_sp<SkColorSpace> colorSpace, const SkScalar pos[],
|
|
|
|
int count, SkShader::TileMode mode) {
|
|
|
|
return MakeTwoPointConical(start, startRadius, end, endRadius, colors,
|
2017-08-28 14:34:05 +00:00
|
|
|
std::move(colorSpace), pos, count, mode, 0, nullptr);
|
2016-09-28 18:27:28 +00:00
|
|
|
}
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
/** Returns a shader that generates a sweep gradient given a center.
|
|
|
|
<p />
|
2017-08-01 20:38:08 +00:00
|
|
|
@param cx The X coordinate of the center of the sweep
|
|
|
|
@param cx The Y coordinate of the center of the sweep
|
|
|
|
@param colors The array[count] of colors, to be distributed around the center, within
|
|
|
|
the gradient angle range.
|
|
|
|
@param pos May be NULL. The array[count] of SkScalars, or NULL, of the relative
|
|
|
|
position of each corresponding color in the colors array. If this is
|
|
|
|
NULL, then the colors are distributed evenly within the angular range.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
|
|
|
@param count Must be >= 2. The number of colors (and pos if not NULL) entries
|
|
|
|
@param mode Tiling mode: controls drawing outside of the gradient angular range.
|
|
|
|
@param startAngle Start of the angular range, corresponding to pos == 0.
|
|
|
|
@param endAngle End of the angular range, corresponding to pos == 1.
|
2008-12-17 15:59:43 +00:00
|
|
|
*/
|
2016-03-09 02:50:00 +00:00
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
2017-08-01 20:38:08 +00:00
|
|
|
SkShader::TileMode mode,
|
|
|
|
SkScalar startAngle, SkScalar endAngle,
|
2016-03-09 02:50:00 +00:00
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
2017-08-01 20:38:08 +00:00
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix) {
|
|
|
|
return MakeSweep(cx, cy, colors, pos, count, SkShader::kClamp_TileMode, 0, 360, flags,
|
|
|
|
localMatrix);
|
|
|
|
}
|
2016-03-09 02:50:00 +00:00
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor colors[], const SkScalar pos[], int count) {
|
2017-08-01 20:38:08 +00:00
|
|
|
return MakeSweep(cx, cy, colors, pos, count, 0, nullptr);
|
2016-03-09 02:50:00 +00:00
|
|
|
}
|
|
|
|
|
2016-09-28 18:27:28 +00:00
|
|
|
/** Returns a shader that generates a sweep gradient given a center.
|
|
|
|
<p />
|
2017-08-01 20:38:08 +00:00
|
|
|
@param cx The X coordinate of the center of the sweep
|
|
|
|
@param cx The Y coordinate of the center of the sweep
|
|
|
|
@param colors The array[count] of colors, to be distributed around the center, within
|
|
|
|
the gradient angle range.
|
|
|
|
@param pos May be NULL. The array[count] of SkScalars, or NULL, of the relative
|
|
|
|
position of each corresponding color in the colors array. If this is
|
|
|
|
NULL, then the colors are distributed evenly within the angular range.
|
|
|
|
If this is not null, the values must begin with 0, end with 1.0, and
|
|
|
|
intermediate values must be strictly increasing.
|
|
|
|
@param count Must be >= 2. The number of colors (and pos if not NULL) entries
|
|
|
|
@param mode Tiling mode: controls drawing outside of the gradient angular range.
|
|
|
|
@param startAngle Start of the angular range, corresponding to pos == 0.
|
|
|
|
@param endAngle End of the angular range, corresponding to pos == 1.
|
2016-09-28 18:27:28 +00:00
|
|
|
*/
|
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count,
|
2017-08-01 20:38:08 +00:00
|
|
|
SkShader::TileMode mode,
|
|
|
|
SkScalar startAngle, SkScalar endAngle,
|
2016-09-28 18:27:28 +00:00
|
|
|
uint32_t flags, const SkMatrix* localMatrix);
|
2017-08-01 20:38:08 +00:00
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count,
|
|
|
|
uint32_t flags, const SkMatrix* localMatrix) {
|
|
|
|
return MakeSweep(cx, cy, colors, std::move(colorSpace), pos, count,
|
|
|
|
SkShader::kClamp_TileMode, 0, 360, flags, localMatrix);
|
|
|
|
}
|
2016-09-28 18:27:28 +00:00
|
|
|
static sk_sp<SkShader> MakeSweep(SkScalar cx, SkScalar cy,
|
|
|
|
const SkColor4f colors[], sk_sp<SkColorSpace> colorSpace,
|
|
|
|
const SkScalar pos[], int count) {
|
2017-08-01 20:38:08 +00:00
|
|
|
return MakeSweep(cx, cy, colors, std::move(colorSpace), pos, count, 0, nullptr);
|
2016-09-28 18:27:28 +00:00
|
|
|
}
|
|
|
|
|
2012-03-23 19:00:34 +00:00
|
|
|
SK_DECLARE_FLATTENABLE_REGISTRAR_GROUP()
|
2008-12-17 15:59:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|