mirror of
https://github.com/photonstorm/phaser
synced 2025-01-26 03:45:08 +00:00
108 lines
2.6 KiB
JavaScript
108 lines
2.6 KiB
JavaScript
/**
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
*/
|
|
|
|
/**
|
|
* Visibility Handler hidden event.
|
|
*
|
|
* The document in which the Game is embedded has entered a hidden state.
|
|
*
|
|
* @event Phaser.Boot.VisibilityHandler#hidden
|
|
*/
|
|
|
|
/**
|
|
* Visibility Handler visible event.
|
|
*
|
|
* The document in which the Game is embedded has entered a visible state.
|
|
*
|
|
* @event Phaser.Boot.VisibilityHandler#visible
|
|
*/
|
|
|
|
/**
|
|
* Visibility Handler blur event.
|
|
*
|
|
* The window in which the Game is embedded has entered a blurred state.
|
|
*
|
|
* @event Phaser.Boot.VisibilityHandler#blur
|
|
*/
|
|
|
|
/**
|
|
* Visibility Handler focus event.
|
|
*
|
|
* The window in which the Game is embedded has entered a focused state.
|
|
*
|
|
* @event Phaser.Boot.VisibilityHandler#focus
|
|
*/
|
|
|
|
/**
|
|
* The Visibility Handler is responsible for listening out for document level visibility change events.
|
|
* This includes `visibilitychange` if the browser supports it, and blur and focus events. It then uses
|
|
* the provided Event Emitter and fires the related events.
|
|
*
|
|
* @function Phaser.Boot.VisibilityHandler
|
|
* @fires Phaser.Boot.VisibilityHandler#hidden
|
|
* @fires Phaser.Boot.VisibilityHandler#visible
|
|
* @fires Phaser.Boot.VisibilityHandler#blur
|
|
* @fires Phaser.Boot.VisibilityHandler#focus
|
|
* @since 3.0.0
|
|
*
|
|
* @param {Phaser.EventEmitter} eventEmitter - The EventEmitter that will emit the visibility events.
|
|
*/
|
|
var VisibilityHandler = function (eventEmitter)
|
|
{
|
|
var hiddenVar;
|
|
|
|
if (document.hidden !== undefined)
|
|
{
|
|
hiddenVar = 'visibilitychange';
|
|
}
|
|
else
|
|
{
|
|
var vendors = [ 'webkit', 'moz', 'ms' ];
|
|
|
|
vendors.forEach(function (prefix)
|
|
{
|
|
if (document[prefix + 'Hidden'] !== undefined)
|
|
{
|
|
document.hidden = function ()
|
|
{
|
|
return document[prefix + 'Hidden'];
|
|
};
|
|
|
|
hiddenVar = prefix + 'visibilitychange';
|
|
}
|
|
|
|
});
|
|
}
|
|
|
|
var onChange = function (event)
|
|
{
|
|
if (document.hidden || event.type === 'pause')
|
|
{
|
|
eventEmitter.emit('hidden');
|
|
}
|
|
else
|
|
{
|
|
eventEmitter.emit('visible');
|
|
}
|
|
};
|
|
|
|
if (hiddenVar)
|
|
{
|
|
document.addEventListener(hiddenVar, onChange, false);
|
|
}
|
|
|
|
window.onblur = function ()
|
|
{
|
|
eventEmitter.emit('blur');
|
|
};
|
|
|
|
window.onfocus = function ()
|
|
{
|
|
eventEmitter.emit('focus');
|
|
};
|
|
};
|
|
|
|
module.exports = VisibilityHandler;
|