Jumat, 20 Februari 2009

cara buat game

Sudah pernah coba main game Tux yang makan-makanin biskuit? (klo belum tau baca dulu tulisan yang ini) Nah, karena gamenya sederhana ini mudah untuk dipelajari… dan karena Saya lagi baik maka Saya beritahu Anda yang penasaran, berikut ini langkah-langkah pembuatannya:

#1 Persiapan

Buat 3 buah layer untuk memudahkan pembuatan. layer 1 untuk diberikan label frame, layer 2 untuk diisi actionscript, layer 3 tempat kita nanti menyimpan movieclip dan sebagainya. Ingat baik-baik untuk menyimpan pada tempatnya (layer label untuk nyimpen label, klo nulis ActionScript di layer eksyenskrip, dan selain itu semua simpan aja di layer symbols). Sebenernya boleh aja sih disatuin semua di 1 layer… tapi fren, percayalah ini juga demi kerapihan program kita… untuk amannya, layer selain symbols dilock/hide aja.

Sementara itu untuk panjang framenya adalah bebas tapi untuk gampangnya kita buat saja jadi 3 yaitu frame awal untuk tampilan menu, frame berikutnya untuk permainan, dan berikutnya lagi untuk tampilan game over. Jangan lupa untuk tiap frame berikan label ‘menu’, ’permainan’, ‘gameover’ nanti pindah framenya tinggal gotoAndStop(“nama label”); Lihat gambar berikut…

tux001.jpg

Pada game ini untuk memudahkan dalam pengertian maka setiap Saya menulis actionscript di depan tiap objek Saya berikan id untuk mengenali objek apakah itu…

objek dengan awalan mc_ adalah movieclip

objek dengan awalan btn_ adalah tombol (button)

objek dengan awalan so_ adalah SharedObject

#2 Bagian Menu

Untuk tampilan menu awalnya buatlah judul game yang besar-besar…!!! buat juga tombol main dengan nama instance (lihat properties button) ‘btn_main’ (ini tombol untuk melanjutkan permainan) dan tombol keluar dengan nama instance ‘btn_keluar’ (ini tombol untuk keluar).

Kemudian buat juga sebuah dynamic text dengan nama var ‘topsekorer’ (ini disediakan untuk menampilkan top scorer). Adapun untuk bisa menyimpan dan membaca data skor pada flash di komputer kita, kita perlu menggunakan fasilitas SharedObject (baca artikel Saya sebelumnya). misalkan nanti kita simpan 2 buah data di SO tersebut yaitu namaSO.data.nama untuk menyimpan nama dan namaSO.data.skor untuk menyimpan skor.

Setelah semua itu selesai berikan actionscript di frame 1 sebagai berikut:

  1. stop(); //supaya ngga jalan kemana2
  2. var so_skor:SharedObject = SharedObject.getLocal("catatanSkor","/"); //untuk baca dan simpan data skor
  3. var jmlTopSkorer:Number = 5; //jumlah top skorer yg ditampilkan
  4. text_topSkorer.text = "" ; //tampilan skor di dynamic text
  5. /* ****************************************
  6. pada SharedObject so_skor ada beberapa data yang disimpan yaitu:
  7. - topSkor dari 1 sampai 6 (so_skor.data.topSkor1, so_skor.data.topSkor2, so_skor.data.topSkor3,...dst)
  8. - namaTopSkorer dari 1 sampai 6 (sama seperti diatas, sebenarnya yg dipakai cuman 5 skor, yang ke-6 untuk temp aja :)
  9. - input nama terakhir (supaya otomatis terisi ketika game over)
  10. **************************************** */
  11. if( so_skor.data.topSkor1 == undefined) //fungsi ini cuma dipakai pertama kali untuk reset skor
  12. {
  13. for(i=1; i<=jmlTopSkorer; i++){
  14. so_skor.data["topSkor"+i]=1500/i;
  15. so_skor.data["namaTopSkorer"+i]="Faisalman";
  16. }
  17. }
  18. /**************************************************************
  19. // untuk menampilkan top skor di dynamic text yg ada di stage :
  20. ***************************************************************/
  21. for (i = 1; i <= jmlTopSkorer; i++) {
  22. text_topSkorer.text = text_topSkorer.text + "\\n" + eval("so_skor.data.namaTopSkorer"+i) + " " + eval("so_skor.data.topSkor"+i);
  23. }
  24. /* ****************************************
  25. // perintah ketika tombol main ditekan :
  26. **************************************** */
  27. btn_main.onPress = function(){
  28. gotoAndStop("permainan");
  29. }
  30. /* ****************************************
  31. //perintah ketika tombol keluar ditekan :
  32. **************************************** */
  33. btn_keluar.onPress = function(){
  34. fscommand("quit",true);
  35. }
  36. /* **************************************************
  37. //kalau mau ada tombol utk reset skor :
  38. btn_reset.onPress = function(){
  39. so_skor.clear();
  40. }
  41. ****************************************************** */

#3 Bagian Permainan

Sesudah selesai membuat menu awal selanjutnya kita buat bagian permainan, seperti yang kita tahu inilah sebenarnya inti dari program yang sedang kita buat. Baiklah langsung saja siapkan tokoh-tokohnya: Tux si pinguin, makanan favoritnya (tulang ikan), dan bom. Anda bisa buat sendiri atau pakai yang sudah Saya buat saja (hasil tracing) seperti di bawah ini…

tux3.JPG

Alasan mengapa gambarnya Saya jadikan vektor adalah supaya pada saat bermain nanti eksekusinya jauh lebih ringan dibanding jika memakai begitu saja gambar bitmap hasil import (tidak percaya silahkan coba sendiri bedanya). lihat saja hasil .swf-nya saudara-saudara… game ini besarnya hanya 8 kilobyte jika dimainkan langsung dengan flash (lihat di bawah).

.

.

By the way anyway busway (halah), jangan lupa masing-masing objek itu dijadikan movieclip (klik kanan objek > convert to symbol … atau klik objek menu>modify>convert to symbol) beri nama apapunlah misalkan pinguin, ikan, atau bom. kemudian beri nama instance (lihat properties movieclip) ‘mc_tux’ pada si pinguin, ‘mc_ikan_1’ pada si tulang ikan, dan ‘mc_bom_1’ pada bom.

Kemudian bagian terpenting dari yang penting di game ini adalah rangkaian actionscript berikut (ingat untuk menyimpannya di layer eksyenskrip)

.

.

.

.

.

.

.

.

jreng jreng jreng!!!

artikel ini belum selesai, bersambung ah… biar pada penasaran. insyaAllah nanti diterusin lagi nulisnya kalau ada waktu senggang, akhir-akhir ini masih sangat sibuk


===========================================

UPDATE 16 Oktober 2007

skrip untuk disimpan di frame ‘permainan’:

  1. stop(); //supaya ngga jalan kemana2
  2. var vLevel:Number = 0; //current level dari game (pertama kali level 0)
  3. var vSkor:Number = 0; //jumlah skor
  4. var vNyawa:Number = 5; //jumlah nyawa dari pinguin
  5. var vJumlahLevel:Number = 8; //jumlah level dari game ini
  6. var vSkorIkan:Number = 10; //skor kalau dapet ikan
  7. var vSkorBom:Number = -25; //skor kalau kena bom
  8. var vSkorMinUtkNaikStage:Number = 250; //setiap dapat 250 poin, naik ke level berikutnya
  9. /* *******************************************************************
  10. // fungsi untuk menggerakkan pinguin dengan keyboard :
  11. // (onEnterFrame menjadikan fungsi ini dipanggil sesuai jumlah fps)
  12. ******************************************************************* */
  13. mc_tux.onEnterFrame = function() {
  14. vtPosisiX = this._x;
  15. vtPosisiY = this._y;
  16. if (Key.isDown(Key.UP)){
  17. this._y -= 15;
  18. }
  19. if (Key.isDown(Key.DOWN)){
  20. this._y += 15;
  21. }
  22. if (Key.isDown(Key.LEFT)){
  23. this._x -= 15;
  24. }
  25. if (Key.isDown(Key.RIGHT)){
  26. this._x += 15;
  27. }
  28. if (this._x<0>this._x > (Stage.width - this._width)){
  29. this._x = vtPosisiX;
  30. }
  31. if (this._y<0>this._y > (Stage.height - this._height)){
  32. this._y = vtPosisiY;
  33. }
  34. }
  35. /* **************************************************************************
  36. // fungsi-fungsi berikut inilah yang mengkolaborasikan semua objek disini :
  37. // (karena bingung menempatkannya, jadi saya urutkan saja sesuai abjad)
  38. ************************************************************************** */
  39. //fungsi yg dipanggil pada saat game over
  40. fGameOver = function() {
  41. for (i = 1; i < (vJumlahLevel + 2); i++) {
  42. removeMovieClip(eval("mc_ikan"+i));
  43. removeMovieClip(eval("mc_bom"+i))
  44. removeMovieClip(eval("mc_bom"+i+"meledak"));
  45. }
  46. gotoAndStop("gameover");
  47. }
  48. //ini untuk mendeteksi adanya tabrakan pinguin dengan ikan atau bom
  49. fDeteksiKejadian = function(vtNamaBaru, vtPoin, vtBelumKena) {
  50. /****************************************
  51. fungsi dalam if ini hanya akan dijalankan
  52. kalau ikan atau bom tsb menabrak pinguin
  53. dan juga objek tsb harus visible :
  54. *****************************************/
  55. if(vtNamaBaru.hitTest(mc_tux) && vtNamaBaru.vtBelumKena) {
  56. vSkor += vtPoin;
  57. if(vSkor == (vSkorMinUtkNaikStage * vLevel)){
  58. fNaikStage();
  59. fTampilanLevel("Level "+vLevel);
  60. } else {
  61. fTampilanLevel("");
  62. }
  63. /************************
  64. membuat efek ledakan :
  65. ************************/
  66. if(vtPoin!=vSkorIkan){
  67. vNyawa-=1;
  68. duplicateMovieClip(mc_duarr,eval(vtNamaBaru+"meledak"),this.getNextHighestDepth());
  69. setProperty(eval(vtNamaBaru+"meledak"),_x,getProperty(mc_tux,_x));
  70. setProperty(eval(vtNamaBaru+"meledak"),_y,getProperty(mc_tux,_y));
  71. } else {
  72. removeMovieClip(eval(vtNamaBaru+"meledak"));
  73. }
  74. vtNamaBaru.vtBelumKena = false;
  75. vtNamaBaru._visible = false;
  76. }
  77. }
  78. //setiap kali pindah level, movieclip ikan dan bom akan diduplikasi
  79. fKloning = function(vtNama_mc, vtBanyak, vtPoin) {
  80. for (i=1; i
  81. var vtNamaBaru:String = vtNama_mc+i;
  82. duplicateMovieClip(vtNama_mc, vtNamaBaru, this.getNextHighestDepth());
  83. setProperty(vtNamaBaru, _x, random(Stage.width));
  84. setProperty(vtNamaBaru, _y, Stage.height);
  85. fNaikTurun(vtNamaBaru,5+random(5*vLevel),vtPoin);
  86. }
  87. removeMovieClip(eval(vtNama_mc+(vtBanyak)));
  88. }
  89. //klo naik level...
  90. fNaikStage = function() {
  91. vLevel += 1;
  92. fKloning("mc_ikan",(vJumlahLevel-vLevel),vSkorIkan);
  93. fKloning("mc_bom",(vLevel+1),vSkorBom);
  94. }
  95. //fungsi untuk menggerakkan hujan ikan2 dan bom2
  96. fNaikTurun = function(vtNamaBaru, vtKecepatan, vtPoin) {
  97. var vtBelumKena:Boolean = true;
  98. eval(vtNamaBaru).onEnterFrame = function(){
  99. //fungsi ini dipanggil setiap enterFrame
  100. if((vLevel > vJumlahLevel) || (vNyawa <>
  101. fGameOver();
  102. }
  103. setProperty(this, _y, getProperty(this, _y) + vtKecepatan);
  104. fDeteksiKejadian(eval(vtNamaBaru),vtPoin,vtBelumKena);
  105. if (this._y > (Stage.height+60)) {
  106. setProperty(this, _y, (random(Stage.height))-(Stage.height));
  107. setProperty(this, _x, random(Stage.width));
  108. this.vtBelumKena = true;
  109. this._visible = true;
  110. }
  111. }
  112. }
  113. //untuk tampilan level di stage
  114. fTampilanLevel = function(vtString) {
  115. txt_level.text=vtString;
  116. }
  117. fNaikStage(); //fungsi ini dipanggil sekali untuk naik ke level 1 (inisialisasi level = 0)

skrip untuk disimpan di frame ‘game over’:

  1. stop(); //supaya ngga jalan kemana2
  2. var vInputNamaTerakhir:String = so_skor.data.namaTerakhir;
  3. var vJuaraKe:Number = 6;
  4. var j:Number = jmlTopSkorer; // variabel jmlTopSkorer dideklarasi di frame 1
  5. // fungsi ini dijalankan jika tombol OK ditekan :
  6. btn_ok.onPress=function()
  7. {
  8. //bandingkan dengan skor hasil dg skor yg ada (untuk menentukan peringkat)
  9. for(i=5; i>=1; i--) {
  10. if(vSkor > eval("so_skor.data.topSkor"+i)){
  11. vJuaraKe = i
  12. }
  13. }
  14. //fungsi while ini hanya dijalankan jika skor hasil lebih besar dari skor yg ada
  15. while (vJuaraKe <= j) {
  16. so_skor.data["topSkor"+j] = so_skor.data["topSkor"+(j-1)];
  17. so_skor.data["namaTopSkorer"+j] = so_skor.data["namaTopSkorer"+(j-1)];
  18. j-=1;
  19. }
  20. so_skor.data["topSkor"+vJuaraKe] = vSkor;
  21. so_skor.data["namaTopSkorer"+vJuaraKe] = text_namaSkorer.text;
  22. so_skor.data.namaTerakhir = text_namaSkorer.text; //simpan nama pemain
  23. so_skor.flush(); //tulis data ke so_skor
  24. }

Peringatan : ActionScript diatas hanya buatan Saya saja sehingga wajar klo terlihat berantakan dan belepotan :mrgreen: , jadi silahkan perbaiki dan improvisasikan dengan kreasi sendiri… (klo script di wordpress ini beda dengan script di file .fla-nya, maka script di file .fla-nya yang benar karena paling akhir diupdate). Source .fla-nya sendiri ini bisa diunduh di http://tinyurl.com/F4154LMAN-game-cupu-source, untuk yang udah jadinya lihat di http://faisalman.wordpress.com/2007/08/02/ayo-buat-game-sendiri/




0 komentar:

Template by : Kendhin x-template.blogspot.com