Build games as easily as you play them — join the Phaser Beam waitlist for Early Access.
var config = { type: Phaser.AUTO, parent: 'phaser-example', width: 800, height: 600, backgroundColor: '#2d2d2d', scene: { preload: preload, create: create, extend: { createPiano: createPiano } } }; var game = new Phaser.Game(config); function preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v355'); this.load.setPath('assets/tests/piano'); this.load.atlas('piano', 'piano.png', 'piano.json'); this.load.audio('C3', 'C3.mp3'); this.load.audio('Db3', 'Db3.mp3'); this.load.audio('D3', 'D3.mp3'); this.load.audio('Eb3', 'Eb3.mp3'); this.load.audio('E3', 'E3.mp3'); this.load.audio('F3', 'F3.mp3'); this.load.audio('Gb3', 'Gb3.mp3'); this.load.audio('G3', 'G3.mp3'); this.load.audio('Ab3', 'Ab3.mp3'); this.load.audio('A3', 'A3.mp3'); this.load.audio('Bb3', 'Bb3.mp3'); this.load.audio('B3', 'B3.mp3'); } function create () { if (this.sound.locked) { var text = this.add.text(10, 10, 'Tap to unlock audio', { font: '16px Courier', fill: '#00ff00' }); this.sound.once('unlocked', function () { text.destroy(); this.createPiano(); }, this); } else { this.createPiano(); } } function createPiano () { this.input.addPointer(9); var x = 100; var y = 0; this.add.image(x, y, 'piano', 'panel').setOrigin(0); var keys = [ [ 'key1', 'C3' ], [ 'key2', 'Db3' ], [ 'key3', 'D3' ], [ 'key4', 'Eb3' ], [ 'key5', 'E3' ], [ 'key6', 'F3' ], [ 'key7', 'Gb3' ], [ 'key8', 'G3' ], [ 'key9', 'Ab3' ], [ 'key10', 'A3' ], [ 'key11', 'Bb3' ], [ 'key12', 'B3' ] ]; var black = [ 'key2', 'key4', 'key7', 'key9', 'key11' ]; for (var i = 0; i < keys.length; i++) { var key = keys[i][0]; var note = keys[i][1]; var singleKey = this.add.image(x, y, 'piano', key); singleKey.setName(note); singleKey.setOrigin(0); if (black.indexOf(key) !== -1) { singleKey.setDepth(1); } var frame = singleKey.frame; var hitArea = new Phaser.Geom.Rectangle(frame.x, frame.y, frame.width, frame.height); singleKey.setInteractive(hitArea, Phaser.Geom.Rectangle.Contains); var sound = this.sound.add(note); singleKey.on('pointerdown', function (sound) { sound.play(); }.bind(this, sound)); singleKey.on('pointerover', function (sound, pointer) { if (pointer.isDown) { sound.play(); } }.bind(this, sound)); } }
var config = {
type: Phaser.AUTO,
parent: 'phaser-example',
width: 800,
height: 600,
backgroundColor: '#2d2d2d',
scene: {
preload: preload,
create: create,
extend: {
createPiano: createPiano
}
}
};
var game = new Phaser.Game(config);
function preload ()
{
this.load.setBaseURL('https://cdn.phaserfiles.com/v355');
this.load.setPath('assets/tests/piano');
this.load.atlas('piano', 'piano.png', 'piano.json');
this.load.audio('C3', 'C3.mp3');
this.load.audio('Db3', 'Db3.mp3');
this.load.audio('D3', 'D3.mp3');
this.load.audio('Eb3', 'Eb3.mp3');
this.load.audio('E3', 'E3.mp3');
this.load.audio('F3', 'F3.mp3');
this.load.audio('Gb3', 'Gb3.mp3');
this.load.audio('G3', 'G3.mp3');
this.load.audio('Ab3', 'Ab3.mp3');
this.load.audio('A3', 'A3.mp3');
this.load.audio('Bb3', 'Bb3.mp3');
this.load.audio('B3', 'B3.mp3');
}
function create ()
{
if (this.sound.locked)
{
var text = this.add.text(10, 10, 'Tap to unlock audio', { font: '16px Courier', fill: '#00ff00' });
this.sound.once('unlocked', function ()
{
text.destroy();
this.createPiano();
}, this);
}
else
{
this.createPiano();
}
}
function createPiano ()
{
this.input.addPointer(9);
var x = 100;
var y = 0;
this.add.image(x, y, 'piano', 'panel').setOrigin(0);
var keys = [
[ 'key1', 'C3' ],
[ 'key2', 'Db3' ],
[ 'key3', 'D3' ],
[ 'key4', 'Eb3' ],
[ 'key5', 'E3' ],
[ 'key6', 'F3' ],
[ 'key7', 'Gb3' ],
[ 'key8', 'G3' ],
[ 'key9', 'Ab3' ],
[ 'key10', 'A3' ],
[ 'key11', 'Bb3' ],
[ 'key12', 'B3' ]
];
var black = [ 'key2', 'key4', 'key7', 'key9', 'key11' ];
for (var i = 0; i < keys.length; i++)
{
var key = keys[i][0];
var note = keys[i][1];
var singleKey = this.add.image(x, y, 'piano', key);
singleKey.setName(note);
singleKey.setOrigin(0);
if (black.indexOf(key) !== -1)
{
singleKey.setDepth(1);
}
var frame = singleKey.frame;
var hitArea = new Phaser.Geom.Rectangle(frame.x, frame.y, frame.width, frame.height);
singleKey.setInteractive(hitArea, Phaser.Geom.Rectangle.Contains);
var sound = this.sound.add(note);
singleKey.on('pointerdown', function (sound)
{
sound.play();
}.bind(this, sound));
singleKey.on('pointerover', function (sound, pointer)
{
if (pointer.isDown)
{
sound.play();
}
}.bind(this, sound));
}
}