aboutsummaryrefslogtreecommitdiffhomepage
path: root/gm/patch.cpp
diff options
context:
space:
mode:
authorGravatar dandov <dandov@google.com>2014-08-04 10:02:00 -0700
committerGravatar Commit bot <commit-bot@chromium.org>2014-08-04 10:02:00 -0700
commitecfff21bde1f0ca3c36533eded325066b5f2d42d (patch)
tree72fd989d958f337a3b6c779cc3f8f34378645501 /gm/patch.cpp
parentd3d6b818c70fa809837eb0cdf2ff5a5d4c6dff53 (diff)
SkCanvas interface for drawing a patch.
Added function SkCanvas::drawPatch to the API. This function receives the patch to draw and the paint. Added function SkBaseDevice::drawPatch to the API. This function also receives the patch to draw and the paint. Currently SkGpuDevice and SkBitmapDevice generate the mesh taking into account the scale factor and call the corresponding device's drawVertices. BUG=skia: R=jvanverth@google.com, egdaniel@google.com, bsalomon@google.com Author: dandov@google.com Review URL: https://codereview.chromium.org/424663006
Diffstat (limited to 'gm/patch.cpp')
-rw-r--r--gm/patch.cpp146
1 files changed, 88 insertions, 58 deletions
diff --git a/gm/patch.cpp b/gm/patch.cpp
index eb99944c0b..5658ef6a88 100644
--- a/gm/patch.cpp
+++ b/gm/patch.cpp
@@ -14,14 +14,71 @@
#include "GrContext.h"
#include "GrTest.h"
-
#include "SkPatch.h"
+static void draw_control_points(SkCanvas* canvas, SkPatch& patch, SkPaint& paint) {
+ //draw control points
+ SkPaint copy(paint);
+ SkPoint bottom[4];
+ patch.getBottomPoints(bottom);
+ SkPoint top[4];
+ patch.getTopPoints(top);
+ SkPoint left[4];
+ patch.getLeftPoints(left);
+ SkPoint right[4];
+ patch.getRightPoints(right);
+
+ copy.setColor(SK_ColorBLACK);
+ copy.setStrokeWidth(0.5);
+ SkPoint corners[4] = { bottom[0], bottom[3], top[0], top[3] };
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, bottom, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 2, bottom+1, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, top, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, left, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, right, copy);
+
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 2, top+1, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 2, left+1, copy);
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 2, right+1, copy);
+
+ copy.setStrokeWidth(2);
+
+ copy.setColor(SK_ColorRED);
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, corners, copy);
+
+ copy.setColor(SK_ColorBLUE);
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, bottom+1, copy);
+
+ copy.setColor(SK_ColorCYAN);
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, top+1, copy);
+
+ copy.setColor(SK_ColorYELLOW);
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, left+1, copy);
+
+ copy.setColor(SK_ColorGREEN);
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, right+1, copy);
+}
+
+static void draw_random_patch(SkPoint points[12], SkColor colors[4], SkCanvas* canvas,
+ SkPaint& paint, SkRandom* rnd) {
+ SkPoint ptsCpy[12];
+ memcpy(ptsCpy, points, 12 * sizeof(SkPoint));
+ for (int i = 0; i < 5; i++) {
+ int index = rnd->nextRangeU(0, 11);
+ SkScalar dx = rnd->nextRangeScalar(-50, 50), dy = rnd->nextRangeScalar(-50, 50);
+ ptsCpy[index].offset(dx, dy);
+ }
+ SkPatch patch(ptsCpy, colors);
+ canvas->drawPatch(patch, paint);
+ draw_control_points(canvas, patch, paint);
+}
+
namespace skiagm {
/**
* This GM draws a SkPatch.
*/
class SkPatchGM : public GM {
+
public:
SkPatchGM() {
this->setBGColor(0xFFFFFFFF);
@@ -37,77 +94,50 @@ protected:
}
virtual uint32_t onGetFlags() const SK_OVERRIDE {
- return kGPUOnly_Flag;
+ return kSkipTiled_Flag | kSkipPipe_Flag | kSkipPicture_Flag;
}
-
-
+
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
-
+
SkPaint paint;
SkColor colors[4] = {
SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorCYAN
};
- SkPoint points[] = {
- {100,100},{130,50},{500,70}, {650,60},
- {350,125},{490,555},{600,700},
- {515,595},{140,550},{110,590},
- {125,400},{70,150}
-
+ SkPoint points[12] = {
+ {50,50},{75,20},{125,80}, {150,50},
+ {120,75},{180,125},{150,150},
+ {125,120},{75,180},{50,150},
+ {20,125},{80,75}
};
-
- SkPatch coons(points, colors);
- SkPatch::VertexData data;
- coons.getVertexData(&data, 10);
-
- canvas->drawVertices(SkCanvas::kTriangles_VertexMode,data.fVertexCount,
- data.fPoints, data.fTexCoords, data.fColors, NULL, data.fIndices,
- data.fIndexCount, paint);
-
- //draw control points
- SkPoint bottom[4];
- coons.getBottomPoints(bottom);
- SkPoint top[4];
- coons.getTopPoints(top);
- SkPoint left[4];
- coons.getLeftPoints(left);
- SkPoint right[4];
- coons.getRightPoints(right);
-
- SkPoint corners[4] = { bottom[0], bottom[3], top[0], top[3] };
- canvas->drawPoints(SkCanvas::kLines_PointMode, 4, bottom, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 2, bottom+1, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 4, top, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 4, left, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 4, right, paint);
-
- canvas->drawPoints(SkCanvas::kLines_PointMode, 2, top+1, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 2, left+1, paint);
- canvas->drawPoints(SkCanvas::kLines_PointMode, 2, right+1, paint);
-
- paint.setStrokeWidth(10);
-
- paint.setColor(SK_ColorRED);
- canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, corners, paint);
-
- paint.setColor(SK_ColorBLUE);
- canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, bottom+1, paint);
-
- paint.setColor(SK_ColorCYAN);
- canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, top+1, paint);
-
- paint.setColor(SK_ColorYELLOW);
- canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, left+1, paint);
-
- paint.setColor(SK_ColorGREEN);
- canvas->drawPoints(SkCanvas::kPoints_PointMode, 2, right+1, paint);
+ SkRandom rnd;
+ SkScalar scale = 0.5f;
+ canvas->save();
+ for (SkScalar x = 0; x < 4; x++) {
+ canvas->save();
+ canvas->scale(scale * (x + 1), scale * (x + 1));
+ canvas->translate(x * 100, 0);
+ draw_random_patch(points, colors, canvas, paint, &rnd);
+ canvas->restore();
+ }
+ canvas->translate(0, 270);
+ SkScalar skew = 0.1f;
+ for (SkScalar x = 0; x < 4; x++) {
+ canvas->save();
+ canvas->scale(scale * (x + 1), scale * (x + 1));
+ canvas->skew(skew * (x + 1), skew * (x + 1));
+ canvas->translate(x * 100, 0);
+ draw_random_patch(points, colors, canvas, paint, &rnd);
+ canvas->restore();
+ }
+ canvas->restore();
}
private:
typedef GM INHERITED;
};
-DEF_GM( return SkNEW(SkPatchGM); )
+DEF_GM(return SkNEW(SkPatchGM); )
}