phaser/examples/display/render texture starfield.js

81 lines
1.9 KiB
JavaScript

var game = new Phaser.Game(800, 600, Phaser.AUTO, 'phaser-example', { preload: preload, create: create, update: update });
function preload() {
game.load.image('star', 'assets/sprites/bullet.png');
}
var star;
var texture1;
var texture2;
var texture3;
var stars = [];
function create() {
// This is the sprite that will be drawn to the texture, we set it to visible false as we only need its texture data.
star = game.add.sprite(0, 0, 'star');
star.visible = false;
// For this effect we'll create a vertical scrolling starfield with 300 stars split across 3 layers.
// This will use only 3 textures / sprites in total.
texture1 = game.add.renderTexture('texture1', 800, 600);
texture2 = game.add.renderTexture('texture2', 800, 600);
texture3 = game.add.renderTexture('texture3', 800, 600);
game.add.sprite(0, 0, texture1);
game.add.sprite(0, 0, texture2);
game.add.sprite(0, 0, texture3);
var t = texture1;
var s = 4;
// 100 sprites per layer
for (var i = 0; i < 300; i++)
{
if (i == 100)
{
// With each 100 stars we ramp up the speed a little and swap to the next texture
s = 6;
t = texture2;
}
else if (i == 200)
{
s = 7;
t = texture3;
}
stars.push( { x: game.world.randomX, y: game.world.randomY, speed: s, texture: t });
}
}
function update() {
for (var i = 0; i < 300; i++)
{
// Update the stars y position based on its speed
stars[i].y += stars[i].speed;
if (stars[i].y > 600)
{
// Off the bottom of the screen? Then wrap around to the top
stars[i].x = game.world.randomX;
stars[i].y = -32;
}
if (i == 0 || i == 100 || i == 200)
{
// If it's the first star of the layer then we clear the texture
stars[i].texture.renderXY(star, stars[i].x, stars[i].y, true, true);
}
else
{
// Otherwise just draw the star sprite where we need it
stars[i].texture.renderXY(star, stars[i].x, stars[i].y, false, true);
}
}
}