summaryrefslogtreecommitdiff
path: root/Source/WebCore/rendering/RenderMedia.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebCore/rendering/RenderMedia.cpp')
-rw-r--r--Source/WebCore/rendering/RenderMedia.cpp60
1 files changed, 19 insertions, 41 deletions
diff --git a/Source/WebCore/rendering/RenderMedia.cpp b/Source/WebCore/rendering/RenderMedia.cpp
index 438ab650f..926390921 100644
--- a/Source/WebCore/rendering/RenderMedia.cpp
+++ b/Source/WebCore/rendering/RenderMedia.cpp
@@ -10,10 +10,10 @@
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
- * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
@@ -34,62 +34,40 @@
namespace WebCore {
-RenderMedia::RenderMedia(HTMLMediaElement& element, PassRef<RenderStyle> style)
- : RenderImage(element, std::move(style))
+RenderMedia::RenderMedia(HTMLMediaElement& element, RenderStyle&& style)
+ : RenderImage(element, WTFMove(style))
{
+ setHasShadowControls(true);
}
-RenderMedia::RenderMedia(HTMLMediaElement& element, PassRef<RenderStyle> style, const IntSize& intrinsicSize)
- : RenderImage(element, std::move(style))
+RenderMedia::RenderMedia(HTMLMediaElement& element, RenderStyle&& style, const IntSize& intrinsicSize)
+ : RenderImage(element, WTFMove(style))
{
setIntrinsicSize(intrinsicSize);
+ setHasShadowControls(true);
}
RenderMedia::~RenderMedia()
{
}
-void RenderMedia::layout()
+void RenderMedia::paintReplaced(PaintInfo&, const LayoutPoint&)
{
- StackStats::LayoutCheckPoint layoutCheckPoint;
- LayoutSize oldSize = contentBoxRect().size();
+}
+void RenderMedia::layout()
+{
+ LayoutSize oldSize = size();
RenderImage::layout();
-
- RenderBox* controlsRenderer = toRenderBox(firstChild());
- if (!controlsRenderer)
- return;
-
- bool controlsNeedLayout = controlsRenderer->needsLayout();
- // If the region chain has changed we also need to relayout the controls to update the region box info.
- // FIXME: We can do better once we compute region box info for RenderReplaced, not only for RenderBlock.
- const RenderFlowThread* flowThread = flowThreadContainingBlock();
- if (flowThread && !controlsNeedLayout) {
- if (flowThread->pageLogicalSizeChanged())
- controlsNeedLayout = true;
- }
-
- LayoutSize newSize = contentBoxRect().size();
- if (newSize == oldSize && !controlsNeedLayout)
- return;
-
- // When calling layout() on a child node, a parent must either push a LayoutStateMaintainter, or
- // instantiate LayoutStateDisabler. Since using a LayoutStateMaintainer is slightly more efficient,
- // and this method will be called many times per second during playback, use a LayoutStateMaintainer:
- LayoutStateMaintainer statePusher(view(), *this, locationOffset(), hasTransform() || hasReflection() || style().isFlippedBlocksWritingMode());
-
- controlsRenderer->setLocation(LayoutPoint(borderLeft(), borderTop()) + LayoutSize(paddingLeft(), paddingTop()));
- controlsRenderer->style().setHeight(Length(newSize.height(), Fixed));
- controlsRenderer->style().setWidth(Length(newSize.width(), Fixed));
- controlsRenderer->setNeedsLayout(MarkOnlyThis);
- controlsRenderer->layout();
- clearChildNeedsLayout();
-
- statePusher.pop();
+ if (oldSize != size())
+ mediaElement().layoutSizeChanged();
}
-void RenderMedia::paintReplaced(PaintInfo&, const LayoutPoint&)
+void RenderMedia::styleDidChange(StyleDifference difference, const RenderStyle* oldStyle)
{
+ RenderImage::styleDidChange(difference, oldStyle);
+ if (!oldStyle || style().visibility() != oldStyle->visibility())
+ mediaElement().visibilityDidChange();
}
} // namespace WebCore