diff options
author | 2011-03-20 20:19:16 +0000 | |
---|---|---|
committer | 2011-03-20 20:19:16 +0000 | |
commit | b7d956df4665e06f3ae98cb696cef7c04452ab8e (patch) | |
tree | 9b620b126a92185178fa5c6e296875dd98993d71 | |
parent | 57463e1908399a489af24583654c38641e265e25 (diff) |
add draw sample
git-svn-id: http://skia.googlecode.com/svn/trunk@966 2bbb7eff-a529-9590-31e7-b0007b416f81
-rw-r--r-- | include/core/SkPoint.h | 3 | ||||
-rw-r--r-- | samplecode/SampleDraw.cpp | 177 |
2 files changed, 180 insertions, 0 deletions
diff --git a/include/core/SkPoint.h b/include/core/SkPoint.h index c89f08003a..52dbd51f6e 100644 --- a/include/core/SkPoint.h +++ b/include/core/SkPoint.h @@ -149,6 +149,9 @@ struct SK_API SkPoint { return pt; } + SkScalar x() const { return fX; } + SkScalar y() const { return fY; } + /** Set the point's X and Y coordinates */ void set(SkScalar x, SkScalar y) { fX = x; fY = y; } diff --git a/samplecode/SampleDraw.cpp b/samplecode/SampleDraw.cpp new file mode 100644 index 0000000000..d7e8dce4a3 --- /dev/null +++ b/samplecode/SampleDraw.cpp @@ -0,0 +1,177 @@ +#include "SampleCode.h" +#include "SkView.h" +#include "SkCanvas.h" +#include "SkGraphics.h" +#include "SkRandom.h" + +class Draw : public SkRefCnt { +public: + void draw(SkCanvas* canvas) { + this->onDraw(canvas); + } + +protected: + virtual void onDraw(SkCanvas*) = 0; +}; + +class RDraw : public Draw { +public: + enum Style { + kRect_Style, + kOval_Style, + kRRect_Style + }; + + RDraw(const SkRect& r, Style s) : fRect(r), fStyle(s) {} + + void setRect(const SkRect& r) { + fRect = r; + } + + void setPaint(const SkPaint& p) { + fPaint = p; + } + +protected: + virtual void onDraw(SkCanvas* canvas) { + switch (fStyle) { + case kRect_Style: + canvas->drawRect(fRect, fPaint); + break; + case kOval_Style: + canvas->drawOval(fRect, fPaint); + break; + case kRRect_Style: { + SkScalar rx = fRect.width() / 5; + SkScalar ry = fRect.height() / 5; + if (rx < ry) { + ry = rx; + } else { + rx = ry; + } + canvas->drawRoundRect(fRect, rx, ry, fPaint); + break; + } + } + } + +private: + SkRect fRect; + SkPaint fPaint; + Style fStyle; +}; + +class DrawFactory { +public: + DrawFactory() { + fPaint.setAntiAlias(true); + } + + const SkPaint& getPaint() const { return fPaint; } + + void setPaint(const SkPaint& p) { + fPaint = p; + } + + virtual Draw* create(const SkPoint&, const SkPoint&) = 0; + +private: + SkPaint fPaint; +}; + +class RectFactory : public DrawFactory { +public: + virtual Draw* create(const SkPoint& p0, const SkPoint& p1) { + SkRect r; + r.set(p0.x(), p0.y(), p1.x(), p1.y()); + r.sort(); + + RDraw* d = new RDraw(r, RDraw::kRRect_Style); + d->setPaint(this->getPaint()); + return d; + } +}; + +class DrawView : public SkView { + Draw* fDraw; + DrawFactory* fFactory; + SkRandom fRand; + SkTDArray<Draw*> fList; + +public: + DrawView() : fDraw(NULL) { + fFactory = new RectFactory; + } + + virtual ~DrawView() { + fList.unrefAll(); + SkSafeUnref(fDraw); + } + + Draw* setDraw(Draw* d) { + SkRefCnt_SafeAssign(fDraw, d); + return d; + } + + SkColor randColor() { + return (SkColor)fRand.nextU() | 0xFF000000; + } + +protected: + // overrides from SkEventSink + virtual bool onQuery(SkEvent* evt) { + if (SampleCode::TitleQ(*evt)) { + SampleCode::TitleR(evt, "Draw"); + return true; + } + return this->INHERITED::onQuery(evt); + } + + void drawBG(SkCanvas* canvas) { + canvas->drawColor(0xFFDDDDDD); +// canvas->drawColor(SK_ColorWHITE); + } + + virtual void onDraw(SkCanvas* canvas) { + this->drawBG(canvas); + + Draw** iter = fList.begin(); + Draw** stop = fList.end(); + for (; iter < stop; iter++) { + (*iter)->draw(canvas); + } + if (fDraw) { + fDraw->draw(canvas); + } + } + + virtual SkView::Click* onFindClickHandler(SkScalar x, SkScalar y) { + return new Click(this); + } + + virtual bool onClick(Click* click) { + if (Click::kUp_State == click->fState) { + *fList.append() = fDraw; + fDraw = NULL; + return true; + } + + if (Click::kDown_State == click->fState) { + SkPaint p = fFactory->getPaint(); + p.setColor(this->randColor()); + fFactory->setPaint(p); + } + this->setDraw(fFactory->create(click->fOrig, click->fCurr))->unref(); + this->inval(NULL); + return true; + } + +private: + typedef SkView INHERITED; +}; + +////////////////////////////////////////////////////////////////////////////// + +static SkView* MyFactory() { return new DrawView; } +static SkViewRegister reg(MyFactory); + |