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

Unified Diff: src/core/SkCanvasDrawable.h

Issue 696063005: initial checkin for experimenting (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 6 years, 1 month 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 | « gyp/core.gypi ('k') | src/core/SkCanvasDrawable.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/core/SkCanvasDrawable.h
diff --git a/src/core/SkCanvasDrawable.h b/src/core/SkCanvasDrawable.h
new file mode 100644
index 0000000000000000000000000000000000000000..8092ea0b7a49755cbe2f497fa37425015b1cfe30
--- /dev/null
+++ b/src/core/SkCanvasDrawable.h
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2014 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#ifndef SkCanvasDrawable_DEFINED
+#define SkCanvasDrawable_DEFINED
+
+#include "SkRefCnt.h"
+
+class SkCanvas;
+struct SkRect;
+
+/**
+ * Base-class to capture a set of drawing commands (sent to SkCanvas). Instances of this class
+ * need not be thread-safe, but they must be able to be used in a thread different from where
+ * they were created.
+ */
+class SkCanvasDrawable : public SkRefCnt {
+public:
+ SkCanvasDrawable();
+
+ /**
+ * Draws into the specified content. The drawing sequence will be balanced upon return
+ * (i.e. the saveLevel() on the canvas will match what it was when draw() was called,
+ * and the current matrix and clip settings will not be changed.
+ */
+ void draw(SkCanvas*);
+
+ /**
+ * Return a unique value for this instance. If two calls to this return the same value,
+ * it is presumed that calling the draw() method will render the same thing as well.
+ *
+ * Subclasses that change their state should call notifyDrawingChanged() to ensure that
+ * a new value will be returned the next time it is called.
+ */
+ uint32_t getGenerationID();
+
+ /**
+ * If the drawable knows a bounds that will contains all of its drawing, return true and
+ * set the parameter to that rectangle. If one is not known, ignore the parameter and
+ * return false.
+ */
+ bool getBounds(SkRect*);
+
+ void notifyDrawingChanged();
+
+protected:
+ virtual void onDraw(SkCanvas*) = 0;
+
+ virtual bool onGetBounds(SkRect*) { return false; }
+
+private:
+ int32_t fGenerationID;
+};
+
+#endif
« no previous file with comments | « gyp/core.gypi ('k') | src/core/SkCanvasDrawable.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698