Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org> | 2 * Copyright (C) 1998, 1999 Torben Weis <weis@kde.org> |
| 3 * 1999 Lars Knoll <knoll@kde.org> | 3 * 1999 Lars Knoll <knoll@kde.org> |
| 4 * 1999 Antti Koivisto <koivisto@kde.org> | 4 * 1999 Antti Koivisto <koivisto@kde.org> |
| 5 * 2000 Dirk Mueller <mueller@kde.org> | 5 * 2000 Dirk Mueller <mueller@kde.org> |
| 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. | 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. |
| 7 * (C) 2006 Graham Dennis (graham.dennis@gmail.com) | 7 * (C) 2006 Graham Dennis (graham.dennis@gmail.com) |
| 8 * (C) 2006 Alexey Proskuryakov (ap@nypop.com) | 8 * (C) 2006 Alexey Proskuryakov (ap@nypop.com) |
| 9 * Copyright (C) 2009 Google Inc. All rights reserved. | 9 * Copyright (C) 2009 Google Inc. All rights reserved. |
| 10 * | 10 * |
| (...skipping 4377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4388 parent->m_needsUpdateViewportIntersectionInSubtree = true; | 4388 parent->m_needsUpdateViewportIntersectionInSubtree = true; |
| 4389 } | 4389 } |
| 4390 | 4390 |
| 4391 void FrameView::updateViewportIntersectionIfNeeded() { | 4391 void FrameView::updateViewportIntersectionIfNeeded() { |
| 4392 if (!m_needsUpdateViewportIntersection) | 4392 if (!m_needsUpdateViewportIntersection) |
| 4393 return; | 4393 return; |
| 4394 m_needsUpdateViewportIntersection = false; | 4394 m_needsUpdateViewportIntersection = false; |
| 4395 m_viewportIntersectionValid = true; | 4395 m_viewportIntersectionValid = true; |
| 4396 FrameView* parent = parentFrameView(); | 4396 FrameView* parent = parentFrameView(); |
| 4397 if (!parent) { | 4397 if (!parent) { |
| 4398 if (HTMLFrameOwnerElement* element = frame().deprecatedLocalOwner()) { | |
| 4399 if (!element->layoutObject()) | |
| 4400 frame().document()->wouldLoadBecause(WouldLoadDisplayNone); | |
| 4401 } | |
| 4402 frame().document()->wouldLoadBecause(WouldLoadOutOfProcess); | |
|
dcheng
2016/10/08 00:46:22
Should this be in an else?
dgrogan
2016/10/13 01:06:22
It was ok without one because of the check in Docu
| |
| 4398 m_viewportIntersection = frameRect(); | 4403 m_viewportIntersection = frameRect(); |
| 4399 return; | 4404 return; |
| 4400 } | 4405 } |
| 4401 ASSERT(!parent->m_needsUpdateViewportIntersection); | 4406 ASSERT(!parent->m_needsUpdateViewportIntersection); |
| 4402 | 4407 |
| 4408 bool parentLoaded = parent->frame().document()->wouldLoadReason() != Created; | |
|
dcheng
2016/10/08 00:46:22
Maybe add a comment here: it'll help me understand
dgrogan
2016/10/13 01:06:22
Comment added. I think we're saying the same thing
| |
| 4409 if (parentLoaded) { | |
| 4410 if (frameRect().isEmpty()) | |
| 4411 frame().document()->wouldLoadBecause(WouldLoadZeroByZero); | |
| 4412 else if (frameRect().maxY() < 0) | |
| 4413 frame().document()->wouldLoadBecause(WouldLoadAbove); | |
| 4414 else if (frameRect().maxX() < 0) | |
| 4415 frame().document()->wouldLoadBecause(WouldLoadLeft); | |
| 4416 } | |
| 4417 | |
| 4403 // If our parent is hidden, then we are too. | 4418 // If our parent is hidden, then we are too. |
| 4404 if (parent->m_viewportIntersection.isEmpty()) { | 4419 if (parent->m_viewportIntersection.isEmpty()) { |
| 4405 m_viewportIntersection = parent->m_viewportIntersection; | 4420 m_viewportIntersection = parent->m_viewportIntersection; |
| 4406 return; | 4421 return; |
| 4407 } | 4422 } |
| 4408 | 4423 |
| 4409 // Transform our bounds into the root frame's content coordinate space, | 4424 // Transform our bounds into the root frame's content coordinate space, |
| 4410 // making sure we have valid layout data in our parent document. If our | 4425 // making sure we have valid layout data in our parent document. If our |
| 4411 // parent is throttled, we'll use possible stale layout information and | 4426 // parent is throttled, we'll use possible stale layout information and |
| 4412 // rely on the fact that another lifecycle update will be scheduled once | 4427 // rely on the fact that another lifecycle update will be scheduled once |
| 4413 // our parent becomes unthrottled. | 4428 // our parent becomes unthrottled. |
| 4414 ASSERT(parent->lifecycle().state() >= DocumentLifecycle::LayoutClean || | 4429 ASSERT(parent->lifecycle().state() >= DocumentLifecycle::LayoutClean || |
| 4415 parent->shouldThrottleRendering()); | 4430 parent->shouldThrottleRendering()); |
| 4416 m_viewportIntersection = parent->contentsToRootFrame(frameRect()); | 4431 m_viewportIntersection = parent->contentsToRootFrame(frameRect()); |
| 4417 | 4432 |
| 4418 // TODO(skyostil): Expand the viewport to make it less likely to see stale | 4433 // TODO(skyostil): Expand the viewport to make it less likely to see stale |
| 4419 // content while scrolling. | 4434 // content while scrolling. |
| 4420 IntRect viewport = parent->m_viewportIntersection; | 4435 IntRect viewport = parent->m_viewportIntersection; |
| 4421 m_viewportIntersection.intersect(viewport); | 4436 m_viewportIntersection.intersect(viewport); |
| 4437 | |
| 4438 if (parentLoaded && !m_viewportIntersection.isEmpty()) | |
| 4439 frame().document()->wouldLoadBecause(WouldLoadVisible); | |
| 4422 } | 4440 } |
| 4423 | 4441 |
| 4424 void FrameView::updateViewportIntersectionsForSubtree( | 4442 void FrameView::updateViewportIntersectionsForSubtree( |
| 4425 DocumentLifecycle::LifecycleState targetState) { | 4443 DocumentLifecycle::LifecycleState targetState) { |
| 4426 bool hadValidIntersection = m_viewportIntersectionValid; | 4444 bool hadValidIntersection = m_viewportIntersectionValid; |
| 4427 bool hadEmptyIntersection = m_viewportIntersection.isEmpty(); | 4445 bool hadEmptyIntersection = m_viewportIntersection.isEmpty(); |
| 4428 updateViewportIntersectionIfNeeded(); | 4446 updateViewportIntersectionIfNeeded(); |
| 4429 | 4447 |
| 4430 // Notify javascript IntersectionObservers | 4448 // Notify javascript IntersectionObservers |
| 4431 if (targetState == DocumentLifecycle::PaintClean && | 4449 if (targetState == DocumentLifecycle::PaintClean && |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4497 | 4515 |
| 4498 void FrameView::notifyRenderThrottlingObservers() { | 4516 void FrameView::notifyRenderThrottlingObservers() { |
| 4499 TRACE_EVENT0("blink", "FrameView::notifyRenderThrottlingObservers"); | 4517 TRACE_EVENT0("blink", "FrameView::notifyRenderThrottlingObservers"); |
| 4500 DCHECK(!isInPerformLayout()); | 4518 DCHECK(!isInPerformLayout()); |
| 4501 DCHECK(frame().document()); | 4519 DCHECK(frame().document()); |
| 4502 DCHECK(!frame().document()->inStyleRecalc()); | 4520 DCHECK(!frame().document()->inStyleRecalc()); |
| 4503 bool wasThrottled = canThrottleRendering(); | 4521 bool wasThrottled = canThrottleRendering(); |
| 4504 | 4522 |
| 4505 updateThrottlingStatus(); | 4523 updateThrottlingStatus(); |
| 4506 | 4524 |
| 4507 frame().document()->onVisibilityMaybeChanged(!m_hiddenForThrottling); | |
| 4508 | |
| 4509 bool becameThrottled = !wasThrottled && canThrottleRendering(); | 4525 bool becameThrottled = !wasThrottled && canThrottleRendering(); |
| 4510 bool becameUnthrottled = wasThrottled && !canThrottleRendering(); | 4526 bool becameUnthrottled = wasThrottled && !canThrottleRendering(); |
| 4511 ScrollingCoordinator* scrollingCoordinator = this->scrollingCoordinator(); | 4527 ScrollingCoordinator* scrollingCoordinator = this->scrollingCoordinator(); |
| 4512 if (becameThrottled) { | 4528 if (becameThrottled) { |
| 4513 // If this FrameView became throttled, we must make sure all of its | 4529 // If this FrameView became throttled, we must make sure all of its |
| 4514 // children become throttled at the same time. Otherwise we might | 4530 // children become throttled at the same time. Otherwise we might |
| 4515 // attempt to paint one of the children with an out-of-date layout | 4531 // attempt to paint one of the children with an out-of-date layout |
| 4516 // before |notifyRenderThrottlingObservers| has made it throttled. | 4532 // before |notifyRenderThrottlingObservers| has made it throttled. |
| 4517 forAllNonThrottledFrameViews([](FrameView& frameView) { | 4533 forAllNonThrottledFrameViews([](FrameView& frameView) { |
| 4518 frameView.m_subtreeThrottled = true; | 4534 frameView.m_subtreeThrottled = true; |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4557 } | 4573 } |
| 4558 | 4574 |
| 4559 bool FrameView::canThrottleRendering() const { | 4575 bool FrameView::canThrottleRendering() const { |
| 4560 if (!RuntimeEnabledFeatures::renderingPipelineThrottlingEnabled()) | 4576 if (!RuntimeEnabledFeatures::renderingPipelineThrottlingEnabled()) |
| 4561 return false; | 4577 return false; |
| 4562 return m_subtreeThrottled || | 4578 return m_subtreeThrottled || |
| 4563 (m_hiddenForThrottling && m_crossOriginForThrottling); | 4579 (m_hiddenForThrottling && m_crossOriginForThrottling); |
| 4564 } | 4580 } |
| 4565 | 4581 |
| 4566 } // namespace blink | 4582 } // namespace blink |
| OLD | NEW |