mirror of
https://github.com/videojs/video.js.git
synced 2025-01-15 10:39:58 +02:00
Merge branch 'stable'
Conflicts: dist/video-js/video-js.css dist/video-js/video-js.min.css dist/video-js/video.dev.js dist/video-js/video.js
This commit is contained in:
commit
9d311640b1
@ -6,6 +6,9 @@ _(none)_
|
|||||||
|
|
||||||
--------------------
|
--------------------
|
||||||
|
|
||||||
|
## 4.6.2 (2014-06-10)
|
||||||
|
* Fixed an issue with the firstplay event not firing when autoplaying ([view](https://github.com/videojs/video.js/pull/1271))
|
||||||
|
|
||||||
## 4.6.1 (2014-05-20)
|
## 4.6.1 (2014-05-20)
|
||||||
* Udpated playbackRate menu to work in minified version ([view](https://github.com/videojs/video.js/pull/1223))
|
* Udpated playbackRate menu to work in minified version ([view](https://github.com/videojs/video.js/pull/1223))
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "video.js",
|
"name": "video.js",
|
||||||
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
||||||
"version": "4.6.1",
|
"version": "4.6.2",
|
||||||
"main": [
|
"main": [
|
||||||
"dist/video-js/video.js",
|
"dist/video-js/video.js",
|
||||||
"dist/video-js/video-js.css"
|
"dist/video-js/video-js.css"
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "video.js",
|
"name": "video.js",
|
||||||
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
||||||
"version": "4.6.1",
|
"version": "4.6.2",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"videojs",
|
"videojs",
|
||||||
"html5",
|
"html5",
|
||||||
|
@ -164,7 +164,7 @@ _inherited from_: [src/js/component.js#L663](https://github.com/videojs/video.js
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `Object` A mock TimeRange object (following HTML spec)
|
* `Object` A mock TimeRange object (following HTML spec)
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L751](https://github.com/videojs/video.js/blob/master/src/js/player.js#L751)
|
_defined in_: [src/js/player.js#L767](https://github.com/videojs/video.js/blob/master/src/js/player.js#L767)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -179,7 +179,7 @@ _defined in_: [src/js/player.js#L751](https://github.com/videojs/video.js/blob/m
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `Number` A decimal between 0 and 1 representing the percent
|
* `Number` A decimal between 0 and 1 representing the percent
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L777](https://github.com/videojs/video.js/blob/master/src/js/player.js#L777)
|
_defined in_: [src/js/player.js#L793](https://github.com/videojs/video.js/blob/master/src/js/player.js#L793)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -197,7 +197,7 @@ _inherited from_: [src/js/component.js#L506](https://github.com/videojs/video.js
|
|||||||
> Old naming for exitFullscreen
|
> Old naming for exitFullscreen
|
||||||
**Deprecated** true
|
**Deprecated** true
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L974](https://github.com/videojs/video.js/blob/master/src/js/player.js#L974)
|
_defined in_: [src/js/player.js#L990](https://github.com/videojs/video.js/blob/master/src/js/player.js#L990)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -233,7 +233,7 @@ _inherited from_: [src/js/component.js#L224](https://github.com/videojs/video.js
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `Boolean` Controls are showing
|
* `Boolean` Controls are showing
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L1234](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1234)
|
_defined in_: [src/js/player.js#L1250](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1250)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -267,7 +267,7 @@ _inherited from_: [src/js/component.js#L194](https://github.com/videojs/video.js
|
|||||||
* `Number` The time in seconds, when not setting
|
* `Number` The time in seconds, when not setting
|
||||||
* `vjs.Player` self, when the current time is set
|
* `vjs.Player` self, when the current time is set
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L674](https://github.com/videojs/video.js/blob/master/src/js/player.js#L674)
|
_defined in_: [src/js/player.js#L690](https://github.com/videojs/video.js/blob/master/src/js/player.js#L690)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -293,7 +293,7 @@ _inherited from_: [src/js/component.js#L775](https://github.com/videojs/video.js
|
|||||||
> This is especially helpful if you are dynamically adding and removing videos
|
> This is especially helpful if you are dynamically adding and removing videos
|
||||||
> to/from the DOM.
|
> to/from the DOM.
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L126](https://github.com/videojs/video.js/blob/master/src/js/player.js#L126)
|
_defined in_: [src/js/player.js#L112](https://github.com/videojs/video.js/blob/master/src/js/player.js#L112)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -312,7 +312,7 @@ _defined in_: [src/js/player.js#L126](https://github.com/videojs/video.js/blob/m
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `Number` The duration of the video in seconds
|
* `Number` The duration of the video in seconds
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L705](https://github.com/videojs/video.js/blob/master/src/js/player.js#L705)
|
_defined in_: [src/js/player.js#L721](https://github.com/videojs/video.js/blob/master/src/js/player.js#L721)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -365,7 +365,7 @@ _inherited from_: [src/js/component.js#L954](https://github.com/videojs/video.js
|
|||||||
* `vjs.MediaError|null` when getting
|
* `vjs.MediaError|null` when getting
|
||||||
* `vjs.Player` when setting
|
* `vjs.Player` when setting
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L1319](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1319)
|
_defined in_: [src/js/player.js#L1335](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1335)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -377,7 +377,7 @@ _defined in_: [src/js/player.js#L1319](https://github.com/videojs/video.js/blob/
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `vjs.Player` self
|
* `vjs.Player` self
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L953](https://github.com/videojs/video.js/blob/master/src/js/player.js#L953)
|
_defined in_: [src/js/player.js#L969](https://github.com/videojs/video.js/blob/master/src/js/player.js#L969)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -505,7 +505,7 @@ _inherited from_: [src/js/component.js#L466](https://github.com/videojs/video.js
|
|||||||
##### PARAMETERS:
|
##### PARAMETERS:
|
||||||
* __isFS__
|
* __isFS__
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L876](https://github.com/videojs/video.js/blob/master/src/js/player.js#L876)
|
_defined in_: [src/js/player.js#L892](https://github.com/videojs/video.js/blob/master/src/js/player.js#L892)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -529,7 +529,7 @@ _defined in_: [src/js/player.js#L876](https://github.com/videojs/video.js/blob/m
|
|||||||
* `Boolean` true if fullscreen, false if not
|
* `Boolean` true if fullscreen, false if not
|
||||||
* `vjs.Player` self, when setting
|
* `vjs.Player` self, when setting
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L864](https://github.com/videojs/video.js/blob/master/src/js/player.js#L864)
|
_defined in_: [src/js/player.js#L880](https://github.com/videojs/video.js/blob/master/src/js/player.js#L880)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -549,7 +549,7 @@ _defined in_: [src/js/player.js#L864](https://github.com/videojs/video.js/blob/m
|
|||||||
* `Boolean` True if mute is on, false if not, when getting
|
* `Boolean` True if mute is on, false if not, when getting
|
||||||
* `vjs.Player` self, when setting mute
|
* `vjs.Player` self, when setting mute
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L826](https://github.com/videojs/video.js/blob/master/src/js/player.js#L826)
|
_defined in_: [src/js/player.js#L842](https://github.com/videojs/video.js/blob/master/src/js/player.js#L842)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -674,7 +674,7 @@ _inherited from_: [src/js/component.js#L173](https://github.com/videojs/video.js
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `vjs.Player` self
|
* `vjs.Player` self
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L643](https://github.com/videojs/video.js/blob/master/src/js/player.js#L643)
|
_defined in_: [src/js/player.js#L659](https://github.com/videojs/video.js/blob/master/src/js/player.js#L659)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -687,7 +687,7 @@ _defined in_: [src/js/player.js#L643](https://github.com/videojs/video.js/blob/m
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `Boolean` false if the media is currently playing, or true otherwise
|
* `Boolean` false if the media is currently playing, or true otherwise
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L656](https://github.com/videojs/video.js/blob/master/src/js/player.js#L656)
|
_defined in_: [src/js/player.js#L672](https://github.com/videojs/video.js/blob/master/src/js/player.js#L672)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -699,7 +699,7 @@ _defined in_: [src/js/player.js#L656](https://github.com/videojs/video.js/blob/m
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `vjs.Player` self
|
* `vjs.Player` self
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L631](https://github.com/videojs/video.js/blob/master/src/js/player.js#L631)
|
_defined in_: [src/js/player.js#L647](https://github.com/videojs/video.js/blob/master/src/js/player.js#L647)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -731,7 +731,7 @@ _inherited from_: [src/js/component.js#L120](https://github.com/videojs/video.js
|
|||||||
* `String` poster URL when getting
|
* `String` poster URL when getting
|
||||||
* `vjs.Player` self when setting
|
* `vjs.Player` self when setting
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L1207](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1207)
|
_defined in_: [src/js/player.js#L1223](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1223)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -779,7 +779,7 @@ _inherited from_: [src/js/component.js#L674](https://github.com/videojs/video.js
|
|||||||
> Old naming for requestFullscreen
|
> Old naming for requestFullscreen
|
||||||
**Deprecated** true
|
**Deprecated** true
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L940](https://github.com/videojs/video.js/blob/master/src/js/player.js#L940)
|
_defined in_: [src/js/player.js#L956](https://github.com/videojs/video.js/blob/master/src/js/player.js#L956)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -798,7 +798,7 @@ _defined in_: [src/js/player.js#L940](https://github.com/videojs/video.js/blob/m
|
|||||||
##### RETURNS:
|
##### RETURNS:
|
||||||
* `vjs.Player` self
|
* `vjs.Player` self
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L895](https://github.com/videojs/video.js/blob/master/src/js/player.js#L895)
|
_defined in_: [src/js/player.js#L911](https://github.com/videojs/video.js/blob/master/src/js/player.js#L911)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -847,7 +847,7 @@ _inherited from_: [src/js/component.js#L684](https://github.com/videojs/video.js
|
|||||||
* `String` The current video source when getting
|
* `String` The current video source when getting
|
||||||
* `String` The player when setting
|
* `String` The player when setting
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L1084](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1084)
|
_defined in_: [src/js/player.js#L1100](https://github.com/videojs/video.js/blob/master/src/js/player.js#L1100)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -895,7 +895,7 @@ _inherited from_: [src/js/component.js#L635](https://github.com/videojs/video.js
|
|||||||
* `Number` The current volume, when getting
|
* `Number` The current volume, when getting
|
||||||
* `vjs.Player` self, when setting
|
* `vjs.Player` self, when setting
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L796](https://github.com/videojs/video.js/blob/master/src/js/player.js#L796)
|
_defined in_: [src/js/player.js#L812](https://github.com/videojs/video.js/blob/master/src/js/player.js#L812)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -924,14 +924,14 @@ _inherited from_: [src/js/component.js#L747](https://github.com/videojs/video.js
|
|||||||
### durationchange `EVENT`
|
### durationchange `EVENT`
|
||||||
> Fired when the duration of the media resource is first known or changed
|
> Fired when the duration of the media resource is first known or changed
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L526](https://github.com/videojs/video.js/blob/master/src/js/player.js#L526)
|
_defined in_: [src/js/player.js#L542](https://github.com/videojs/video.js/blob/master/src/js/player.js#L542)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### ended `EVENT`
|
### ended `EVENT`
|
||||||
> Fired when the end of the media resource is reached (currentTime == duration)
|
> Fired when the end of the media resource is reached (currentTime == duration)
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L515](https://github.com/videojs/video.js/blob/master/src/js/player.js#L515)
|
_defined in_: [src/js/player.js#L531](https://github.com/videojs/video.js/blob/master/src/js/player.js#L531)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -942,63 +942,63 @@ _defined in_: [src/js/player.js#L515](https://github.com/videojs/video.js/blob/m
|
|||||||
> implementation yet, so use sparingly. If you don't have a reason to
|
> implementation yet, so use sparingly. If you don't have a reason to
|
||||||
> prevent playback, use `myPlayer.one('play');` instead.
|
> prevent playback, use `myPlayer.one('play');` instead.
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L472](https://github.com/videojs/video.js/blob/master/src/js/player.js#L472)
|
_defined in_: [src/js/player.js#L488](https://github.com/videojs/video.js/blob/master/src/js/player.js#L488)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### fullscreenchange `EVENT`
|
### fullscreenchange `EVENT`
|
||||||
> Fired when the player switches in or out of fullscreen mode
|
> Fired when the player switches in or out of fullscreen mode
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L555](https://github.com/videojs/video.js/blob/master/src/js/player.js#L555)
|
_defined in_: [src/js/player.js#L571](https://github.com/videojs/video.js/blob/master/src/js/player.js#L571)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### loadedalldata `EVENT`
|
### loadedalldata `EVENT`
|
||||||
> Fired when the player has finished downloading the source data
|
> Fired when the player has finished downloading the source data
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L452](https://github.com/videojs/video.js/blob/master/src/js/player.js#L452)
|
_defined in_: [src/js/player.js#L468](https://github.com/videojs/video.js/blob/master/src/js/player.js#L468)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### loadeddata `EVENT`
|
### loadeddata `EVENT`
|
||||||
> Fired when the player has downloaded data at the current playback position
|
> Fired when the player has downloaded data at the current playback position
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L446](https://github.com/videojs/video.js/blob/master/src/js/player.js#L446)
|
_defined in_: [src/js/player.js#L462](https://github.com/videojs/video.js/blob/master/src/js/player.js#L462)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### loadedmetadata `EVENT`
|
### loadedmetadata `EVENT`
|
||||||
> Fired when the player has initial duration and dimension information
|
> Fired when the player has initial duration and dimension information
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L440](https://github.com/videojs/video.js/blob/master/src/js/player.js#L440)
|
_defined in_: [src/js/player.js#L456](https://github.com/videojs/video.js/blob/master/src/js/player.js#L456)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### loadstart `EVENT`
|
### loadstart `EVENT`
|
||||||
> Fired when the user agent begins looking for media data
|
> Fired when the user agent begins looking for media data
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L410](https://github.com/videojs/video.js/blob/master/src/js/player.js#L410)
|
_defined in_: [src/js/player.js#L412](https://github.com/videojs/video.js/blob/master/src/js/player.js#L412)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### pause `EVENT`
|
### pause `EVENT`
|
||||||
> Fired whenever the media has been paused
|
> Fired whenever the media has been paused
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L486](https://github.com/videojs/video.js/blob/master/src/js/player.js#L486)
|
_defined in_: [src/js/player.js#L502](https://github.com/videojs/video.js/blob/master/src/js/player.js#L502)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### play `EVENT`
|
### play `EVENT`
|
||||||
> Fired whenever the media begins or resumes playback
|
> Fired whenever the media begins or resumes playback
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L458](https://github.com/videojs/video.js/blob/master/src/js/player.js#L458)
|
_defined in_: [src/js/player.js#L474](https://github.com/videojs/video.js/blob/master/src/js/player.js#L474)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### progress `EVENT`
|
### progress `EVENT`
|
||||||
> Fired while the user agent is downloading media data
|
> Fired while the user agent is downloading media data
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L504](https://github.com/videojs/video.js/blob/master/src/js/player.js#L504)
|
_defined in_: [src/js/player.js#L520](https://github.com/videojs/video.js/blob/master/src/js/player.js#L520)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -1015,14 +1015,14 @@ _inherited from_: [src/js/component.js#L854](https://github.com/videojs/video.js
|
|||||||
> During playback this is fired every 15-250 milliseconds, depnding on the
|
> During playback this is fired every 15-250 milliseconds, depnding on the
|
||||||
> playback technology in use.
|
> playback technology in use.
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L498](https://github.com/videojs/video.js/blob/master/src/js/player.js#L498)
|
_defined in_: [src/js/player.js#L514](https://github.com/videojs/video.js/blob/master/src/js/player.js#L514)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### volumechange `EVENT`
|
### volumechange `EVENT`
|
||||||
> Fired when the volume changes
|
> Fired when the volume changes
|
||||||
|
|
||||||
_defined in_: [src/js/player.js#L549](https://github.com/videojs/video.js/blob/master/src/js/player.js#L549)
|
_defined in_: [src/js/player.js#L565](https://github.com/videojs/video.js/blob/master/src/js/player.js#L565)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "video.js",
|
"name": "video.js",
|
||||||
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
"description": "An HTML5 and Flash video player with a common API and skin for both.",
|
||||||
"version": "4.6.1",
|
"version": "4.6.2",
|
||||||
"copyright": "Copyright 2014 Brightcove, Inc. https://github.com/videojs/video.js/blob/master/LICENSE",
|
"copyright": "Copyright 2014 Brightcove, Inc. https://github.com/videojs/video.js/blob/master/LICENSE",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"videojs",
|
"videojs",
|
||||||
|
@ -32,10 +32,7 @@ vjs.Html5 = vjs.MediaTechController.extend({
|
|||||||
// If the element source is already set, we may have missed the loadstart event, and want to trigger it.
|
// If the element source is already set, we may have missed the loadstart event, and want to trigger it.
|
||||||
// We don't want to set the source again and interrupt playback.
|
// We don't want to set the source again and interrupt playback.
|
||||||
if (source && this.el_.currentSrc === source.src && this.el_.networkState > 0) {
|
if (source && this.el_.currentSrc === source.src && this.el_.networkState > 0) {
|
||||||
// wait for the player to be ready so the player listeners are attached
|
|
||||||
player.ready(function(){
|
|
||||||
player.trigger('loadstart');
|
player.trigger('loadstart');
|
||||||
});
|
|
||||||
// Otherwise set the source if one was provided.
|
// Otherwise set the source if one was provided.
|
||||||
} else if (source) {
|
} else if (source) {
|
||||||
this.el_.src = source.src;
|
this.el_.src = source.src;
|
||||||
|
@ -58,20 +58,6 @@ vjs.Player = vjs.Component.extend({
|
|||||||
// see enableTouchActivity in Component
|
// see enableTouchActivity in Component
|
||||||
options.reportTouchActivity = false;
|
options.reportTouchActivity = false;
|
||||||
|
|
||||||
// Make sure the event listeners are the first things to happen when
|
|
||||||
// the player is ready. See #1208
|
|
||||||
// If not, the tech might fire events before the listeners are attached.
|
|
||||||
this.ready(function(){
|
|
||||||
this.on('loadstart', this.onLoadStart);
|
|
||||||
this.on('ended', this.onEnded);
|
|
||||||
this.on('play', this.onPlay);
|
|
||||||
this.on('firstplay', this.onFirstPlay);
|
|
||||||
this.on('pause', this.onPause);
|
|
||||||
this.on('progress', this.onProgress);
|
|
||||||
this.on('durationchange', this.onDurationChange);
|
|
||||||
this.on('fullscreenchange', this.onFullscreenChange);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Run base component initializing with new options.
|
// Run base component initializing with new options.
|
||||||
// Builds the element through createEl()
|
// Builds the element through createEl()
|
||||||
// Inits and embeds any child components in opts
|
// Inits and embeds any child components in opts
|
||||||
@ -230,6 +216,22 @@ vjs.Player.prototype.createEl = function(){
|
|||||||
}
|
}
|
||||||
vjs.insertFirst(tag, el); // Breaks iPhone, fixed in HTML5 setup.
|
vjs.insertFirst(tag, el); // Breaks iPhone, fixed in HTML5 setup.
|
||||||
|
|
||||||
|
// The event listeners need to be added before the children are added
|
||||||
|
// in the component init because the tech (loaded with mediaLoader) may
|
||||||
|
// fire events, like loadstart, that these events need to capture.
|
||||||
|
// Long term it might be better to expose a way to do this in component.init
|
||||||
|
// like component.initEventListeners() that runs between el creation and
|
||||||
|
// adding children
|
||||||
|
this.el_ = el;
|
||||||
|
this.on('loadstart', this.onLoadStart);
|
||||||
|
this.on('ended', this.onEnded);
|
||||||
|
this.on('play', this.onPlay);
|
||||||
|
this.on('firstplay', this.onFirstPlay);
|
||||||
|
this.on('pause', this.onPause);
|
||||||
|
this.on('progress', this.onProgress);
|
||||||
|
this.on('durationchange', this.onDurationChange);
|
||||||
|
this.on('fullscreenchange', this.onFullscreenChange);
|
||||||
|
|
||||||
return el;
|
return el;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -408,30 +410,44 @@ vjs.Player.prototype.stopTrackingCurrentTime = function(){
|
|||||||
* @event loadstart
|
* @event loadstart
|
||||||
*/
|
*/
|
||||||
vjs.Player.prototype.onLoadStart = function() {
|
vjs.Player.prototype.onLoadStart = function() {
|
||||||
// remove any first play listeners that weren't triggered from a previous video.
|
// TODO: Update to use `emptied` event instead. See #1277.
|
||||||
this.off('play', initFirstPlay);
|
|
||||||
this.one('play', initFirstPlay);
|
|
||||||
|
|
||||||
if (this.error()) {
|
// reset the error state
|
||||||
this.error(null);
|
this.error(null);
|
||||||
}
|
|
||||||
|
|
||||||
vjs.removeClass(this.el_, 'vjs-has-started');
|
// If it's already playing we want to trigger a firstplay event now.
|
||||||
|
// The firstplay event relies on both the play and loadstart events
|
||||||
|
// which can happen in any order for a new source
|
||||||
|
if (!this.paused()) {
|
||||||
|
this.trigger('firstplay');
|
||||||
|
} else {
|
||||||
|
// reset the hasStarted state
|
||||||
|
this.hasStarted(false);
|
||||||
|
this.one('play', function(){
|
||||||
|
this.hasStarted(true);
|
||||||
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// Need to create this outside the scope of onLoadStart so it
|
vjs.Player.prototype.hasStarted_ = false;
|
||||||
// can be added and removed (to avoid piling first play listeners).
|
|
||||||
function initFirstPlay(e) {
|
|
||||||
var fpEvent = { type: 'firstplay', target: this.el_ };
|
|
||||||
// Using vjs.trigger so we can check if default was prevented
|
|
||||||
var keepGoing = vjs.trigger(this.el_, fpEvent);
|
|
||||||
|
|
||||||
if (!keepGoing) {
|
vjs.Player.prototype.hasStarted = function(hasStarted){
|
||||||
e.preventDefault();
|
if (hasStarted !== undefined) {
|
||||||
e.stopPropagation();
|
// only update if this is a new value
|
||||||
e.stopImmediatePropagation();
|
if (this.hasStarted_ !== hasStarted) {
|
||||||
|
this.hasStarted_ = hasStarted;
|
||||||
|
if (hasStarted) {
|
||||||
|
this.addClass('vjs-has-started');
|
||||||
|
// trigger the firstplay event if this newly has played
|
||||||
|
this.trigger('firstplay');
|
||||||
|
} else {
|
||||||
|
this.removeClass('vjs-has-started');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
return this.hasStarted_;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fired when the player has initial duration and dimension information
|
* Fired when the player has initial duration and dimension information
|
||||||
|
@ -40,6 +40,7 @@ vjs.MediaFaker.prototype.src = function(){ return 'movie.mp4'; };
|
|||||||
vjs.MediaFaker.prototype.volume = function(){ return 0; };
|
vjs.MediaFaker.prototype.volume = function(){ return 0; };
|
||||||
vjs.MediaFaker.prototype.muted = function(){ return false; };
|
vjs.MediaFaker.prototype.muted = function(){ return false; };
|
||||||
vjs.MediaFaker.prototype.pause = function(){ return false; };
|
vjs.MediaFaker.prototype.pause = function(){ return false; };
|
||||||
|
vjs.MediaFaker.prototype.paused = function(){ return true; };
|
||||||
vjs.MediaFaker.prototype.supportsFullScreen = function(){ return false; };
|
vjs.MediaFaker.prototype.supportsFullScreen = function(){ return false; };
|
||||||
vjs.MediaFaker.prototype.features = {};
|
vjs.MediaFaker.prototype.features = {};
|
||||||
vjs.MediaFaker.prototype.buffered = function(){ return {}; };
|
vjs.MediaFaker.prototype.buffered = function(){ return {}; };
|
||||||
|
@ -378,7 +378,7 @@ test('should not add multiple first play events despite subsequent loads', funct
|
|||||||
var player = PlayerTest.makePlayer({});
|
var player = PlayerTest.makePlayer({});
|
||||||
|
|
||||||
player.on('firstplay', function(){
|
player.on('firstplay', function(){
|
||||||
ok('First play should fire once.');
|
ok(true, 'First play should fire once.');
|
||||||
});
|
});
|
||||||
|
|
||||||
// Checking to make sure onLoadStart removes first play listener before adding a new one.
|
// Checking to make sure onLoadStart removes first play listener before adding a new one.
|
||||||
@ -387,6 +387,35 @@ test('should not add multiple first play events despite subsequent loads', funct
|
|||||||
player.trigger('play');
|
player.trigger('play');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should fire firstplay after resetting the player', function() {
|
||||||
|
var player = PlayerTest.makePlayer({});
|
||||||
|
|
||||||
|
var fpFired = false;
|
||||||
|
player.on('firstplay', function(){
|
||||||
|
fpFired = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
// init firstplay listeners
|
||||||
|
player.trigger('loadstart');
|
||||||
|
player.trigger('play');
|
||||||
|
ok(fpFired, 'First firstplay fired');
|
||||||
|
|
||||||
|
// reset the player
|
||||||
|
player.trigger('loadstart');
|
||||||
|
fpFired = false;
|
||||||
|
player.trigger('play');
|
||||||
|
ok(fpFired, 'Second firstplay fired');
|
||||||
|
|
||||||
|
// the play event can fire before the loadstart event.
|
||||||
|
// in that case we still want the firstplay even to fire.
|
||||||
|
player.tech.paused = function(){ return false; };
|
||||||
|
fpFired = false;
|
||||||
|
// reset the player
|
||||||
|
player.trigger('loadstart');
|
||||||
|
// player.trigger('play');
|
||||||
|
ok(fpFired, 'Third firstplay fired');
|
||||||
|
});
|
||||||
|
|
||||||
test('should remove vjs-has-started class', function(){
|
test('should remove vjs-has-started class', function(){
|
||||||
expect(3);
|
expect(3);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user