diff options
author | commit-bot@chromium.org <commit-bot@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-07-01 17:50:29 +0000 |
---|---|---|
committer | commit-bot@chromium.org <commit-bot@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-07-01 17:50:29 +0000 |
commit | 064779aa18694b68536c113f7d5b74ccbe38d3ba (patch) | |
tree | dfd68ac72495ef4eb86957526a65e74ee7a92283 /samplecode | |
parent | c6081abd2f28d2179ad8e3bef557cb0d00fffe01 (diff) |
Adding my Bitmap2Path sample for 1on1 meeting.
BUG=
R=reed@google.com, borenet@google.com
Author: dierk@google.com
Review URL: https://chromiumcodereview.appspot.com/16829003
git-svn-id: http://skia.googlecode.com/svn/trunk@9843 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'samplecode')
-rw-r--r-- | samplecode/SamplePathUtils.cpp | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/samplecode/SamplePathUtils.cpp b/samplecode/SamplePathUtils.cpp new file mode 100644 index 0000000000..e7d0c538b7 --- /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) +; |