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

Unified Diff: gm/patch.cpp

Issue 429343004: Stopped skipping tests in dm of SkPatch (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Removed Random Patches in GM Created 6 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 | include/core/SkCanvas.h » ('j') | include/core/SkPatch.h » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gm/patch.cpp
diff --git a/gm/patch.cpp b/gm/patch.cpp
index 5658ef6a889d9d65788a708a7cff44e57259b9d6..3a767ae6a352eeb9375fdd830926cceef54a2cd0 100644
--- a/gm/patch.cpp
+++ b/gm/patch.cpp
@@ -16,16 +16,16 @@
#include "GrTest.h"
#include "SkPatch.h"
robertphillips 2014/08/05 15:42:00 I don't think we should pass in the paint. It does
dandov 2014/08/05 17:34:05 Done.
-static void draw_control_points(SkCanvas* canvas, SkPatch& patch, SkPaint& paint) {
+static void draw_control_points(SkCanvas* canvas, const SkPatch& patch, const SkPaint& paint) {
//draw control points
SkPaint copy(paint);
- SkPoint bottom[4];
+ SkPoint bottom[SkPatch::kNumPtsCubic];
patch.getBottomPoints(bottom);
- SkPoint top[4];
+ SkPoint top[SkPatch::kNumPtsCubic];
patch.getTopPoints(top);
- SkPoint left[4];
+ SkPoint left[SkPatch::kNumPtsCubic];
patch.getLeftPoints(left);
- SkPoint right[4];
+ SkPoint right[SkPatch::kNumPtsCubic];
patch.getRightPoints(right);
copy.setColor(SK_ColorBLACK);
@@ -59,20 +59,6 @@ static void draw_control_points(SkCanvas* canvas, SkPatch& patch, SkPaint& paint
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.
@@ -94,40 +80,51 @@ protected:
}
virtual uint32_t onGetFlags() const SK_OVERRIDE {
- return kSkipTiled_Flag | kSkipPipe_Flag | kSkipPicture_Flag;
+ return kSkipTiled_Flag;
}
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
SkPaint paint;
- SkColor colors[4] = {
+
+ // The order of the colors and points is clockwise starting at upper-left corner.
+ SkColor colors[SkPatch::kNumColors] = {
SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorCYAN
};
- SkPoint points[12] = {
+ SkPoint points[SkPatch::kNumCtrlPts] = {
+ //top points
{50,50},{75,20},{125,80}, {150,50},
- {120,75},{180,125},{150,150},
- {125,120},{75,180},{50,150},
+ //right points
+ {120,75},{180,125},
+ //bottom points
+ {150,150},{125,120},{75,180},{50,150},
+ //left points
{20,125},{80,75}
};
- SkRandom rnd;
- SkScalar scale = 0.5f;
+ SkPatch patch(points, colors);
robertphillips 2014/08/05 15:42:00 kScale ?
dandov 2014/08/05 17:34:05 Done.
+ static const SkScalar scale = 0.5f;
+ canvas->translate(100, 100);
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->drawPatch(patch, paint);
+ draw_control_points(canvas, patch, paint);
canvas->restore();
}
+
canvas->translate(0, 270);
- SkScalar skew = 0.1f;
+
robertphillips 2014/08/05 15:42:00 kSkew ?
dandov 2014/08/05 17:34:05 Done.
+ static const SkScalar skew = 0.2f;
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->skew(skew * (x + 1), skew * (x + 1));
+ canvas->drawPatch(patch, paint);
+ draw_control_points(canvas, patch, paint);
canvas->restore();
}
canvas->restore();
« no previous file with comments | « no previous file | include/core/SkCanvas.h » ('j') | include/core/SkPatch.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698