OLD | NEW |
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 Loading... |
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 // TODO(crbug.com/513016): None of the items might individually trigger a |
| 76 // veto even though they collectively have enough "bad" operations that a |
| 77 // corresponding flattened Picture would get vetoed. |
| 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_ |
OLD | NEW |