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

Unified Diff: samplecode/SamplePathUtils.cpp

Issue 16829003: Adding my Bitmap2Path sample for 1on1 meeting. (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: fixed more trybot errors. Created 7 years, 6 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 | « include/utils/SkPathUtils.h ('k') | src/utils/SkPathUtils.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: samplecode/SamplePathUtils.cpp
diff --git a/samplecode/SamplePathUtils.cpp b/samplecode/SamplePathUtils.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..e7d0c538b7940d5334e1d0cf3c7bf18d0f4181ba
--- /dev/null
+++ b/samplecode/SamplePathUtils.cpp
@@ -0,0 +1,85 @@
+/*
+ * 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 "SampleCode.h"
+#include "SkCanvas.h"
+#include "SkPathUtils.h"
+#include "SkView.h"
+//#include "SkPathOps.h" // loads fine here, won't in PathUtils src files
+#include "SkRandom.h"
+#include "SkTime.h"
+
+class samplePathUtils : public SampleView {
+public:
+ samplePathUtils() {
+ bmp_paint.setAntiAlias(true); // Black paint for bitmap
+ bmp_paint.setStyle(SkPaint::kFill_Style);
+ bmp_paint.setColor(SK_ColorBLACK);
+ }
+
+protected:
+ static const int numModes = 3;
+ static const int h=8, w=12, stride=2, scale=10; // stride is in bytes
+ static const int numChars = h * stride; // number of chars in entire array
+
+ SkPaint bmp_paint;
+
+ // overrides from SkEventSink
+ virtual bool onQuery(SkEvent* evt) {
+ if (SampleCode::TitleQ(*evt)) {
+ SampleCode::TitleR(evt, "PathUtils");
+ return true;
+ }
+ return this->INHERITED::onQuery(evt);
+ }
+
+ /////////////////////////////////////////////////////////////
+
+ virtual void onDrawContent(SkCanvas* canvas) {
+ // bitmap definitions
+ const char bits[numModes][numChars] = {
+ { 0x18, 0x00, 0x3c, 0x00, 0x7e, 0x00, 0xdb, 0x00,
+ 0xff, 0x00, 0x24, 0x00, 0x5a, 0x00, 0xa5, 0x00 },
+
+ { 0x20, 0x80, 0x91, 0x20, 0xbf, 0xa0, 0xee, 0xe0,
+ 0xff, 0xe0, 0x7f, 0xc0, 0x20, 0x80, 0x40, 0x40 },
+
+ { 0x0f, 0x00, 0x7f, 0xe0, 0xff, 0xf0, 0xe6, 0x70,
+ 0xff, 0xf0, 0x19, 0x80, 0x36, 0xc0, 0xc0, 0x30 }
+ };
+
+ for (int i = 0; i < numModes; ++i) {
+ SkPath path; // generate and simplify each path
+ SkPathUtils::BitsToPath_Path(&path, (char*) &bits[i], h, w, stride);
+
+ canvas->save(); // DRAWING
+ canvas->scale(scale, scale); // scales up each bitmap
+ canvas->translate(0, 1.5f * h * i);
+ canvas->drawPath(path, bmp_paint); // draw bitmap
+ canvas->restore();
+
+ // use the SkRegion method
+ SkPath pathR;
+ SkPathUtils::BitsToPath_Region(&pathR, (char*) &bits[i], h, w, stride);
+
+ canvas->save();
+ canvas->scale(scale, scale); // scales up each bitmap
+ canvas->translate(1.5f * w, 1.5f * h * i); // translates past previous bitmap
+ canvas->drawPath(pathR, bmp_paint); // draw bitmap
+ canvas->restore();
+ }
+ }
+
+private:
+ typedef SkView INHERITED;
+};
+
+//////////////////////////////////////////////////////////////////////////////
+
+static SkView* MyFactory() { return new samplePathUtils; }
+static SkViewRegister reg(MyFactory)
+;
« no previous file with comments | « include/utils/SkPathUtils.h ('k') | src/utils/SkPathUtils.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698