Index: gm/patch.cpp |
diff --git a/gm/patch.cpp b/gm/patch.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2e54df24d573237cc06532eb45dcb7f80fee4d19 |
--- /dev/null |
+++ b/gm/patch.cpp |
@@ -0,0 +1,88 @@ |
+ |
+/* |
+ * Copyright 2014 Google Inc. |
+ * |
+ * Use of this source code is governed by a BSD-style license that can be |
+ * found in the LICENSE file. |
+ */ |
+ |
+// This test only works with the GPU backend. |
+ |
+#include "gm.h" |
+ |
+#if SK_SUPPORT_GPU |
+ |
+#include "GrContext.h" |
+#include "GrTest.h" |
+ |
+#include "SkPatch.h" |
+ |
+namespace skiagm { |
+/** |
+ * This GM draws a SkPatch. |
+ */ |
+class SkPatchGM : public GM { |
+public: |
+ SkPatchGM() { |
+ this->setBGColor(0xFFFFFFFF); |
+ } |
+ |
+protected: |
+ virtual SkString onShortName() SK_OVERRIDE { |
+ return SkString("skpatch"); |
bsalomon
2014/07/24 18:10:23
maybe just call it patch? I don't think similar gm
dandov
2014/07/24 19:56:46
I changed to patch_primitive because there is alre
|
+ } |
+ |
+ virtual SkISize onISize() SK_OVERRIDE { |
+ return SkISize::Make(800, 800); |
+ } |
+ |
+ virtual uint32_t onGetFlags() const SK_OVERRIDE { |
+ // This is a GPU-specific GM. |
+ return kGPUOnly_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}, |
+ {110,590}, {140,550}, {515,595}, {600,700}, |
+ {70,150}, {125,400}, |
+ {350,125}, {490,555} |
+ }; |
+ |
+ SkPatch coons(points, colors, 10); |
+ coons.setData(); |
+ |
+ canvas->drawVertices(SkCanvas::kTriangles_VertexMode,coons.getVertexCount(), |
+ coons.getPoints(), coons.getTexCoords(), coons.getColors(), NULL, coons.getIndices(), |
+ coons.getIndexCount(), paint); |
+ |
+ //draw control points |
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, coons.getBottomPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, coons.getTopPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, coons.getLeftPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kLines_PointMode, 4, coons.getRightPoints(), paint); |
+ |
+ paint.setStrokeWidth(5); |
+ paint.setColor(SK_ColorRED); |
+ |
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, coons.getBottomPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, coons.getTopPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, coons.getLeftPoints(), paint); |
+ canvas->drawPoints(SkCanvas::kPoints_PointMode, 4, coons.getRightPoints(), paint); |
+ } |
+ |
+private: |
+ typedef GM INHERITED; |
+}; |
+ |
+DEF_GM( return SkNEW(SkPatchGM); ) |
+ |
+} |
+ |
+#endif |