Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(18)

Unified Diff: gm/gradients_gpu.cpp

Issue 22854005: GPU Gradients (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Moved mode toggling back to base class, fixed EffectKey masking. Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | gyp/gmslides.gypi » ('j') | samplecode/SampleApp.cpp » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gm/gradients_gpu.cpp
diff --git a/gm/gradientDirtyLaundry.cpp b/gm/gradients_gpu.cpp
similarity index 63%
copy from gm/gradientDirtyLaundry.cpp
copy to gm/gradients_gpu.cpp
index ff6864ad7a7584d2a2609f587502c778e9046c18..0caef6eebd51b840e90d1a975084e6f20b4c0d7d 100644
--- a/gm/gradientDirtyLaundry.cpp
+++ b/gm/gradients_gpu.cpp
@@ -1,4 +1,3 @@
-
/*
* Copyright 2013 Google Inc.
*
@@ -17,22 +16,14 @@ struct GradData {
};
static const SkColor gColors[] = {
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
- SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK,
+ SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE,
};
-//static const SkScalar gPos[] = { SK_Scalar1*999/2000, SK_Scalar1*1001/2000 };
-
static const GradData gGradData[] = {
- { 40, gColors, NULL },
- // { 2, gColors, gPos },
- // { 2, gCol2, NULL },
+ { 1, gColors, NULL },
+ { 2, gColors, NULL },
+// { 3, gColors, NULL },
+ { 4, gColors, NULL },
};
static SkShader* MakeLinear(const SkPoint pts[2], const GradData& data,
@@ -59,11 +50,37 @@ static SkShader* MakeSweep(const SkPoint pts[2], const GradData& data,
data.fPos, data.fCount, mapper);
}
+static SkShader* Make2Radial(const SkPoint pts[2], const GradData& data,
+ SkShader::TileMode tm, SkUnitMapper* mapper) {
+ SkPoint center0, center1;
+ center0.set(SkScalarAve(pts[0].fX, pts[1].fX),
+ SkScalarAve(pts[0].fY, pts[1].fY));
+ center1.set(SkScalarInterp(pts[0].fX, pts[1].fX, SkIntToScalar(3)/5),
+ SkScalarInterp(pts[0].fY, pts[1].fY, SkIntToScalar(1)/4));
+ return SkGradientShader::CreateTwoPointRadial(
+ center1, (pts[1].fX - pts[0].fX) / 7,
+ center0, (pts[1].fX - pts[0].fX) / 2,
+ data.fColors, data.fPos, data.fCount, tm, mapper);
+}
+
+static SkShader* Make2Conical(const SkPoint pts[2], const GradData& data,
+ SkShader::TileMode tm, SkUnitMapper* mapper) {
+ SkPoint center0, center1;
+ SkScalar radius0 = SkScalarDiv(pts[1].fX - pts[0].fX, 10);
+ SkScalar radius1 = SkScalarDiv(pts[1].fX - pts[0].fX, 3);
+ center0.set(pts[0].fX + radius0, pts[0].fY + radius0);
+ center1.set(pts[1].fX - radius1, pts[1].fY - radius1);
+ return SkGradientShader::CreateTwoPointConical(center1, radius1,
+ center0, radius0,
+ data.fColors, data.fPos,
+ data.fCount, tm, mapper);
+}
+
typedef SkShader* (*GradMaker)(const SkPoint pts[2], const GradData& data,
SkShader::TileMode tm, SkUnitMapper* mapper);
static const GradMaker gGradMakers[] = {
- MakeLinear, MakeRadial, MakeSweep,
+ MakeLinear, MakeRadial, MakeSweep, Make2Radial, Make2Conical,
};
///////////////////////////////////////////////////////////////////////////////
@@ -75,7 +92,7 @@ public:
}
protected:
- SkString onShortName() SK_OVERRIDE { return SkString("gradient_dirty_laundry"); }
+ SkString onShortName() SK_OVERRIDE { return SkString("gradients_gpu"); }
virtual SkISize onISize() SK_OVERRIDE { return make_isize(640, 615); }
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
@@ -88,9 +105,9 @@ protected:
paint.setAntiAlias(true);
canvas->translate(SkIntToScalar(20), SkIntToScalar(20));
- for (size_t i = 0; i < SK_ARRAY_COUNT(gGradData); i++) {
+ for (size_t i = 0; i < SK_ARRAY_COUNT(gGradData); ++i) {
canvas->save();
- for (size_t j = 0; j < SK_ARRAY_COUNT(gGradMakers); j++) {
+ for (size_t j = 0; j < 1; ++j){ //SK_ARRAY_COUNT(gGradMakers); ++j) {
bsalomon 2013/08/13 14:28:37 Is this intended?
dierk 2013/08/13 19:50:17 Was done for test purposes when modifications were
SkShader* shader = gGradMakers[j](pts, gGradData[i], tm, NULL);
paint.setShader(shader)->unref();
canvas->drawRect(r, paint);
« no previous file with comments | « no previous file | gyp/gmslides.gypi » ('j') | samplecode/SampleApp.cpp » ('J')

Powered by Google App Engine
This is Rietveld 408576698