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

Unified Diff: sky/engine/core/painting/PaintingNode.h

Issue 1216833003: Make rendering use PaintingNodes for increased efficiency. (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Cleanup and fixes for keeping stocks working Created 5 years, 5 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 | « sky/engine/core/painting/Drawable.h ('k') | sky/engine/core/painting/PaintingNode.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sky/engine/core/painting/PaintingNode.h
diff --git a/sky/engine/core/painting/PaintingNode.h b/sky/engine/core/painting/PaintingNode.h
new file mode 100644
index 0000000000000000000000000000000000000000..7d58a065047b838bf186e9e69e959b4bac324fc7
--- /dev/null
+++ b/sky/engine/core/painting/PaintingNode.h
@@ -0,0 +1,55 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef SKY_ENGINE_CORE_PAINTING_PAINTINGNODE_H_
+#define SKY_ENGINE_CORE_PAINTING_PAINTINGNODE_H_
+
+#include "sky/engine/core/painting/Drawable.h"
+#include "sky/engine/tonic/dart_wrappable.h"
+#include "sky/engine/wtf/PassRefPtr.h"
+#include "sky/engine/wtf/RefCounted.h"
+#include "third_party/skia/include/core/SkDrawable.h"
+
+namespace blink {
+
+class PaintingNodeDrawable : public SkDrawable {
abarth-chromium 2015/07/07 20:49:39 One class per file, please.
iansf 2015/07/07 21:11:23 Done.
+public:
+ static PassRefPtr<PaintingNodeDrawable> create(PassRefPtr<SkDrawable> skDrawable = nullptr);
+
+ ~PaintingNodeDrawable() override {}
abarth-chromium 2015/07/07 20:49:39 Please move virtual (and override) implementations
iansf 2015/07/07 21:11:23 Done.
+
+ SkRect onGetBounds();
+ void onDraw(SkCanvas* canvas);
+ SkPicture* onNewPictureSnapshot();
+ void set_drawable(PassRefPtr<SkDrawable> drawable) { m_drawable = drawable; }
+
+private:
+ PaintingNodeDrawable();
+ explicit PaintingNodeDrawable(PassRefPtr<SkDrawable> skDrawable);
+ RefPtr<SkDrawable> m_drawable;
+};
+
+
+
+
+class PaintingNode : public RefCounted<PaintingNode>, public DartWrappable {
+ DEFINE_WRAPPERTYPEINFO();
+public:
+ static PassRefPtr<PaintingNode> create();
+ ~PaintingNode() override;
+
+ void setBackingDrawable(PassRefPtr<Drawable> drawable) {
+ m_paintingNodeDrawable->set_drawable(drawable->toSkia());
+ }
+ SkDrawable* toSkia() { return m_paintingNodeDrawable.get(); }
+ PassRefPtr<Picture> newPictureSnapshot();
+
+private:
+ PaintingNode();
+ RefPtr<PaintingNodeDrawable> m_paintingNodeDrawable;
+};
+
+} // namespace blink
+
+#endif // SKY_ENGINE_CORE_PAINTING_PAINTINGNODE_H_
« no previous file with comments | « sky/engine/core/painting/Drawable.h ('k') | sky/engine/core/painting/PaintingNode.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698