OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2009, 2010 Apple Inc. All rights reserved. | 2 * Copyright (C) 2009, 2010 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 273 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
284 m_overflowControlsHostLayer->addChild(videoLayer); | 284 m_overflowControlsHostLayer->addChild(videoLayer); |
285 if (GraphicsLayer* backgroundLayer = fixedRootBackgroundLayer()) | 285 if (GraphicsLayer* backgroundLayer = fixedRootBackgroundLayer()) |
286 backgroundLayer->removeFromParent(); | 286 backgroundLayer->removeFromParent(); |
287 } | 287 } |
288 | 288 |
289 void RenderLayerCompositor::updateIfNeeded() | 289 void RenderLayerCompositor::updateIfNeeded() |
290 { | 290 { |
291 CompositingUpdateType updateType = m_pendingUpdateType; | 291 CompositingUpdateType updateType = m_pendingUpdateType; |
292 m_pendingUpdateType = CompositingUpdateNone; | 292 m_pendingUpdateType = CompositingUpdateNone; |
293 | 293 |
294 if (!hasAcceleratedCompositing()) | 294 if (!hasAcceleratedCompositing() || updateType == CompositingUpdateNone) |
295 return; | |
296 | |
297 bool needsToUpdateScrollingCoordinator = scrollingCoordinator() && scrolling
Coordinator()->needsToUpdateAfterCompositingChange(); | |
298 if (updateType == CompositingUpdateNone && !needsToUpdateScrollingCoordinato
r) | |
299 return; | 295 return; |
300 | 296 |
301 RenderLayer* updateRoot = rootRenderLayer(); | 297 RenderLayer* updateRoot = rootRenderLayer(); |
302 | 298 |
303 Vector<RenderLayer*> layersNeedingRepaint; | 299 Vector<RenderLayer*> layersNeedingRepaint; |
304 | 300 |
305 if (updateType >= CompositingUpdateAfterCompositingInputChange) { | 301 if (updateType >= CompositingUpdateAfterCompositingInputChange) { |
306 bool layersChanged = false; | 302 bool layersChanged = false; |
307 { | 303 { |
308 TRACE_EVENT0("blink_rendering", "CompositingInputsUpdater::update"); | 304 TRACE_EVENT0("blink_rendering", "CompositingInputsUpdater::update"); |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
359 | 355 |
360 if (RuntimeEnabledFeatures::overlayFullscreenVideoEnabled()) | 356 if (RuntimeEnabledFeatures::overlayFullscreenVideoEnabled()) |
361 applyOverlayFullscreenVideoAdjustment(); | 357 applyOverlayFullscreenVideoAdjustment(); |
362 } | 358 } |
363 | 359 |
364 if (m_needsUpdateFixedBackground) { | 360 if (m_needsUpdateFixedBackground) { |
365 rootFixedBackgroundsChanged(); | 361 rootFixedBackgroundsChanged(); |
366 m_needsUpdateFixedBackground = false; | 362 m_needsUpdateFixedBackground = false; |
367 } | 363 } |
368 | 364 |
369 // The scrolling coordinator may realize that it needs updating while compos
iting was being updated in this function. | |
370 needsToUpdateScrollingCoordinator |= scrollingCoordinator() && scrollingCoor
dinator()->needsToUpdateAfterCompositingChange(); | |
371 if (needsToUpdateScrollingCoordinator && m_renderView.frame()->isMainFrame()
&& scrollingCoordinator() && inCompositingMode()) | |
372 scrollingCoordinator()->updateAfterCompositingChange(); | |
373 | |
374 for (unsigned i = 0; i < layersNeedingRepaint.size(); i++) { | 365 for (unsigned i = 0; i < layersNeedingRepaint.size(); i++) { |
375 RenderLayer* layer = layersNeedingRepaint[i]; | 366 RenderLayer* layer = layersNeedingRepaint[i]; |
376 layer->repainter().computeRepaintRectsIncludingNonCompositingDescendants
(); | 367 layer->repainter().computeRepaintRectsIncludingNonCompositingDescendants
(); |
377 | 368 |
378 repaintOnCompositingChange(layer); | 369 repaintOnCompositingChange(layer); |
379 } | 370 } |
380 | 371 |
381 // Inform the inspector that the layer tree has changed. | 372 // Inform the inspector that the layer tree has changed. |
382 if (m_renderView.frame()->isMainFrame()) | 373 if (m_renderView.frame()->isMainFrame()) |
383 InspectorInstrumentation::layerTreeDidChange(m_renderView.frame()); | 374 InspectorInstrumentation::layerTreeDidChange(m_renderView.frame()); |
(...skipping 855 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1239 } else if (graphicsLayer == m_scrollLayer.get()) { | 1230 } else if (graphicsLayer == m_scrollLayer.get()) { |
1240 name = "LocalFrame Scrolling Layer"; | 1231 name = "LocalFrame Scrolling Layer"; |
1241 } else { | 1232 } else { |
1242 ASSERT_NOT_REACHED(); | 1233 ASSERT_NOT_REACHED(); |
1243 } | 1234 } |
1244 | 1235 |
1245 return name; | 1236 return name; |
1246 } | 1237 } |
1247 | 1238 |
1248 } // namespace WebCore | 1239 } // namespace WebCore |
OLD | NEW |