Chromium Code Reviews| 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(); |