2018-01-08 18:47:13 +00:00
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var BaseSound = require('../BaseSound');
|
2018-01-11 16:55:05 +00:00
|
|
|
var SoundValueEvent = require('../SoundValueEvent');
|
2018-01-08 18:47:13 +00:00
|
|
|
var HTML5AudioSound = new Class({
|
|
|
|
Extends: BaseSound,
|
|
|
|
initialize: function HTML5AudioSound(manager, key, config) {
|
|
|
|
if (config === void 0) { config = {}; }
|
2018-01-11 16:35:25 +00:00
|
|
|
/**
|
|
|
|
* An array containing all HTML5 Audio tags that could be used for individual
|
|
|
|
* sound's playback. Number of instances depends on the config value passed
|
|
|
|
* to the Loader#audio method call, default is 1.
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @property {HTMLAudioElement[]} tags
|
|
|
|
*/
|
|
|
|
this.tags = manager.game.cache.audio.get(key);
|
2018-01-11 16:36:51 +00:00
|
|
|
if (!this.tags) {
|
|
|
|
console.error('No audio loaded in cache with key: \'' + key + '\'!');
|
|
|
|
return;
|
|
|
|
}
|
2018-01-08 18:54:40 +00:00
|
|
|
/**
|
2018-01-11 16:37:28 +00:00
|
|
|
* Reference to an HTML5 Audio tag used for playing sound.
|
2018-01-08 18:54:40 +00:00
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @property {HTMLAudioElement} audio
|
|
|
|
* @default null
|
|
|
|
*/
|
2018-01-08 18:54:15 +00:00
|
|
|
this.audio = null;
|
2018-01-11 16:38:47 +00:00
|
|
|
this.duration = this.tags[0].duration;
|
|
|
|
this.totalDuration = this.tags[0].duration;
|
2018-01-08 18:47:13 +00:00
|
|
|
BaseSound.call(this, manager, key, config);
|
2018-01-11 16:40:59 +00:00
|
|
|
},
|
|
|
|
play: function (markerName, config) {
|
|
|
|
if (!BaseSound.prototype.play.call(this, markerName, config)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// TODO implement play method
|
|
|
|
this.events.dispatch(new SoundEvent(this, 'SOUND_PLAY'));
|
|
|
|
return true;
|
2018-01-11 16:42:18 +00:00
|
|
|
},
|
|
|
|
pause: function () {
|
|
|
|
if (!BaseSound.prototype.pause.call(this)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// TODO implement pause method
|
|
|
|
this.events.dispatch(new SoundEvent(this, 'SOUND_PAUSE'));
|
|
|
|
return true;
|
2018-01-11 16:43:56 +00:00
|
|
|
},
|
|
|
|
resume: function () {
|
|
|
|
if (!BaseSound.prototype.resume.call(this)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// \/\/\/ isPlaying = true, isPaused = false \/\/\/
|
|
|
|
// TODO implement resume method
|
|
|
|
this.events.dispatch(new SoundEvent(this, 'SOUND_RESUME'));
|
|
|
|
return true;
|
2018-01-11 16:45:02 +00:00
|
|
|
},
|
|
|
|
stop: function () {
|
|
|
|
if (!BaseSound.prototype.stop.call(this)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// \/\/\/ isPlaying = false, isPaused = false \/\/\/
|
|
|
|
// TODO implement stop method
|
|
|
|
this.events.dispatch(new SoundEvent(this, 'SOUND_STOP'));
|
|
|
|
return true;
|
2018-01-11 16:47:01 +00:00
|
|
|
},
|
|
|
|
update: function (time, delta) {
|
|
|
|
|
2018-01-11 16:48:23 +00:00
|
|
|
},
|
|
|
|
destroy: function () {
|
|
|
|
BaseSound.prototype.destroy.call(this);
|
|
|
|
// TODO release all HTML5 Audio tag related stuff
|
2018-01-11 16:49:40 +00:00
|
|
|
},
|
|
|
|
setMute: function () {
|
|
|
|
if (this.audio) {
|
|
|
|
this.audio.muted = this.currentConfig.mute || this.manager.mute;
|
|
|
|
}
|
2018-01-11 16:50:20 +00:00
|
|
|
},
|
|
|
|
setVolume: function () {
|
|
|
|
if (this.audio) {
|
|
|
|
this.audio.volume = this.currentConfig.volume * this.manager.volume;
|
|
|
|
}
|
2018-01-11 16:51:58 +00:00
|
|
|
},
|
|
|
|
setRate: function () {
|
|
|
|
BaseSound.prototype.setRate.call(this);
|
|
|
|
if (this.audio) {
|
|
|
|
this.audio.playbackRate = this.totalRate;
|
|
|
|
}
|
2018-01-08 18:47:13 +00:00
|
|
|
}
|
|
|
|
});
|
2018-01-11 16:55:05 +00:00
|
|
|
/**
|
|
|
|
* Mute setting.
|
|
|
|
*
|
|
|
|
* @name Phaser.Sound.HTML5AudioSound#mute
|
|
|
|
* @property {boolean} mute
|
|
|
|
*/
|
|
|
|
Object.defineProperty(HTML5AudioSound.prototype, 'mute', {
|
|
|
|
get: function () {
|
|
|
|
return this.currentConfig.mute;
|
|
|
|
},
|
|
|
|
set: function (value) {
|
|
|
|
this.currentConfig.mute = value;
|
|
|
|
this.setMute();
|
|
|
|
this.events.dispatch(new SoundValueEvent(this, 'SOUND_MUTE', value));
|
|
|
|
}
|
|
|
|
});
|
2018-01-11 16:57:04 +00:00
|
|
|
/**
|
|
|
|
* Volume setting.
|
|
|
|
*
|
|
|
|
* @name Phaser.Sound.HTML5AudioSound#volume
|
|
|
|
* @property {number} volume
|
|
|
|
*/
|
|
|
|
Object.defineProperty(HTML5AudioSound.prototype, 'volume', {
|
|
|
|
get: function () {
|
|
|
|
return this.currentConfig.volume;
|
|
|
|
},
|
|
|
|
set: function (value) {
|
|
|
|
this.currentConfig.volume = value;
|
|
|
|
this.setVolume();
|
|
|
|
this.events.dispatch(new SoundValueEvent(this, 'SOUND_VOLUME', value));
|
|
|
|
}
|
|
|
|
});
|
2018-01-11 16:58:26 +00:00
|
|
|
/**
|
|
|
|
* Current position of playing sound.
|
|
|
|
*
|
|
|
|
* @name Phaser.Sound.HTML5AudioSound#seek
|
|
|
|
* @property {number} seek
|
|
|
|
*/
|
|
|
|
Object.defineProperty(HTML5AudioSound.prototype, 'seek', {
|
|
|
|
get: function () {
|
|
|
|
if (this.isPlaying) {
|
|
|
|
return this.audio.currentTime;
|
|
|
|
}
|
|
|
|
else if (this.isPaused) {
|
|
|
|
return this.currentConfig.seek;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2018-01-08 18:47:13 +00:00
|
|
|
module.exports = HTML5AudioSound;
|