Skip to content

Latest commit

 

History

History
254 lines (171 loc) · 7.64 KB

README.md

File metadata and controls

254 lines (171 loc) · 7.64 KB

HTML Video "class"

Minified version can be found in the demo/public_html folder

Tested using BrowserStack

BrowserStack


Abstract

This HTML video player aims to simplify the setup and playback of [vanilla] HTML video. All you have to do is create ONE div element, set it to the size you want, and initialize the player with it. There are no dependencies of any external CSS, etc. This player is entirely self-contained.

All sub-elements (tags, controls, etc.) will be generated automatically (inline SVG). This should eliminate the need for coding/creating nested elements for any video implementation.

To load a video, I've implemented some fuzzy logic into it. This means that you have the option of just inputting a single string for a single file, or an array of filepaths for multiple files. The code should be smart enough to determine the filetype which it'll use for the <source> tag(s) it'll generate.

You can also input an optional second string parameter for a poster file.

The video has rudimentary detection what browser environment you're on. If you're on a mobile browser, once playback starts, it will remove all "custom" controls and default to built-in browser player controls - this is to ensure proper behavior/compatibility. Of course, I did say "rudimentary" (i.e. not bullet-proof), so you can always manually set it via the ismobile variable.

Quick Start

First, Create your div in the HTML - give it an ID (let's assume it's videoPlayer). Style it as you wish (set WxH via CSS)

Next, instanciate video player instance and assign it to the div you just created

var video = new VideoPlayer();
	video.init('videoPlayer');

Next, load your video and (optional) poster.

video.load('VIDEO_FILE', 'POSTER_FILE');

That's it ;)

Parameters

Behavioral settings for the player

autoplay | Default: false
Auto plays video.

startmuted | Default: false
Mutes video on initial (auto) play. Requires autoplay to be true.

replaywithsound | Default: false
Force unmutes video on replay (by default it uses the last audio setting).

loop | Default: false
Loops the video.

allowfullscreen | Default: false
Enables manual fullscreen button.

playonseek | Default: true
Forces playback whenever you move the playhead. If set to false it stays on its last play/pause state even after jumping/seeking.

uniqereplay | Default: true
Uses a replay icon for the replay. When set to false, it'll use the same icon as the play button.

chromeless | Default: false
Removes all controls. Useful for preview videos on collapsed states for desktop units where you don't want video controls visible. WARNING: If you also set elementtrigger to false, then you can only control/toggle the video programatically.

progressive | Default: true
Preloads the entire video (or a huge chunk of it) before playback.

ismobile | Default: auto-detect
Reverts to built-in video player and controls. Naturally a lot of the "special behaviors above" will be disabled in this mode.

elementtrigger | Default: true
Allows clicking of the entire video container itself to play/pause. If set to false, you'll have to use the control icons/buttons.

preview | Default: 0
Setting to a positive integer will enable TIMED auto-playing/auto-muted playback. Then it will stop and show the play button for full video playback (with sound).

debug | Default: false
Output player logs to console.

Methods

Usual Suspects

init(CONTAINER_DIV)
CONTAINER_DIV is the id of your chosen video container DOM element.

load(FILE(S), POSTER)
FILE(S) could be a string to a single file, or an array of filepaths.

play()
Plays video

pause()
Pauses video

stop()
"Stops" video. Techincally, there's no realy stop() method in HTML video. So what this does is it mimmicks a "stop" by pausing it and rewinding back to the initial frame.

replay()
Plays video from initial frame.

mute()
Mutes video

unmute()
Unmutes video

seek(TIME)
Jumps to time

setPoster(IMAGE)
Manually set poster image

Some methods that are available but not necessarily advertized.

reflow()
Can be called if you dynamically change the size of the video container and need the control elements to re-position relative to the new container dimensions.

The elements that are "centered" are indexed in the centered_controls array. Which means you can inject your own html elements programatically and also have them centered if you push it into the array.

unload()
Unloads the video. Instance itself is still active.

destroy()
Destroys the video instance completely. You'll have to re-initialize it if you want to use it again.

isPlaying()
The same as checking isplaying but in method format.

Convenience variables

Some variables you can check for current video status.

playhead
Position of the playhead

duration
Total duration of the video

proxy
If for some reason, you want to access the <video> element itself, you can do it through this :)

initialized
If the video instance has been initialized

ready
If the video state is ready for playback

started
If the video has started

firsttime
If the video hasn't been replayed.

completed
If the video has completed a full playback already.

hasposter If the current video has a poster assigned to it.

Callbacks and Tracking

Callbacks that can be overriden

callback_end callback_play callback_pause callback_volume callback_loading callback_progress callback_ready

track_start track_end track_preview_start track_preview_end track_play track_pause track_replay track_mute track_unmute track_q25 track_q50 track_q75 track_enterfs track_exitf

Example(s)

To override, simply override the method your video instance. For example to add in a Studio tracking event on video start:

VIDEO_INSTANCE.track_start = function(e) {
    Enabler.counter('VIDEO_STARTS', true);
};

Or let's say you want to do something else in the unit when video playback ends:

VIDEO_INSTANCE.callback_end = function(e) {
    // DO SOMETHING ELSE
};

Alternatively, you could inject it to track_end instead. More than one way to skin a cat ;)

Control Skinning

Overriding control DOM elements

While the position of control elements are pretty much fixed (the big play butotn will always be centered, etc.), you CAN change the actual 'buttons' used.

These are the methods you can override:

dom_template_bigplay dom_template_bigsound dom_template_replay dom_template_spinner dom_template_play dom_template_pause dom_template_mute dom_template_unmute dom_template_fs

Example(s)

As an example, by default, this is the current template for the big play button:

dom_template_bigplay: function() {
	this.dom_bigplay = document.createElement('div');
	this.dom_bigplay.innerHTML = this.svg.bigplay; // USES an SVG in another variable
	this.dom_bigplay.getElementsByTagName('path')[0].style.fill = this.colors_bigplay;
}

Let's say you just want to use an image that was provided by the client. Then you'd override it with:

VIDEO_INSTANCE.dom_template_bigplay = function() {
	VIDEO_INSTANCE.dom_bigplay = document.createElement('img');
	VIDEO_INSTANCE.dom_bigplay.src = 'YOUR_IMAGE_HERE';
};

Note: you have to use the dom_bigplay within the overriden method because the player subroutines manipulates that element (to toggle visibility, etc.)