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

Side by Side Diff: third_party/WebKit/Source/web/WebGraphicsContextImpl.h

Issue 1415143005: Preparation for enabling slimming paint synchronized painting (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase and fix webkit_unit_tests Created 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef WebGraphicsContextImpl_h 5 #ifndef WebGraphicsContextImpl_h
6 #define WebGraphicsContextImpl_h 6 #define WebGraphicsContextImpl_h
7 7
8 #include "platform/graphics/paint/DisplayItem.h" 8 #include "platform/graphics/paint/DisplayItem.h"
9 #include "platform/graphics/paint/DisplayItemCacheSkipper.h"
9 #include "platform/graphics/paint/DisplayItemClient.h" 10 #include "platform/graphics/paint/DisplayItemClient.h"
10 #include "public/web/WebGraphicsContext.h" 11 #include "public/web/WebGraphicsContext.h"
11 #include "wtf/OwnPtr.h" 12 #include "wtf/OwnPtr.h"
12 13
13 namespace blink { 14 namespace blink {
14 15
15 class DrawingRecorder; 16 class DrawingRecorder;
16 class GraphicsContext; 17 class GraphicsContext;
17 18
18 // Wraps a blink::GraphicsContext. 19 // Wraps a blink::GraphicsContext.
19 // Internal consumers can extract the underlying context (via WebGraphicsContext Impl). 20 // Internal consumers can extract the underlying context (via WebGraphicsContext Impl).
20 // External consumers can make a single drawing using a WebCanvas. 21 // External consumers can make a single drawing using a WebCanvas.
21 class WebGraphicsContextImpl : public WebGraphicsContext { 22 class WebGraphicsContextImpl : public WebGraphicsContext {
22 public: 23 public:
23 WebGraphicsContextImpl(GraphicsContext&, const DisplayItemClientWrapper&, Di splayItem::Type); 24 WebGraphicsContextImpl(GraphicsContext&, const DisplayItemClientWrapper&, Di splayItem::Type);
24 ~WebGraphicsContextImpl(); 25 ~WebGraphicsContextImpl();
25 GraphicsContext& graphicsContext() { return m_graphicsContext; } 26 GraphicsContext& graphicsContext() { return m_graphicsContext; }
26 27
27 // blink::WebGraphicsContext 28 // blink::WebGraphicsContext
28 WebCanvas* beginDrawing(const WebFloatRect& bounds) override; 29 WebCanvas* beginDrawing(const WebFloatRect& bounds) override;
29 void endDrawing() override; 30 void endDrawing() override;
30 31
31 private: 32 private:
32 GraphicsContext& m_graphicsContext; 33 GraphicsContext& m_graphicsContext;
33 DisplayItemClientWrapper m_client; 34 DisplayItemClientWrapper m_client;
34 DisplayItem::Type m_type; 35 DisplayItem::Type m_type;
35 OwnPtr<DrawingRecorder> m_drawingRecorder; 36 OwnPtr<DrawingRecorder> m_drawingRecorder;
37 DisplayItemCacheSkipper m_cacheSkipper;
pdr. 2015/10/29 04:06:10 I wouldn't expect WebGraphicsContext to disable ca
Xianzhu 2015/10/29 04:22:01 WebGraphicsContext seems to expect that no cache e
chrishtr 2015/10/29 20:22:46 Let's delete the beginDrawing()/endDrawing() metho
36 #ifndef NDEBUG 38 #ifndef NDEBUG
37 bool m_hasBegunDrawing; 39 bool m_hasBegunDrawing;
38 #endif 40 #endif
39 }; 41 };
40 42
41 // Source/web/ assumes that WebGraphicsContextImpl is the only implementation. 43 // Source/web/ assumes that WebGraphicsContextImpl is the only implementation.
42 DEFINE_TYPE_CASTS(WebGraphicsContextImpl, WebGraphicsContext, webGraphicsContext , true, true); 44 DEFINE_TYPE_CASTS(WebGraphicsContextImpl, WebGraphicsContext, webGraphicsContext , true, true);
43 45
44 } // namespace blink 46 } // namespace blink
45 47
46 #endif 48 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698