1
0
mirror of https://github.com/videojs/video.js.git synced 2024-12-10 11:10:19 +02:00

Provide more information to screen reader users about the progress bar, current time, and time remaining diff --git a/src/js/controls.js b/src/js/controls.js

index bb050b9..504913c 100644

Signed-off-by: Greg Kraus <gdkraus@ncsu.edu>
This commit is contained in:
Greg Kraus 2013-01-20 07:26:48 -05:00
parent 00a508508e
commit c74c4e2c3a

34
src/js/controls.js vendored
View File

@ -361,7 +361,8 @@ vjs.CurrentTimeDisplay.prototype.createEl = function(){
this.content = vjs.createEl('div', { this.content = vjs.createEl('div', {
className: 'vjs-current-time-display', className: 'vjs-current-time-display',
innerHTML: '0:00' innerHTML: '<span class="vjs-control-text">Current Time </span>' + '0:00', // label the current time for screen reader users
'aria-live': 'off' // tell screen readers not to automatically read the time as it changes
}); });
el.appendChild(vjs.createEl('div').appendChild(this.content)); el.appendChild(vjs.createEl('div').appendChild(this.content));
@ -371,7 +372,7 @@ vjs.CurrentTimeDisplay.prototype.createEl = function(){
vjs.CurrentTimeDisplay.prototype.updateContent = function(){ vjs.CurrentTimeDisplay.prototype.updateContent = function(){
// Allows for smooth scrubbing, when player can't keep up. // Allows for smooth scrubbing, when player can't keep up.
var time = (this.player_.scrubbing) ? this.player_.getCache().currentTime : this.player_.currentTime(); var time = (this.player_.scrubbing) ? this.player_.getCache().currentTime : this.player_.currentTime();
this.content.innerHTML = vjs.formatTime(time, this.player_.duration()); this.content.innerHTML = '<span class="vjs-control-text">Current Time </span>' + vjs.formatTime(time, this.player_.duration());
}; };
/** /**
@ -402,7 +403,9 @@ vjs.DurationDisplay.prototype.createEl = function(){
}; };
vjs.DurationDisplay.prototype.updateContent = function(){ vjs.DurationDisplay.prototype.updateContent = function(){
if (this.player_.duration()) { this.content.innerHTML = vjs.formatTime(this.player_.duration()); } if (this.player_.duration()) {
this.content.innerHTML = '<span class="vjs-control-text">Current Time </span>' + vjs.formatTime(this.player_.duration()); // label the current time for screen reader users
}
}; };
/** /**
@ -444,7 +447,8 @@ vjs.RemainingTimeDisplay.prototype.createEl = function(){
this.content = vjs.createEl('div', { this.content = vjs.createEl('div', {
className: 'vjs-remaining-time-display', className: 'vjs-remaining-time-display',
innerHTML: '-0:00' innerHTML: '<span class="vjs-control-text">Remaining Time </span>' + '-0:00', // label the remaining time for screen reader users
'aria-live': 'off' // tell screen readers not to automatically read the time as it changes
}); });
el.appendChild(vjs.createEl('div').appendChild(this.content)); el.appendChild(vjs.createEl('div').appendChild(this.content));
@ -452,7 +456,11 @@ vjs.RemainingTimeDisplay.prototype.createEl = function(){
}; };
vjs.RemainingTimeDisplay.prototype.updateContent = function(){ vjs.RemainingTimeDisplay.prototype.updateContent = function(){
if (this.player_.duration()) { this.content.innerHTML = '-'+vjs.formatTime(this.player_.remainingTime()); } if (this.player_.duration()) {
if (this.player_.duration()) {
this.content.innerHTML = '<span class="vjs-control-text">Remaining Time </span>' + '-'+ vjs.formatTime(this.player_.remainingTime());
}
}
// Allows for smooth scrubbing, when player can't keep up. // Allows for smooth scrubbing, when player can't keep up.
// var time = (this.player_.scrubbing) ? this.player_.getCache().currentTime : this.player_.currentTime(); // var time = (this.player_.scrubbing) ? this.player_.getCache().currentTime : this.player_.currentTime();
@ -638,6 +646,8 @@ vjs.ProgressControl.prototype.createEl = function(){
*/ */
vjs.SeekBar = function(player, options){ vjs.SeekBar = function(player, options){
goog.base(this, player, options); goog.base(this, player, options);
player.on('timeupdate', vjs.bind(this, this.updateARIAAttributes));
player.ready(vjs.bind(this, this.updateARIAAttributes));
}; };
goog.inherits(vjs.SeekBar, vjs.Slider); goog.inherits(vjs.SeekBar, vjs.Slider);
@ -655,10 +665,18 @@ vjs.SeekBar.prototype.playerEvent = 'timeupdate';
vjs.SeekBar.prototype.createEl = function(){ vjs.SeekBar.prototype.createEl = function(){
return goog.base(this, 'createEl', 'div', { return goog.base(this, 'createEl', 'div', {
className: 'vjs-progress-holder' className: 'vjs-progress-holder',
'aria-label': 'video progress bar'
}); });
}; };
vjs.SeekBar.prototype.updateARIAAttributes = function(){
// Allows for smooth scrubbing, when player can't keep up.
var time = (this.player_.scrubbing) ? this.player_.getCache().currentTime : this.player_.currentTime();
this.el_.setAttribute('aria-valuenow',vjs.round(this.getPercent()*100, 2)); // machine readable value of progress bar (percentage complete)
this.el_.setAttribute('aria-valuetext',vjs.formatTime(time, this.player_.duration())); // human readable value of progress bar (time complete)
};
vjs.SeekBar.prototype.getPercent = function(){ vjs.SeekBar.prototype.getPercent = function(){
return this.player_.currentTime() / this.player_.duration(); return this.player_.currentTime() / this.player_.duration();
}; };
@ -692,11 +710,11 @@ vjs.SeekBar.prototype.onMouseUp = function(event){
}; };
vjs.SeekBar.prototype.stepForward = function(){ vjs.SeekBar.prototype.stepForward = function(){
this.player_.currentTime(this.player_.currentTime() + 1); this.player_.currentTime(this.player_.currentTime() + 5); // more quickly fast forward for keyboard-only users
}; };
vjs.SeekBar.prototype.stepBack = function(){ vjs.SeekBar.prototype.stepBack = function(){
this.player_.currentTime(this.player_.currentTime() - 1); this.player_.currentTime(this.player_.currentTime() - 5); // more quickly rewind for keyboard-only users
}; };