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

Side by Side Diff: cc/playback/display_item_list.h

Issue 1494223003: cc: Shrink size of display item (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: danakj review Created 5 years 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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_PLAYBACK_DISPLAY_ITEM_LIST_H_ 5 #ifndef CC_PLAYBACK_DISPLAY_ITEM_LIST_H_
6 #define CC_PLAYBACK_DISPLAY_ITEM_LIST_H_ 6 #define CC_PLAYBACK_DISPLAY_ITEM_LIST_H_
7 7
8 #include "base/gtest_prod_util.h" 8 #include "base/gtest_prod_util.h"
9 #include "base/memory/ref_counted.h" 9 #include "base/memory/ref_counted.h"
10 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
11 #include "base/trace_event/trace_event.h" 11 #include "base/trace_event/trace_event.h"
12 #include "cc/base/cc_export.h" 12 #include "cc/base/cc_export.h"
13 #include "cc/base/contiguous_container.h" 13 #include "cc/base/contiguous_container.h"
14 #include "cc/playback/discardable_image_map.h" 14 #include "cc/playback/discardable_image_map.h"
15 #include "cc/playback/display_item.h" 15 #include "cc/playback/display_item.h"
16 #include "cc/playback/display_item_list_settings.h" 16 #include "cc/playback/display_item_list_settings.h"
17 #include "skia/ext/refptr.h" 17 #include "skia/ext/refptr.h"
18 #include "third_party/skia/include/core/SkPicture.h" 18 #include "third_party/skia/include/core/SkPicture.h"
19 #include "ui/gfx/geometry/rect.h" 19 #include "ui/gfx/geometry/rect.h"
20 20
21 class SkCanvas; 21 class SkCanvas;
22 class SkPictureRecorder; 22 class SkPictureRecorder;
23 23
24 namespace cc { 24 namespace cc {
25 class DisplayItem;
26 class DrawingDisplayItem;
25 27
26 namespace proto { 28 namespace proto {
27 class DisplayItemList; 29 class DisplayItemList;
28 } 30 }
29 31
30 class CC_EXPORT DisplayItemList 32 class CC_EXPORT DisplayItemList
31 : public base::RefCountedThreadSafe<DisplayItemList> { 33 : public base::RefCountedThreadSafe<DisplayItemList> {
32 public: 34 public:
33 // Creates a display item list. If picture caching is used, then layer_rect 35 // Creates a display item list. If picture caching is used, then layer_rect
34 // specifies the cull rect of the display item list (the picture will not 36 // specifies the cull rect of the display item list (the picture will not
(...skipping 18 matching lines...) Expand all
53 void Raster(SkCanvas* canvas, 55 void Raster(SkCanvas* canvas,
54 SkPicture::AbortCallback* callback, 56 SkPicture::AbortCallback* callback,
55 const gfx::Rect& canvas_target_playback_rect, 57 const gfx::Rect& canvas_target_playback_rect,
56 float contents_scale) const; 58 float contents_scale) const;
57 59
58 // This is a fast path for use only if canvas_ is set and 60 // This is a fast path for use only if canvas_ is set and
59 // retain_individual_display_items_ is false. This method also updates 61 // retain_individual_display_items_ is false. This method also updates
60 // is_suitable_for_gpu_rasterization_ and approximate_op_count_. 62 // is_suitable_for_gpu_rasterization_ and approximate_op_count_.
61 void RasterIntoCanvas(const DisplayItem& display_item); 63 void RasterIntoCanvas(const DisplayItem& display_item);
62 64
63 template <typename DisplayItemType> 65 // Because processing happens in this function, all the set up for
64 DisplayItemType* CreateAndAppendItem(const gfx::Rect& visual_rect) { 66 // this item should be done via the args, which is why the return
65 #if DCHECK_IS_ON() 67 // type needs to be const, to prevent set-after-processing mistakes.
66 needs_process_ = true; 68 template <typename DisplayItemType, typename... Args>
67 #endif 69 const DisplayItemType& CreateAndAppendItem(const gfx::Rect& visual_rect,
70 const Args&... args) {
68 visual_rects_.push_back(visual_rect); 71 visual_rects_.push_back(visual_rect);
69 ProcessAppendedItemsOnTheFly(); 72 // TODO(enne): This should forward the args.
70 return &items_.AllocateAndConstruct<DisplayItemType>(); 73 auto* item = &items_.AllocateAndConstruct<DisplayItemType>(args...);
74 approximate_op_count_ += item->ApproximateOpCount();
75 // None of the items might individually trigger a veto even though they
danakj 2015/12/08 19:52:04 TODO(crbug.com/513016): ^ would be nice
enne (OOO) 2015/12/08 20:00:59 Done.
76 // collectively have enough "bad" operations that a corresponding flattened
77 // Picture would get vetoed. See crbug.com/513016
78 is_suitable_for_gpu_rasterization_ &= item->IsSuitableForGpuRasterization();
79 ProcessAppendedItem(item);
80 return *item;
71 } 81 }
72 82
73 // Removes the last item. This cannot be called on lists with cached pictures
74 // (since the data may already have been incorporated into cached picture
75 // sizes, etc).
76 void RemoveLast();
77
78 // Called after all items are appended, to process the items and, if 83 // Called after all items are appended, to process the items and, if
79 // applicable, create an internally cached SkPicture. 84 // applicable, create an internally cached SkPicture.
80 void Finalize(); 85 void Finalize();
81 86
82 bool IsSuitableForGpuRasterization() const; 87 bool IsSuitableForGpuRasterization() const;
83 int ApproximateOpCount() const; 88 int ApproximateOpCount() const;
84 size_t ApproximateMemoryUsage() const; 89 size_t ApproximateMemoryUsage() const;
85 bool ShouldBeAnalyzedForSolidColor() const; 90 bool ShouldBeAnalyzedForSolidColor() const;
86 91
87 bool RetainsIndividualDisplayItems() const; 92 bool RetainsIndividualDisplayItems() const;
88 93
89 scoped_refptr<base::trace_event::ConvertableToTraceFormat> AsValue( 94 scoped_refptr<base::trace_event::ConvertableToTraceFormat> AsValue(
90 bool include_items) const; 95 bool include_items) const;
91 96
92 void EmitTraceSnapshot() const; 97 void EmitTraceSnapshot() const;
93 98
94 void GenerateDiscardableImagesMetadata(); 99 void GenerateDiscardableImagesMetadata();
95 void GetDiscardableImagesInRect(const gfx::Rect& rect, 100 void GetDiscardableImagesInRect(const gfx::Rect& rect,
96 float raster_scale, 101 float raster_scale,
97 std::vector<DrawImage>* images); 102 std::vector<DrawImage>* images);
98 103
99 gfx::Rect VisualRectForTesting(int index) { return visual_rects_[index]; } 104 gfx::Rect VisualRectForTesting(int index) { return visual_rects_[index]; }
100 105
101 private: 106 private:
102 DisplayItemList(gfx::Rect layer_rect, 107 DisplayItemList(gfx::Rect layer_rect,
103 const DisplayItemListSettings& display_list_settings, 108 const DisplayItemListSettings& display_list_settings,
104 bool retain_individual_display_items); 109 bool retain_individual_display_items);
105 ~DisplayItemList(); 110 ~DisplayItemList();
106 111
107 // While appending new items, if they are not being retained, this can process 112 void ProcessAppendedItem(const DisplayItem* item);
108 // periodically to avoid retaining all the items and processing at the end.
109 void ProcessAppendedItemsOnTheFly();
110 void ProcessAppendedItems();
111 #if DCHECK_IS_ON()
112 bool ProcessAppendedItemsCalled() const { return !needs_process_; }
113 bool needs_process_;
114 #else
115 bool ProcessAppendedItemsCalled() const { return true; }
116 #endif
117 113
118 ContiguousContainer<DisplayItem> items_; 114 ContiguousContainer<DisplayItem> items_;
119 // The visual rects associated with each of the display items in the 115 // The visual rects associated with each of the display items in the
120 // display item list. There is one rect per display item, and the 116 // display item list. There is one rect per display item, and the
121 // position in |visual_rects_| matches the position of the item in 117 // position in |visual_rects_| matches the position of the item in
122 // |items_| . These rects are intentionally kept separate 118 // |items_| . These rects are intentionally kept separate
123 // because they are not needed while walking the |items_| for raster. 119 // because they are not needed while walking the |items_| for raster.
124 std::vector<gfx::Rect> visual_rects_; 120 std::vector<gfx::Rect> visual_rects_;
125 skia::RefPtr<SkPicture> picture_; 121 skia::RefPtr<SkPicture> picture_;
126 122
127 scoped_ptr<SkPictureRecorder> recorder_; 123 scoped_ptr<SkPictureRecorder> recorder_;
128 skia::RefPtr<SkCanvas> canvas_; 124 skia::RefPtr<SkCanvas> canvas_;
129 const DisplayItemListSettings settings_; 125 const DisplayItemListSettings settings_;
130 bool retain_individual_display_items_; 126 bool retain_individual_display_items_;
131 127
132 gfx::Rect layer_rect_; 128 gfx::Rect layer_rect_;
133 bool is_suitable_for_gpu_rasterization_; 129 bool is_suitable_for_gpu_rasterization_;
134 int approximate_op_count_; 130 int approximate_op_count_;
135 131
136 // Memory usage due to the cached SkPicture. 132 // Memory usage due to the cached SkPicture.
137 size_t picture_memory_usage_; 133 size_t picture_memory_usage_;
138 134
139 // Memory usage due to external data held by display items.
140 size_t external_memory_usage_;
141
142 DiscardableImageMap image_map_; 135 DiscardableImageMap image_map_;
143 136
144 friend class base::RefCountedThreadSafe<DisplayItemList>; 137 friend class base::RefCountedThreadSafe<DisplayItemList>;
145 FRIEND_TEST_ALL_PREFIXES(DisplayItemListTest, ApproximateMemoryUsage); 138 FRIEND_TEST_ALL_PREFIXES(DisplayItemListTest, ApproximateMemoryUsage);
146 DISALLOW_COPY_AND_ASSIGN(DisplayItemList); 139 DISALLOW_COPY_AND_ASSIGN(DisplayItemList);
147 }; 140 };
148 141
149 } // namespace cc 142 } // namespace cc
150 143
151 #endif // CC_PLAYBACK_DISPLAY_ITEM_LIST_H_ 144 #endif // CC_PLAYBACK_DISPLAY_ITEM_LIST_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698