Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009, 2010, 2011 Apple Inc. All rights reserved. | 2 * Copyright (C) 2009, 2010, 2011 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 1505 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1516 // causes unclipped render surfaces which cause bugs. | 1516 // causes unclipped render surfaces which cause bugs. |
| 1517 // http://crbug.com/521768 | 1517 // http://crbug.com/521768 |
| 1518 if (hasScrollingLayer()) { | 1518 if (hasScrollingLayer()) { |
| 1519 m_graphicsLayer->setShouldFlattenTransform(false); | 1519 m_graphicsLayer->setShouldFlattenTransform(false); |
| 1520 m_scrollingLayer->setShouldFlattenTransform(false); | 1520 m_scrollingLayer->setShouldFlattenTransform(false); |
| 1521 } | 1521 } |
| 1522 } | 1522 } |
| 1523 | 1523 |
| 1524 void CompositedLayerMapping::updateElementIdAndCompositorMutableProperties() | 1524 void CompositedLayerMapping::updateElementIdAndCompositorMutableProperties() |
| 1525 { | 1525 { |
| 1526 if (!RuntimeEnabledFeatures::compositorWorkerEnabled()) | |
| 1527 return; | |
| 1528 | |
| 1529 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), "CompositedLaye rMapping::updateElementId()"); | |
| 1530 | |
| 1531 uint64_t elementId = 0; | 1526 uint64_t elementId = 0; |
| 1532 uint32_t mainMutableProperties = CompositorMutableProperty::kNone; | 1527 uint32_t primaryMutableProperties = CompositorMutableProperty::kNone; |
| 1533 uint32_t scrollMutableProperties = CompositorMutableProperty::kNone; | 1528 uint32_t scrollMutableProperties = CompositorMutableProperty::kNone; |
| 1534 | 1529 |
| 1535 if (m_owningLayer.layoutObject()->style()->hasCompositorProxy()) { | 1530 Node* owningNode = m_owningLayer.layoutObject()->generatingNode(); |
| 1536 if (Node* owningNode = m_owningLayer.layoutObject()->generatingNode()) { | 1531 Element* owningElement = nullptr; |
| 1537 if (owningNode->isElementNode()) { | 1532 if (owningNode && owningNode->isElementNode()) |
| 1538 Element* owningElement = toElement(owningNode); | 1533 owningElement = toElement(owningNode); |
| 1539 uint32_t compositorMutableProperties = owningElement->compositor MutableProperties(); | 1534 |
| 1540 elementId = DOMNodeIds::idForNode(owningNode); | 1535 if (RuntimeEnabledFeatures::compositorWorkerEnabled() && owningElement && m_ owningLayer.layoutObject()->style()->hasCompositorProxy()) { |
| 1541 mainMutableProperties = (CompositorMutableProperty::kOpacity | C ompositorMutableProperty::kTransform) & compositorMutableProperties; | 1536 uint32_t compositorMutableProperties = owningElement->compositorMutableP roperties(); |
| 1542 scrollMutableProperties = (CompositorMutableProperty::kScrollLef t | CompositorMutableProperty::kScrollTop) & compositorMutableProperties; | 1537 elementId = DOMNodeIds::idForNode(owningNode); |
| 1543 } | 1538 primaryMutableProperties = (CompositorMutableProperty::kOpacity | Compos itorMutableProperty::kTransform) & compositorMutableProperties; |
| 1544 } | 1539 scrollMutableProperties = (CompositorMutableProperty::kScrollLeft | Comp ositorMutableProperty::kScrollTop) & compositorMutableProperties; |
| 1545 } | 1540 } |
| 1546 | 1541 |
| 1547 m_graphicsLayer->setElementId(elementId); | 1542 if (m_owningLayer.layoutObject()->style()->shouldCompositeForCurrentAnimatio ns() && owningNode) |
| 1548 m_graphicsLayer->setCompositorMutableProperties(mainMutableProperties); | 1543 elementId = DOMNodeIds::idForNode(owningNode); |
| 1549 | 1544 |
| 1550 if (m_scrollingContentsLayer.get()) { | 1545 m_graphicsLayer->setElementId(createCompositorElementId(elementId, Composito rSubElementId::Primary)); |
|
ajuma
2016/06/07 13:44:01
This is implicitly relying on Primary having value
Ian Vollick
2016/06/07 14:30:08
This is perhaps too subtle, but operator bool for
| |
| 1551 m_scrollingContentsLayer->setElementId(elementId); | 1546 m_graphicsLayer->setCompositorMutableProperties(primaryMutableProperties); |
| 1547 | |
| 1548 // We always set the elementId for m_scrollingContentsLayer since it can be | |
| 1549 // animated for smooth scrolling. | |
| 1550 if (m_scrollingContentsLayer.get()) | |
| 1552 m_scrollingContentsLayer->setCompositorMutableProperties(scrollMutablePr operties); | 1551 m_scrollingContentsLayer->setCompositorMutableProperties(scrollMutablePr operties); |
|
ajuma
2016/06/07 13:44:01
How does this relate to the logic added to ::updat
Ian Vollick
2016/06/07 14:30:08
Good question.
* element id: if you have a compo
| |
| 1553 } | |
| 1554 } | 1552 } |
| 1555 | 1553 |
| 1556 bool CompositedLayerMapping::updateForegroundLayer(bool needsForegroundLayer) | 1554 bool CompositedLayerMapping::updateForegroundLayer(bool needsForegroundLayer) |
| 1557 { | 1555 { |
| 1558 bool layerChanged = false; | 1556 bool layerChanged = false; |
| 1559 if (needsForegroundLayer) { | 1557 if (needsForegroundLayer) { |
| 1560 if (!m_foregroundLayer) { | 1558 if (!m_foregroundLayer) { |
| 1561 m_foregroundLayer = createGraphicsLayer(CompositingReasonLayerForFor eground); | 1559 m_foregroundLayer = createGraphicsLayer(CompositingReasonLayerForFor eground); |
| 1562 layerChanged = true; | 1560 layerChanged = true; |
| 1563 } | 1561 } |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1630 bool layerChanged = false; | 1628 bool layerChanged = false; |
| 1631 if (needsScrollingLayers) { | 1629 if (needsScrollingLayers) { |
| 1632 if (!m_scrollingLayer) { | 1630 if (!m_scrollingLayer) { |
| 1633 // Outer layer which corresponds with the scroll view. | 1631 // Outer layer which corresponds with the scroll view. |
| 1634 m_scrollingLayer = createGraphicsLayer(CompositingReasonLayerForScro llingContainer); | 1632 m_scrollingLayer = createGraphicsLayer(CompositingReasonLayerForScro llingContainer); |
| 1635 m_scrollingLayer->setDrawsContent(false); | 1633 m_scrollingLayer->setDrawsContent(false); |
| 1636 m_scrollingLayer->setMasksToBounds(true); | 1634 m_scrollingLayer->setMasksToBounds(true); |
| 1637 | 1635 |
| 1638 // Inner layer which renders the content that scrolls. | 1636 // Inner layer which renders the content that scrolls. |
| 1639 m_scrollingContentsLayer = createGraphicsLayer(CompositingReasonLaye rForScrollingContents); | 1637 m_scrollingContentsLayer = createGraphicsLayer(CompositingReasonLaye rForScrollingContents); |
| 1638 | |
| 1639 if (Node* owningNode = m_owningLayer.layoutObject()->generatingNode( )) { | |
| 1640 m_scrollingContentsLayer->setElementId(createCompositorElementId (DOMNodeIds::idForNode(owningNode), CompositorSubElementId::Scroll)); | |
| 1641 m_scrollingContentsLayer->setCompositorMutableProperties(Composi torMutableProperty::kScrollLeft | CompositorMutableProperty::kScrollTop); | |
| 1642 } | |
| 1643 | |
| 1640 m_scrollingLayer->addChild(m_scrollingContentsLayer.get()); | 1644 m_scrollingLayer->addChild(m_scrollingContentsLayer.get()); |
| 1641 | 1645 |
| 1642 layerChanged = true; | 1646 layerChanged = true; |
| 1643 if (scrollingCoordinator) { | 1647 if (scrollingCoordinator) { |
| 1644 scrollingCoordinator->scrollableAreaScrollLayerDidChange(m_ownin gLayer.getScrollableArea()); | 1648 scrollingCoordinator->scrollableAreaScrollLayerDidChange(m_ownin gLayer.getScrollableArea()); |
| 1645 scrollingCoordinator->scrollableAreasDidChange(); | 1649 scrollingCoordinator->scrollableAreasDidChange(); |
| 1646 } | 1650 } |
| 1647 } | 1651 } |
| 1648 } else if (m_scrollingLayer) { | 1652 } else if (m_scrollingLayer) { |
| 1649 m_scrollingLayer = nullptr; | 1653 m_scrollingLayer = nullptr; |
| (...skipping 1004 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2654 } else if (graphicsLayer == m_scrollingContentsLayer.get()) { | 2658 } else if (graphicsLayer == m_scrollingContentsLayer.get()) { |
| 2655 name = "Scrolling Contents Layer"; | 2659 name = "Scrolling Contents Layer"; |
| 2656 } else { | 2660 } else { |
| 2657 ASSERT_NOT_REACHED(); | 2661 ASSERT_NOT_REACHED(); |
| 2658 } | 2662 } |
| 2659 | 2663 |
| 2660 return name; | 2664 return name; |
| 2661 } | 2665 } |
| 2662 | 2666 |
| 2663 } // namespace blink | 2667 } // namespace blink |
| OLD | NEW |