Index: gm/pathopsinverse.cpp |
=================================================================== |
--- gm/pathopsinverse.cpp (revision 0) |
+++ gm/pathopsinverse.cpp (revision 0) |
@@ -0,0 +1,116 @@ |
+/* |
+ * Copyright 2013 Google Inc. |
+ * |
+ * Use of this source code is governed by a BSD-style license that can be |
+ * found in the LICENSE file. |
+ */ |
+ |
+#include "gm.h" |
+#include "SkBitmap.h" |
+#include "SkPath.h" |
+#include "SkPathOps.h" |
+#include "SkRect.h" |
+ |
+namespace skiagm { |
+ |
+class PathOpsInverseGM : public GM { |
+public: |
+ PathOpsInverseGM() { |
+ this->makePaints(); |
bsalomon
2013/04/22 13:13:57
There's a virtual on GM called "onOnceBeforeDraw".
|
+ } |
+ |
+protected: |
+ void makePaints() { |
+ const unsigned oneColor = 0xFF8080FF; |
+ const unsigned twoColor = 0x807F1f1f; |
+ SkColor blendColor = blend(oneColor, twoColor); |
+ makePaint(&onePaint, oneColor); |
+ makePaint(&twoPaint, twoColor); |
+ makePaint(&opPaint[kDifference_PathOp], oneColor); |
+ makePaint(&opPaint[kIntersect_PathOp], blendColor); |
+ makePaint(&opPaint[kUnion_PathOp], 0xFFc0FFc0); |
+ makePaint(&opPaint[kReverseDifference_PathOp], twoColor); |
+ makePaint(&opPaint[kXOR_PathOp], 0xFFa0FFe0); |
+ makePaint(&outlinePaint, 0xFF000000); |
+ outlinePaint.setStyle(SkPaint::kStroke_Style); |
+ } |
+ |
+ SkColor blend(SkColor one, SkColor two) { |
+ SkBitmap temp; |
+ temp.setConfig(SkBitmap::kARGB_8888_Config, 1, 1); |
+ temp.allocPixels(); |
+ SkCanvas canvas(temp); |
+ canvas.drawColor(one); |
+ canvas.drawColor(two); |
+ void* pixels = temp.getPixels(); |
+ return *(SkColor*) pixels; |
+ } |
+ |
+ void makePaint(SkPaint* paint, SkColor color) { |
+ paint->setAntiAlias(true); |
+ paint->setStyle(SkPaint::kFill_Style); |
+ paint->setColor(color); |
+ } |
+ |
+ virtual SkString onShortName() SK_OVERRIDE { |
+ return SkString("pathopsinverse"); |
+ } |
+ |
+ virtual SkISize onISize() SK_OVERRIDE { |
+ return make_isize(1200, 900); |
+ } |
+ |
+ virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { |
+ SkPath one, two; |
+ int yPos = 0; |
+ for (int oneFill = 0; oneFill <= 1; ++oneFill) { |
+ SkPath::FillType oneF = oneFill ? SkPath::kInverseEvenOdd_FillType |
+ : SkPath::kEvenOdd_FillType; |
+ for (int twoFill = 0; twoFill <= 1; ++twoFill) { |
+ SkPath::FillType twoF = twoFill ? SkPath::kInverseEvenOdd_FillType |
+ : SkPath::kEvenOdd_FillType; |
+ one.reset(); |
+ one.setFillType(oneF); |
+ one.addRect(10, 10, 70, 70); |
+ two.reset(); |
+ two.setFillType(twoF); |
+ two.addRect(40, 40, 100, 100); |
+ canvas->save(); |
+ canvas->translate(0, SkIntToScalar(yPos)); |
+ canvas->clipRect(SkRect::MakeWH(110, 110), SkRegion::kIntersect_Op, true); |
+ canvas->drawPath(one, onePaint); |
+ canvas->drawPath(one, outlinePaint); |
+ canvas->drawPath(two, twoPaint); |
+ canvas->drawPath(two, outlinePaint); |
+ canvas->restore(); |
+ int xPos = 150; |
+ for (int op = kDifference_PathOp; op <= kReverseDifference_PathOp; ++op) { |
+ SkPath result; |
+ Op(one, two, (SkPathOp) op, &result); |
+ canvas->save(); |
+ canvas->translate(SkIntToScalar(xPos), SkIntToScalar(yPos)); |
+ canvas->clipRect(SkRect::MakeWH(110, 110), SkRegion::kIntersect_Op, true); |
+ canvas->drawPath(result, opPaint[op]); |
+ canvas->drawPath(result, outlinePaint); |
+ canvas->restore(); |
+ xPos += 150; |
+ } |
+ yPos += 150; |
+ } |
+ } |
+ } |
+ |
+private: |
+ SkPaint onePaint; |
bsalomon
2013/04/22 13:13:57
fOnePaint, etc?
|
+ SkPaint twoPaint; |
+ SkPaint outlinePaint; |
+ SkPaint opPaint[kReverseDifference_PathOp - kDifference_PathOp + 1]; |
+ typedef GM INHERITED; |
+}; |
+ |
+////////////////////////////////////////////////////////////////////////////// |
+ |
+static GM* MyFactory(void*) { return new PathOpsInverseGM; } |
+static GMRegistry reg(MyFactory); |
+ |
+} |