Home » » Tutorial Membuat Game Sederhana dengan Framework Phaser

Tutorial Membuat Game Sederhana dengan Framework Phaser

Posted by Droid Flashpedia on Tuesday, March 7, 2017

Tutorial Membuat Game Sederhana dengan Framework Phaser
Tutorial membuat game dengan framework phaser


Tutorial Membuat Game Sederhana dengan Framework Phaser - Masih membahas tentang tutorial membuat game html 5 menggunakan framework phaser. Kali ini kita akan membahas lebih dalam lagi tentang pemrograman game berbasis html 5 dengan framework phaser. Game yang akan dibuat di sini merupakan game sederhana dengan framework phaser, yang mana kita akan berlatih cara membuat layout dalam phaser, membuat sprite untuk karakter, membuat background game dan melakukan kontrol terhadap karakter.

Tutorial Membuat Game dengan Framework Phaser


Untuk membuat game dengan framework phaser, terlebih dahulu buatlah folder dengan nama tutor2 di htdoc. kemudian di dalam folder tutor2 buatlah folder lagi dengan nama assets dan js.
Struktur folder tutor


Setelah kita membuat folder tutor beserta sub foldernya, selanjutnya kita akan memulai membuat game sederhana dengan framework phaser, langkahnya adalah sebagai berikut :

1. Copy-kan file phaser.min.js yang berada pada folder build phaser ke dalam folder js yang berada pada folder tutor2 yang kita buat tadi.

2. Kemudian setelah kita meng-copy file phaser.min.js kemudian kita cari file asset yang kita butuhkan untuk membuat game. untuk mudahnya file tersebut penulis sediakan di sini.

File dude.png

File platform.png

File sky.png

File star.png


3. Taruh file-file asset tersebut ke dalam folder assets. Dan kemudian kita akan mulai menuliskan code untuk game phaser.

4. Buatlah file latihan1.html, kemudian kita tulis code berikut ini.

<!doctype html>

<html lang="en">

<head>

<meta charset="UTF-8" />

<title>Membuat Game Sederhana</title>

<script type="text/javascript" src="js/phaser.min.js"></script>

    <style type="text/css">

        body {

            margin: 0;

        }

    </style>

</head>

<body>



<script type="text/javascript">



var game = new Phaser.Game(800, 600, Phaser.AUTO, '', { preload: preload, create: create, update: update });



function preload() {

//Load gambar dan spritesheet

game.load.image('sky', 'assets/sky.png');

game.load.image('ground', 'assets/platform.png');

game.load.image('star', 'assets/star.png');

game.load.spritesheet('dude', 'assets/dude.png', 32, 48);

}



var platforms;

var player;

var cursors;



var stars;

var score = 0;

var scoreText;



function create() {

//menggunakan physics untuk membuat objek membunyai efek gravitasi

game.physics.startSystem(Phaser.Physics.ARCADE);



//menambahkan background sky

game.add.sprite(0, 0, 'sky');



//membuat grup untuk mengelompokkan objek

platforms = game.add.group();



//mengaktifkan physics untuk semua objek yang ada pada platforms

platforms.enableBody = true;



//membuat ground

var ground = platforms.create(0, game.world.height - 64, 'ground');



//mengatur lebar agar sesuai dengan lebar game

ground.scale.setTo(2, 2);



//Fungsi agar tidak akan terjatuh saat objek karakter berada di atas ground

ground.body.immovable = true;



//membuat dua buah ledges

var ledge = platforms.create(400, 400, 'ground');

ledge.body.immovable = true;



ledge = platforms.create(-150, 250, 'ground');

ledge.body.immovable = true;



//settingan untuk player

player = game.add.sprite(32, game.world.height - 150, 'dude');



//mengaktifkan physics pada player

game.physics.arcade.enable(player);



//pengaturan properties untuk physics. Memberikan karakter dapat memantul

player.body.bounce.y = 0.2;

player.body.gravity.y = 300;

player.body.collideWorldBounds = true;



//membuat player dapat berjalan ke kanan dan kiri

player.animations.add('left', [0, 1, 2, 3], 10, true);

player.animations.add('right', [5, 6, 7, 8], 10, true);



//membuat sprite bintang

stars = game.add.group();



//mengaktifkan physics untuk stars

stars.enableBody = true;



// membuat 12 bintang di layar

for (var i = 0; i<12; i++) {

//membuat star dari grup stars

var star = stars.create(i * 70, 0, 'star');



//menambahkan gravity untuk star

star.body.gravity.y = 300;



//membuat nilai random untuk tiap bintang

star.body.bounce.y = 0.7 + Math.random() * 0.2;

}



//menambahkan score pada game

scoreText = game.add.text(16, 16, 'Score: 0', {fontSize:'32px', fill: '#000'});



//membuat kontrol karakter

cursors = game.input.keyboard.createCursorKeys();



}



function update() {

// Collide player dan stars dengan platforms

game.physics.arcade.collide(player, platforms);

game.physics.arcade.collide(stars, platforms);



//melakukan cek apabila player bersentuhan dengan star, dan melakukan fungsi collectStar

game.physics.arcade.overlap(player, stars, collectStar, null, this);



// reset player velocity

player.body.velocity.x = 0;



if (cursors.left.isDown) {

//bergerak ke kiri

player.body.velocity.x = -150;

player.animations.play('left');



} else if (cursors.right.isDown) {

//bergerak ke kanan

player.body.velocity.x = 150;

player.animations.play('right');

} else {

//tidak bergerak

player.animations.stop();

player.frame = 4;

}



//memberikan player kemampuan untuk melompat apabila tombol arrow atas ditekan

if (cursors.up.isDown && player.body.touching.down) {

player.body.velocity.y = -350;

}

}



function collectStar (player, star) {

//menghilangkan sprite bintang dari layar

star.kill();



//melakukan update pada score saat fungsi collectStar

score += 5;

scoreText.text = 'Score: ' + score;

}





</script>



</body>

</html>


5. Tampilan dari game yang sudah kita buat akan tampil seperti berikut setelah dijalankan pada local web server.
Tampilan game


Dalam code di atas terdapat fungsi-fungsi tambahan seperti fungsi update dan fungsi collectStar, fungsi-fungsi tersebut merupakan fungsi javascript tambahan yang kita butuhkan untuk melakukan berbagai macam aksi terhadap karakter yang ada pada game yang kita buat.

Apabila kawan-kawan masih bingung tentang langkah-langkah membuat game di atas, berikut ini ada video tutorial tentang pembutan game dengan framework phaser.





Demikian artikel tentang Tutorial Membuat Game Sederhana dengan Framework Phaser, meskipun tutorial ini sangat sederhana sekali semoga tutorial ini bisa bermanfaat. Bagi yang kurang jelas tentang bagaimana membuat game menggunakan framework phaser seperti contoh di atas, kawan-kawan bisa mendownload file-nya DI SINI.


0 comments:

Post a Comment

Popular Posts

Blog Archive

.comment-content a {display: none;}