Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. | 2 * Copyright (C) 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. |
| 3 * Copyright (C) 2012 Google Inc. All rights reserved. | 3 * Copyright (C) 2012 Google Inc. All rights reserved. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
| 7 * are met: | 7 * are met: |
| 8 * | 8 * |
| 9 * 1. Redistributions of source code must retain the above copyright | 9 * 1. Redistributions of source code must retain the above copyright |
| 10 * notice, this list of conditions and the following disclaimer. | 10 * notice, this list of conditions and the following disclaimer. |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 30 #include "config.h" | 30 #include "config.h" |
| 31 #include "core/html/shadow/MediaControlElements.h" | 31 #include "core/html/shadow/MediaControlElements.h" |
| 32 | 32 |
| 33 #include "bindings/core/v8/ExceptionStatePlaceholder.h" | 33 #include "bindings/core/v8/ExceptionStatePlaceholder.h" |
| 34 #include "core/dom/DOMTokenList.h" | 34 #include "core/dom/DOMTokenList.h" |
| 35 #include "core/dom/shadow/ShadowRoot.h" | 35 #include "core/dom/shadow/ShadowRoot.h" |
| 36 #include "core/events/MouseEvent.h" | 36 #include "core/events/MouseEvent.h" |
| 37 #include "core/frame/LocalFrame.h" | 37 #include "core/frame/LocalFrame.h" |
| 38 #include "core/html/HTMLVideoElement.h" | 38 #include "core/html/HTMLVideoElement.h" |
| 39 #include "core/html/MediaController.h" | 39 #include "core/html/MediaController.h" |
| 40 #include "core/html/TimeRanges.h" | |
| 40 #include "core/html/shadow/MediaControls.h" | 41 #include "core/html/shadow/MediaControls.h" |
| 41 #include "core/html/track/TextTrack.h" | 42 #include "core/html/track/TextTrack.h" |
| 42 #include "core/html/track/vtt/VTTRegionList.h" | 43 #include "core/html/track/vtt/VTTRegionList.h" |
| 43 #include "core/page/EventHandler.h" | 44 #include "core/page/EventHandler.h" |
| 44 #include "core/rendering/RenderMediaControlElements.h" | 45 #include "core/rendering/RenderMediaControlElements.h" |
| 45 #include "core/rendering/RenderSlider.h" | 46 #include "core/rendering/RenderSlider.h" |
| 46 #include "core/rendering/RenderTheme.h" | 47 #include "core/rendering/RenderTheme.h" |
| 47 #include "core/rendering/RenderVideo.h" | 48 #include "core/rendering/RenderVideo.h" |
| 48 #include "platform/RuntimeEnabledFeatures.h" | 49 #include "platform/RuntimeEnabledFeatures.h" |
| 49 | 50 |
| 50 namespace blink { | 51 namespace blink { |
| 51 | 52 |
| 52 using namespace HTMLNames; | 53 using namespace HTMLNames; |
| 53 | 54 |
| 54 static const AtomicString& getMediaControlCurrentTimeDisplayElementShadowPseudoI d(); | 55 static const AtomicString& getMediaControlCurrentTimeDisplayElementShadowPseudoI d(); |
| 55 static const AtomicString& getMediaControlTimeRemainingDisplayElementShadowPseud oId(); | 56 static const AtomicString& getMediaControlTimeRemainingDisplayElementShadowPseud oId(); |
| 56 | 57 |
| 57 // This is the duration from mediaControls.css | 58 // This is the duration from mediaControls.css |
| 58 static const double fadeOutDuration = 0.3; | 59 static const double fadeOutDuration = 0.3; |
| 59 | 60 |
| 61 // Snap seeks to the nearest seekable() range if they're <= this percentage of t he duration apart. | |
| 62 // I.e., if the seekable() range is [4s, 5s] and the duration 10s, clicks on the timeline >= 3s or <= 6s | |
| 63 // would snap to 4 and 5 respectively. Clicks outside of those ranges would be dropped. | |
| 64 // | |
| 65 // This ensures accidental clicks don't cause annoying timeline jumps, or worse, restart the entire | |
| 66 // playback process when only a seek to zero is available. | |
| 67 static const double snapPercentageForSeeks = 10 / 100.0; | |
|
philipj_slow
2014/10/01 11:14:22
This is 0.1 and not a percentage :)
| |
| 68 | |
| 60 static bool isUserInteractionEvent(Event* event) | 69 static bool isUserInteractionEvent(Event* event) |
| 61 { | 70 { |
| 62 const AtomicString& type = event->type(); | 71 const AtomicString& type = event->type(); |
| 63 return type == EventTypeNames::mousedown | 72 return type == EventTypeNames::mousedown |
| 64 || type == EventTypeNames::mouseup | 73 || type == EventTypeNames::mouseup |
| 65 || type == EventTypeNames::click | 74 || type == EventTypeNames::click |
| 66 || type == EventTypeNames::dblclick | 75 || type == EventTypeNames::dblclick |
| 67 || event->isKeyboardEvent() | 76 || event->isKeyboardEvent() |
| 68 || event->isTouchEvent(); | 77 || event->isTouchEvent(); |
| 69 } | 78 } |
| (...skipping 341 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 411 | 420 |
| 412 MediaControlInputElement::defaultEventHandler(event); | 421 MediaControlInputElement::defaultEventHandler(event); |
| 413 | 422 |
| 414 if (event->type() == EventTypeNames::mouseover || event->type() == EventType Names::mouseout || event->type() == EventTypeNames::mousemove) | 423 if (event->type() == EventTypeNames::mouseover || event->type() == EventType Names::mouseout || event->type() == EventTypeNames::mousemove) |
| 415 return; | 424 return; |
| 416 | 425 |
| 417 double time = value().toDouble(); | 426 double time = value().toDouble(); |
| 418 if (event->type() == EventTypeNames::input) { | 427 if (event->type() == EventTypeNames::input) { |
| 419 // FIXME: This will need to take the timeline offset into consideration | 428 // FIXME: This will need to take the timeline offset into consideration |
| 420 // once that concept is supported, see https://crbug.com/312699 | 429 // once that concept is supported, see https://crbug.com/312699 |
| 421 if (mediaElement().controller()) | 430 if (mediaElement().controller()) { |
| 422 mediaElement().controller()->setCurrentTime(time); | 431 mediaElement().controller()->setCurrentTime(time); |
|
philipj_slow
2014/10/01 11:14:22
Should the same rule not apply to a media element
DaleCurtis
2014/10/14 18:06:26
Done.
philipj_slow
2014/10/16 18:52:51
We appear to have miscommunicated :) I mean that t
DaleCurtis
2014/10/16 19:51:50
Sorry I still don't understand. :| Are you saying
philipj_slow
2014/10/16 20:03:18
Oops, sloppy reading on my part! You've already do
| |
| 423 else | 432 } else { |
| 424 mediaElement().setCurrentTime(time, IGNORE_EXCEPTION); | 433 // Only pass through seeks that are within the seekable range or clo se enough that we're sure |
| 434 // the user didn't make an accidental click. | |
| 435 RefPtrWillBeRawPtr<TimeRanges> seekableRanges = mediaElement().seeka ble(); | |
| 436 if (seekableRanges->contain(time)) { | |
| 437 mediaElement().setCurrentTime(time, IGNORE_EXCEPTION); | |
| 438 } else { | |
| 439 const double duration = getFloatingPointAttribute(maxAttr); | |
|
philipj_slow
2014/10/01 11:14:22
It took me a while to realize that the duration is
| |
| 440 const double nearestTime = seekableRanges->nearest(time, mediaEl ement().currentTime()); | |
| 441 if (duration && std::abs(time - nearestTime) / duration <= snapP ercentageForSeeks) | |
| 442 mediaElement().setCurrentTime(time, IGNORE_EXCEPTION); | |
| 443 } | |
| 444 } | |
| 425 } | 445 } |
| 426 | 446 |
| 427 RenderSlider* slider = toRenderSlider(renderer()); | 447 RenderSlider* slider = toRenderSlider(renderer()); |
| 428 if (slider && slider->inDragMode()) | 448 if (slider && slider->inDragMode()) |
| 429 mediaControls().updateCurrentTimeDisplay(); | 449 mediaControls().updateCurrentTimeDisplay(); |
| 430 } | 450 } |
| 431 | 451 |
| 432 bool MediaControlTimelineElement::willRespondToMouseClickEvents() | 452 bool MediaControlTimelineElement::willRespondToMouseClickEvents() |
| 433 { | 453 { |
| 434 return inDocument() && document().isActive(); | 454 return inDocument() && document().isActive(); |
| (...skipping 335 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 770 float fontSize = smallestDimension * 0.05f; | 790 float fontSize = smallestDimension * 0.05f; |
| 771 if (fontSize != m_fontSize) { | 791 if (fontSize != m_fontSize) { |
| 772 m_fontSize = fontSize; | 792 m_fontSize = fontSize; |
| 773 setInlineStyleProperty(CSSPropertyFontSize, fontSize, CSSPrimitiveValue: :CSS_PX); | 793 setInlineStyleProperty(CSSPropertyFontSize, fontSize, CSSPrimitiveValue: :CSS_PX); |
| 774 } | 794 } |
| 775 } | 795 } |
| 776 | 796 |
| 777 // ---------------------------- | 797 // ---------------------------- |
| 778 | 798 |
| 779 } // namespace blink | 799 } // namespace blink |
| OLD | NEW |