| 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 #include "cc/blink/web_display_item_list_impl.h" | 5 #include "cc/blink/web_display_item_list_impl.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "cc/blink/web_filter_operations_impl.h" | 9 #include "cc/blink/web_filter_operations_impl.h" |
| 10 #include "cc/playback/clip_display_item.h" | 10 #include "cc/playback/clip_display_item.h" |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 | 43 |
| 44 WebDisplayItemListImpl::WebDisplayItemListImpl( | 44 WebDisplayItemListImpl::WebDisplayItemListImpl( |
| 45 cc::DisplayItemList* display_list) | 45 cc::DisplayItemList* display_list) |
| 46 : display_item_list_(display_list) { | 46 : display_item_list_(display_list) { |
| 47 } | 47 } |
| 48 | 48 |
| 49 void WebDisplayItemListImpl::appendDrawingItem( | 49 void WebDisplayItemListImpl::appendDrawingItem( |
| 50 const blink::WebRect& visual_rect, | 50 const blink::WebRect& visual_rect, |
| 51 const SkPicture* picture) { | 51 const SkPicture* picture) { |
| 52 if (display_item_list_->RetainsIndividualDisplayItems()) { | 52 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 53 display_item_list_->CreateAndAppendItem<cc::DrawingDisplayItem>( | 53 auto* item = |
| 54 visual_rect, skia::SharePtr(const_cast<SkPicture*>(picture))); | 54 display_item_list_->CreateAndAppendItem<cc::DrawingDisplayItem>( |
| 55 visual_rect); |
| 56 item->SetNew(skia::SharePtr(const_cast<SkPicture*>(picture))); |
| 55 } else { | 57 } else { |
| 56 cc::DrawingDisplayItem item( | 58 cc::DrawingDisplayItem item; |
| 57 skia::SharePtr(const_cast<SkPicture*>(picture))); | 59 item.SetNew(skia::SharePtr(const_cast<SkPicture*>(picture))); |
| 58 display_item_list_->RasterIntoCanvas(item); | 60 display_item_list_->RasterIntoCanvas(item); |
| 59 } | 61 } |
| 60 } | 62 } |
| 61 | 63 |
| 62 void WebDisplayItemListImpl::appendClipItem( | 64 void WebDisplayItemListImpl::appendClipItem( |
| 63 const blink::WebRect& visual_rect, | 65 const blink::WebRect& visual_rect, |
| 64 const blink::WebRect& clip_rect, | 66 const blink::WebRect& clip_rect, |
| 65 const blink::WebVector<SkRRect>& rounded_clip_rects) { | 67 const blink::WebVector<SkRRect>& rounded_clip_rects) { |
| 66 std::vector<SkRRect> rounded_rects; | 68 std::vector<SkRRect> rounded_rects; |
| 67 for (size_t i = 0; i < rounded_clip_rects.size(); ++i) { | 69 for (size_t i = 0; i < rounded_clip_rects.size(); ++i) { |
| 68 rounded_rects.push_back(rounded_clip_rects[i]); | 70 rounded_rects.push_back(rounded_clip_rects[i]); |
| 69 } | 71 } |
| 70 if (display_item_list_->RetainsIndividualDisplayItems()) { | 72 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 71 display_item_list_->CreateAndAppendItem<cc::ClipDisplayItem>( | 73 auto* item = display_item_list_->CreateAndAppendItem<cc::ClipDisplayItem>( |
| 72 visual_rect, clip_rect, rounded_rects); | 74 visual_rect); |
| 75 item->SetNew(clip_rect, rounded_rects); |
| 73 } else { | 76 } else { |
| 74 cc::ClipDisplayItem item(clip_rect, rounded_rects); | 77 cc::ClipDisplayItem item; |
| 78 item.SetNew(clip_rect, rounded_rects); |
| 75 display_item_list_->RasterIntoCanvas(item); | 79 display_item_list_->RasterIntoCanvas(item); |
| 76 } | 80 } |
| 77 } | 81 } |
| 78 | 82 |
| 79 void WebDisplayItemListImpl::appendEndClipItem( | 83 void WebDisplayItemListImpl::appendEndClipItem( |
| 80 const blink::WebRect& visual_rect) { | 84 const blink::WebRect& visual_rect) { |
| 81 if (display_item_list_->RetainsIndividualDisplayItems()) { | 85 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 82 display_item_list_->CreateAndAppendItem<cc::EndClipDisplayItem>( | 86 display_item_list_->CreateAndAppendItem<cc::EndClipDisplayItem>( |
| 83 visual_rect); | 87 visual_rect); |
| 84 } else { | 88 } else { |
| 85 display_item_list_->RasterIntoCanvas(cc::EndClipDisplayItem()); | 89 display_item_list_->RasterIntoCanvas(cc::EndClipDisplayItem()); |
| 86 } | 90 } |
| 87 } | 91 } |
| 88 | 92 |
| 89 void WebDisplayItemListImpl::appendClipPathItem( | 93 void WebDisplayItemListImpl::appendClipPathItem( |
| 90 const blink::WebRect& visual_rect, | 94 const blink::WebRect& visual_rect, |
| 91 const SkPath& clip_path, | 95 const SkPath& clip_path, |
| 92 SkRegion::Op clip_op, | 96 SkRegion::Op clip_op, |
| 93 bool antialias) { | 97 bool antialias) { |
| 94 if (display_item_list_->RetainsIndividualDisplayItems()) { | 98 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 95 display_item_list_->CreateAndAppendItem<cc::ClipPathDisplayItem>( | 99 auto* item = |
| 96 visual_rect, clip_path, clip_op, antialias); | 100 display_item_list_->CreateAndAppendItem<cc::ClipPathDisplayItem>( |
| 101 visual_rect); |
| 102 item->SetNew(clip_path, clip_op, antialias); |
| 97 } else { | 103 } else { |
| 98 cc::ClipPathDisplayItem item(clip_path, clip_op, antialias); | 104 cc::ClipPathDisplayItem item; |
| 105 item.SetNew(clip_path, clip_op, antialias); |
| 99 display_item_list_->RasterIntoCanvas(item); | 106 display_item_list_->RasterIntoCanvas(item); |
| 100 } | 107 } |
| 101 } | 108 } |
| 102 | 109 |
| 103 void WebDisplayItemListImpl::appendEndClipPathItem( | 110 void WebDisplayItemListImpl::appendEndClipPathItem( |
| 104 const blink::WebRect& visual_rect) { | 111 const blink::WebRect& visual_rect) { |
| 105 if (display_item_list_->RetainsIndividualDisplayItems()) { | 112 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 106 display_item_list_->CreateAndAppendItem<cc::EndClipPathDisplayItem>( | 113 display_item_list_->CreateAndAppendItem<cc::EndClipPathDisplayItem>( |
| 107 visual_rect); | 114 visual_rect); |
| 108 } else { | 115 } else { |
| 109 display_item_list_->RasterIntoCanvas(cc::EndClipPathDisplayItem()); | 116 display_item_list_->RasterIntoCanvas(cc::EndClipPathDisplayItem()); |
| 110 } | 117 } |
| 111 } | 118 } |
| 112 | 119 |
| 113 void WebDisplayItemListImpl::appendFloatClipItem( | 120 void WebDisplayItemListImpl::appendFloatClipItem( |
| 114 const blink::WebRect& visual_rect, | 121 const blink::WebRect& visual_rect, |
| 115 const blink::WebFloatRect& clip_rect) { | 122 const blink::WebFloatRect& clip_rect) { |
| 116 if (display_item_list_->RetainsIndividualDisplayItems()) { | 123 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 117 display_item_list_->CreateAndAppendItem<cc::FloatClipDisplayItem>( | 124 auto* item = |
| 118 visual_rect, clip_rect); | 125 display_item_list_->CreateAndAppendItem<cc::FloatClipDisplayItem>( |
| 126 visual_rect); |
| 127 item->SetNew(clip_rect); |
| 119 } else { | 128 } else { |
| 120 cc::FloatClipDisplayItem item(clip_rect); | 129 cc::FloatClipDisplayItem item; |
| 130 item.SetNew(clip_rect); |
| 121 display_item_list_->RasterIntoCanvas(item); | 131 display_item_list_->RasterIntoCanvas(item); |
| 122 } | 132 } |
| 123 } | 133 } |
| 124 | 134 |
| 125 void WebDisplayItemListImpl::appendEndFloatClipItem( | 135 void WebDisplayItemListImpl::appendEndFloatClipItem( |
| 126 const blink::WebRect& visual_rect) { | 136 const blink::WebRect& visual_rect) { |
| 127 if (display_item_list_->RetainsIndividualDisplayItems()) { | 137 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 128 display_item_list_->CreateAndAppendItem<cc::EndFloatClipDisplayItem>( | 138 display_item_list_->CreateAndAppendItem<cc::EndFloatClipDisplayItem>( |
| 129 visual_rect); | 139 visual_rect); |
| 130 } else { | 140 } else { |
| 131 display_item_list_->RasterIntoCanvas(cc::EndFloatClipDisplayItem()); | 141 display_item_list_->RasterIntoCanvas(cc::EndFloatClipDisplayItem()); |
| 132 } | 142 } |
| 133 } | 143 } |
| 134 | 144 |
| 135 void WebDisplayItemListImpl::appendTransformItem( | 145 void WebDisplayItemListImpl::appendTransformItem( |
| 136 const blink::WebRect& visual_rect, | 146 const blink::WebRect& visual_rect, |
| 137 const SkMatrix44& matrix) { | 147 const SkMatrix44& matrix) { |
| 138 gfx::Transform transform(gfx::Transform::kSkipInitialization); | 148 gfx::Transform transform(gfx::Transform::kSkipInitialization); |
| 139 transform.matrix() = matrix; | 149 transform.matrix() = matrix; |
| 140 | 150 |
| 141 if (display_item_list_->RetainsIndividualDisplayItems()) { | 151 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 142 display_item_list_->CreateAndAppendItem<cc::TransformDisplayItem>( | 152 auto* item = |
| 143 visual_rect, transform); | 153 display_item_list_->CreateAndAppendItem<cc::TransformDisplayItem>( |
| 154 visual_rect); |
| 155 item->SetNew(transform); |
| 144 } else { | 156 } else { |
| 145 cc::TransformDisplayItem item(transform); | 157 cc::TransformDisplayItem item; |
| 158 item.SetNew(transform); |
| 146 display_item_list_->RasterIntoCanvas(item); | 159 display_item_list_->RasterIntoCanvas(item); |
| 147 } | 160 } |
| 148 } | 161 } |
| 149 | 162 |
| 150 void WebDisplayItemListImpl::appendEndTransformItem( | 163 void WebDisplayItemListImpl::appendEndTransformItem( |
| 151 const blink::WebRect& visual_rect) { | 164 const blink::WebRect& visual_rect) { |
| 152 if (display_item_list_->RetainsIndividualDisplayItems()) { | 165 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 153 display_item_list_->CreateAndAppendItem<cc::EndTransformDisplayItem>( | 166 display_item_list_->CreateAndAppendItem<cc::EndTransformDisplayItem>( |
| 154 visual_rect); | 167 visual_rect); |
| 155 } else { | 168 } else { |
| 156 display_item_list_->RasterIntoCanvas(cc::EndTransformDisplayItem()); | 169 display_item_list_->RasterIntoCanvas(cc::EndTransformDisplayItem()); |
| 157 } | 170 } |
| 158 } | 171 } |
| 159 | 172 |
| 160 void WebDisplayItemListImpl::appendCompositingItem( | 173 void WebDisplayItemListImpl::appendCompositingItem( |
| 161 const blink::WebRect& visual_rect, | 174 const blink::WebRect& visual_rect, |
| 162 float opacity, | 175 float opacity, |
| 163 SkXfermode::Mode xfermode, | 176 SkXfermode::Mode xfermode, |
| 164 SkRect* bounds, | 177 SkRect* bounds, |
| 165 SkColorFilter* color_filter) { | 178 SkColorFilter* color_filter) { |
| 166 DCHECK_GE(opacity, 0.f); | 179 DCHECK_GE(opacity, 0.f); |
| 167 DCHECK_LE(opacity, 1.f); | 180 DCHECK_LE(opacity, 1.f); |
| 168 // TODO(ajuma): This should really be rounding instead of flooring the alpha | 181 // TODO(ajuma): This should really be rounding instead of flooring the alpha |
| 169 // value, but that breaks slimming paint reftests. | 182 // value, but that breaks slimming paint reftests. |
| 170 | 183 |
| 171 if (display_item_list_->RetainsIndividualDisplayItems()) { | 184 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 172 display_item_list_->CreateAndAppendItem<cc::CompositingDisplayItem>( | 185 auto* item = |
| 173 visual_rect, static_cast<uint8_t>(gfx::ToFlooredInt(255 * opacity)), | 186 display_item_list_->CreateAndAppendItem<cc::CompositingDisplayItem>( |
| 174 xfermode, bounds, skia::SharePtr(color_filter)); | 187 visual_rect); |
| 188 item->SetNew(static_cast<uint8_t>(gfx::ToFlooredInt(255 * opacity)), |
| 189 xfermode, bounds, skia::SharePtr(color_filter)); |
| 175 } else { | 190 } else { |
| 176 cc::CompositingDisplayItem item( | 191 cc::CompositingDisplayItem item; |
| 177 static_cast<uint8_t>(gfx::ToFlooredInt(255 * opacity)), xfermode, | 192 item.SetNew(static_cast<uint8_t>(gfx::ToFlooredInt(255 * opacity)), |
| 178 bounds, skia::SharePtr(color_filter)); | 193 xfermode, bounds, skia::SharePtr(color_filter)); |
| 179 display_item_list_->RasterIntoCanvas(item); | 194 display_item_list_->RasterIntoCanvas(item); |
| 180 } | 195 } |
| 181 } | 196 } |
| 182 | 197 |
| 183 void WebDisplayItemListImpl::appendEndCompositingItem( | 198 void WebDisplayItemListImpl::appendEndCompositingItem( |
| 184 const blink::WebRect& visual_rect) { | 199 const blink::WebRect& visual_rect) { |
| 185 if (display_item_list_->RetainsIndividualDisplayItems()) { | 200 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 186 display_item_list_->CreateAndAppendItem<cc::EndCompositingDisplayItem>( | 201 display_item_list_->CreateAndAppendItem<cc::EndCompositingDisplayItem>( |
| 187 visual_rect); | 202 visual_rect); |
| 188 } else { | 203 } else { |
| 189 display_item_list_->RasterIntoCanvas(cc::EndCompositingDisplayItem()); | 204 display_item_list_->RasterIntoCanvas(cc::EndCompositingDisplayItem()); |
| 190 } | 205 } |
| 191 } | 206 } |
| 192 | 207 |
| 193 void WebDisplayItemListImpl::appendFilterItem( | 208 void WebDisplayItemListImpl::appendFilterItem( |
| 194 const blink::WebRect& visual_rect, | 209 const blink::WebRect& visual_rect, |
| 195 const blink::WebFilterOperations& filters, | 210 const blink::WebFilterOperations& filters, |
| 196 const blink::WebFloatRect& bounds) { | 211 const blink::WebFloatRect& bounds) { |
| 197 const WebFilterOperationsImpl& filters_impl = | 212 const WebFilterOperationsImpl& filters_impl = |
| 198 static_cast<const WebFilterOperationsImpl&>(filters); | 213 static_cast<const WebFilterOperationsImpl&>(filters); |
| 199 | 214 |
| 200 if (display_item_list_->RetainsIndividualDisplayItems()) { | 215 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 201 display_item_list_->CreateAndAppendItem<cc::FilterDisplayItem>( | 216 auto* item = display_item_list_->CreateAndAppendItem<cc::FilterDisplayItem>( |
| 202 visual_rect, filters_impl.AsFilterOperations(), bounds); | 217 visual_rect); |
| 218 item->SetNew(filters_impl.AsFilterOperations(), bounds); |
| 203 } else { | 219 } else { |
| 204 cc::FilterDisplayItem item(filters_impl.AsFilterOperations(), bounds); | 220 cc::FilterDisplayItem item; |
| 221 item.SetNew(filters_impl.AsFilterOperations(), bounds); |
| 205 display_item_list_->RasterIntoCanvas(item); | 222 display_item_list_->RasterIntoCanvas(item); |
| 206 } | 223 } |
| 207 } | 224 } |
| 208 | 225 |
| 209 void WebDisplayItemListImpl::appendEndFilterItem( | 226 void WebDisplayItemListImpl::appendEndFilterItem( |
| 210 const blink::WebRect& visual_rect) { | 227 const blink::WebRect& visual_rect) { |
| 211 if (display_item_list_->RetainsIndividualDisplayItems()) { | 228 if (display_item_list_->RetainsIndividualDisplayItems()) { |
| 212 display_item_list_->CreateAndAppendItem<cc::EndFilterDisplayItem>( | 229 display_item_list_->CreateAndAppendItem<cc::EndFilterDisplayItem>( |
| 213 visual_rect); | 230 visual_rect); |
| 214 } else { | 231 } else { |
| (...skipping 13 matching lines...) Expand all Loading... |
| 228 | 245 |
| 229 void WebDisplayItemListImpl::appendEndScrollItem( | 246 void WebDisplayItemListImpl::appendEndScrollItem( |
| 230 const blink::WebRect& visual_rect) { | 247 const blink::WebRect& visual_rect) { |
| 231 appendEndTransformItem(visual_rect); | 248 appendEndTransformItem(visual_rect); |
| 232 } | 249 } |
| 233 | 250 |
| 234 WebDisplayItemListImpl::~WebDisplayItemListImpl() { | 251 WebDisplayItemListImpl::~WebDisplayItemListImpl() { |
| 235 } | 252 } |
| 236 | 253 |
| 237 } // namespace cc_blink | 254 } // namespace cc_blink |
| OLD | NEW |