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

Side by Side Diff: cc/picture.h

Issue 11731002: Implement a method to access the non-composited content root layer picture pile. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase. Created 7 years, 11 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « cc/layer_tree_host_unittest.cc ('k') | cc/picture_layer_impl.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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 CC_PICTURE_H_ 5 #ifndef CC_PICTURE_H_
6 #define CC_PICTURE_H_ 6 #define CC_PICTURE_H_
7 7
8 #include <list> 8 #include <list>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
(...skipping 19 matching lines...) Expand all
30 const gfx::Rect& OpaqueRect() const { return opaque_rect_; } 30 const gfx::Rect& OpaqueRect() const { return opaque_rect_; }
31 31
32 // Make a thread-safe clone for rasterizing with. 32 // Make a thread-safe clone for rasterizing with.
33 scoped_refptr<Picture> Clone() const; 33 scoped_refptr<Picture> Clone() const;
34 34
35 // Record a paint operation. To be able to safely use this SkPicture for 35 // Record a paint operation. To be able to safely use this SkPicture for
36 // playback on a different thread this can only be called once. 36 // playback on a different thread this can only be called once.
37 void Record(ContentLayerClient*, RenderingStats&); 37 void Record(ContentLayerClient*, RenderingStats&);
38 38
39 // Has Record() been called yet? 39 // Has Record() been called yet?
40 bool HasRecording() const { return picture_.get(); } 40 bool HasRecording() const { return picture_.get() != NULL; }
41 41
42 // Apply this contents scale and raster the content rect into the canvas. 42 // Apply this contents scale and raster the content rect into the canvas.
43 void Raster(SkCanvas* canvas, gfx::Rect content_rect, float contents_scale); 43 void Raster(SkCanvas* canvas, gfx::Rect content_rect, float contents_scale);
44 44
45 void GatherPixelRefs(const gfx::Rect& rect, 45 void GatherPixelRefs(const gfx::Rect& rect,
46 std::list<skia::LazyPixelRef*>&); 46 std::list<skia::LazyPixelRef*>&);
47 47
48 private: 48 private:
49 Picture(gfx::Rect layer_rect); 49 Picture(gfx::Rect layer_rect);
50 // This constructor assumes SkPicture is already ref'd and transfers 50 // This constructor assumes SkPicture is already ref'd and transfers
51 // ownership to this picture. 51 // ownership to this picture.
52 Picture(const skia::RefPtr<SkPicture>&, 52 Picture(const skia::RefPtr<SkPicture>&,
53 gfx::Rect layer_rect, 53 gfx::Rect layer_rect,
54 gfx::Rect opaque_rect); 54 gfx::Rect opaque_rect);
55 ~Picture(); 55 ~Picture();
56 56
57 gfx::Rect layer_rect_; 57 gfx::Rect layer_rect_;
58 gfx::Rect opaque_rect_; 58 gfx::Rect opaque_rect_;
59 skia::RefPtr<SkPicture> picture_; 59 skia::RefPtr<SkPicture> picture_;
60 60
61 friend class base::RefCountedThreadSafe<Picture>; 61 friend class base::RefCountedThreadSafe<Picture>;
62 DISALLOW_COPY_AND_ASSIGN(Picture); 62 DISALLOW_COPY_AND_ASSIGN(Picture);
63 }; 63 };
64 64
65 } // namespace cc 65 } // namespace cc
66 66
67 #endif // CC_PICTURE_H_ 67 #endif // CC_PICTURE_H_
OLDNEW
« no previous file with comments | « cc/layer_tree_host_unittest.cc ('k') | cc/picture_layer_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698