From 5f1ab04193ad0130ca8204aadaceae083aca9881 Mon Sep 17 00:00:00 2001 From: Feng Qian Date: Wed, 17 Jun 2009 12:12:20 -0700 Subject: Get WebKit r44544. --- WebCore/rendering/MediaControlElements.cpp | 41 ++++++++++++++++++++++-------- 1 file changed, 30 insertions(+), 11 deletions(-) (limited to 'WebCore/rendering/MediaControlElements.cpp') diff --git a/WebCore/rendering/MediaControlElements.cpp b/WebCore/rendering/MediaControlElements.cpp index d84e9ad..5cd9363 100644 --- a/WebCore/rendering/MediaControlElements.cpp +++ b/WebCore/rendering/MediaControlElements.cpp @@ -32,9 +32,7 @@ #include "MediaControlElements.h" -#include "Event.h" #include "EventNames.h" -#include "EventHandler.h" #include "FloatConversion.h" #include "Frame.h" #include "HTMLNames.h" @@ -61,7 +59,6 @@ MediaControlShadowRootElement::MediaControlShadowRootElement(Document* doc, HTML rootStyle->setDisplay(BLOCK); rootStyle->setPosition(RelativePosition); RenderMediaControlShadowRoot* renderer = new (mediaElement->renderer()->renderArena()) RenderMediaControlShadowRoot(this); - renderer->setParent(mediaElement->renderer()); renderer->setStyle(rootStyle.release()); setRenderer(renderer); setAttached(); @@ -121,10 +118,11 @@ MediaTimeDisplayElement::MediaTimeDisplayElement(Document* doc, HTMLMediaElement // ---------------------------- -MediaControlInputElement::MediaControlInputElement(Document* doc, PseudoId pseudo, const String& type, HTMLMediaElement* mediaElement) +MediaControlInputElement::MediaControlInputElement(Document* doc, PseudoId pseudo, const String& type, HTMLMediaElement* mediaElement, MediaControlElementType displayType) : HTMLInputElement(inputTag, doc) , m_mediaElement(mediaElement) , m_pseudoStyleId(pseudo) + , m_displayType(displayType) { setInputType(type); RenderStyle* style = m_mediaElement->renderer()->getCachedPseudoStyle(m_pseudoStyleId); @@ -145,6 +143,7 @@ void MediaControlInputElement::attachToParent(Element* parent) void MediaControlInputElement::update() { + updateDisplayType(); if (renderer()) renderer()->updateFromElement(); } @@ -165,10 +164,20 @@ bool MediaControlInputElement::hitTest(const IntPoint& absPoint) return false; } +void MediaControlInputElement::setDisplayType(MediaControlElementType displayType) +{ + if (displayType == m_displayType) + return; + + m_displayType = displayType; + if (RenderObject* o = renderer()) + o->repaint(); +} + // ---------------------------- MediaControlMuteButtonElement::MediaControlMuteButtonElement(Document* doc, HTMLMediaElement* element) - : MediaControlInputElement(doc, MEDIA_CONTROLS_MUTE_BUTTON, "button", element) + : MediaControlInputElement(doc, MEDIA_CONTROLS_MUTE_BUTTON, "button", element, element->muted() ? MediaUnMuteButton : MediaMuteButton) { } @@ -181,10 +190,15 @@ void MediaControlMuteButtonElement::defaultEventHandler(Event* event) HTMLInputElement::defaultEventHandler(event); } +void MediaControlMuteButtonElement::updateDisplayType() +{ + setDisplayType(m_mediaElement->muted() ? MediaUnMuteButton : MediaMuteButton); +} + // ---------------------------- MediaControlPlayButtonElement::MediaControlPlayButtonElement(Document* doc, HTMLMediaElement* element) - : MediaControlInputElement(doc, MEDIA_CONTROLS_PLAY_BUTTON, "button", element) + : MediaControlInputElement(doc, MEDIA_CONTROLS_PLAY_BUTTON, "button", element, element->canPlay() ? MediaPlayButton : MediaPauseButton) { } @@ -197,10 +211,16 @@ void MediaControlPlayButtonElement::defaultEventHandler(Event* event) HTMLInputElement::defaultEventHandler(event); } +void MediaControlPlayButtonElement::updateDisplayType() +{ + setDisplayType(m_mediaElement->canPlay() ? MediaPlayButton : MediaPauseButton); +} + // ---------------------------- MediaControlSeekButtonElement::MediaControlSeekButtonElement(Document* doc, HTMLMediaElement* element, bool forward) - : MediaControlInputElement(doc, forward ? MEDIA_CONTROLS_SEEK_FORWARD_BUTTON : MEDIA_CONTROLS_SEEK_BACK_BUTTON, "button", element) + : MediaControlInputElement(doc, forward ? MEDIA_CONTROLS_SEEK_FORWARD_BUTTON : MEDIA_CONTROLS_SEEK_BACK_BUTTON, + "button", element, forward ? MediaSeekForwardButton : MediaSeekBackButton) , m_forward(forward) , m_seeking(false) , m_capturing(false) @@ -248,10 +268,9 @@ void MediaControlSeekButtonElement::seekTimerFired(Timer