Home / Developer  / Game Development  / 2D Game Development  / เขียนเกมบน HTML5 ด้วย Cocos2d X HTML และ JavaScript สร้างตัวละคร

เขียนเกมบน HTML5 ด้วย Cocos2d X HTML และ JavaScript สร้างตัวละคร

เริ่มต้นเขียนเกมบน HTML5 ด้วย Framework ที่ชื่อ Cocos2D X สำหรับ HTML5 ด้วยภาษาโปรแกรม JavaScript ให้เล่นได้ทุกอุปกรณ์ทั้งเว็บและสมาร์ทโฟนCocos2d HTML5 นั้นจะเน้นการทำงานบน Javascript เป็นหลักครับ ซึ่งแตกต่างจาก Cocos2D บน iPhone ยังไงก็ขออธิบายคร่าวๆ ว่า จริงๆแล้ว Cocos2D ที่เราใช้พัฒนาเกมบน iPhone หรือ Android นั้นการทำงานหลักๆของมันใช้ Library ที่เรียกว่า SoiderMonkey ครับซึ่งมันจะเรียกการทำงานผ่าน Javascript ทำงานแบบเบื้องหลัง

แกน Core ของ Cocos2D คือ Javascript

แกน Core ของ Cocos2D คือ Javascript

นั่นคือเอา Framework Cocos2D ปรกติที่เขียนด้วย Objective C ไปเรียก Javascript อีกที ดังนั้นไม่แปลกครับ ถ้า Cocos2D Javascript จะเน้น Javascript ได้ซึ่งแตกต่างแค่เรื่องของ Syntax การเขียนคำสั่งแค่นั้นเองครับ
การพัฒนาเกมบน Cocos2D HTML5 จึงไม่แตกต่างกับการพัฒนาเกมบน Cocos2D บน iPhone แน่นอนครับ เน้นหลักคือเราต้องมายัด Javascript เป็นภาษาหลักนั่นเอง

เริ่มต้นพัฒนาเกมบน HTML5 ด้วย Framework Cocos2D HTML5 และ Cocos2D Javascript
เข้าเว็บไซต์ http://www.cocos2d-x.org/projects/cocos2d-x/wiki/Download เพื่อทำการดาวน์โหลดเวอร์ชันล่สุดของ Cocos2D-X HTML5 ครับ ขนาดของไฟล์อยู่ที่ 67.4 MB (ใหญ่เล็กน้อย)
หลังจากนั้นให้ทำการแตก Folder ออกมาครับ

ดาวน์โหลด framework มาก่อน

ดาวน์โหลด framework มาก่อน

ตัวอย่างของทางที่ Cocos2D HTML5 แถมมาให้นั้นมีอยู่ใน Folder Samples ครับลองเข้าไปเล่นได้

ไฟล์ทั้งหมดของ Cocos2d X

ไฟล์ทั้งหมดของ Cocos2d X

แต่สำหรับเกมของเรานั้นผมแนะนำให้สร้าง Folder ขึ้นมาใหม่ครับ คนละ Path บนเครื่องเลยก็ได้ ในตัวอย่างผมสร้าง Folder ขึ้นมาว่า “html5game”
หลังจากนั้นเข้าไปสร้าง Folder ใหม่ขึ้นมาใน “htm5game” ว่า “Src” ครับ

เปิดเข้าไปใน Folder “Src” ให้สร้างไฟล์ขึ้นมาว่า “resurce.js” ครับ
Path ที่ถูกต้องจะเป็น “html5game/Src/resource.js” เปิดโปรแกรม Text Editor ขึ้นมาครับใส่คำสั่ง JavaScript ลงไปตามนี้

ดังนั้นคำสั่งที่กำหนดขึ้นนั้นคือการจำค่า Folder ที่จะเก็บภาพกราฟิกที่ใช้ในเกมนั่นคือ Folder ที่เราต้องสร้างเข้าไปใหม่ ผมตั้งชื่อว่า “Graphics”
Path ที่ถูกต้องจะเป็น “html5game/Graphics”

โดยมี Resource ที่เราจะใช้คือกราฟิกของตัวละคร ในที่นี้ผมใช้ภาพกราฟิกนามสกุล .png ตั้งชื่อว่า gameplayer.png เก็บลงในตัวแปล s_player โดยมีการเรียก Path ของ Folder ไปที่ Graphics/gameplyer.png
ผมได้เตรียมภาพกราฟิกไว้แล้วคือภาพนี้ ไฟล์ภาพ gameplayer.png

gameplayer.png

gameplayer.png

ต่อมาให้ทำการสร้างคำงในการดึงภาพกราฟิกมาปรากฏ ให้ทำการเข้าไปที่ Folder “Src” แล้วสร้างไฟล์ใหม่ชื่อว่า “ManLayer.js” แล้วใส่คำสั่งต่อไปนี้

เป็นการสร้าง คลาสใหม่ขึ้นมาชื่อว่า MainLayer ซึงเป็น Library ของ Cocos2D อยู่แล้วขึ้นมา
การโหลดกราฟิกตัวละครจากไฟล์ Src/resource.js ในส่วนของ

นั้นจะถูก MainLayer เรียกผ่านตัวแปร player ตามนี้

ส่วนคำสั่งในการแสดงผลกราฟิกนั้นเหมือน Cocos2D ทุกอย่างครับคือ

his.addChild(player);

เป็นการเรียก Sprite ภาพขึ้นไป

ต่อมาให้เพิ่ม Method เพิ่มเข้าไปสำหรับ สร้าง Layer บนหน้าเว็บ HTML5 ครับ ในบรรทัด //Method ให้เพิ่ม Method ต่อไปนี้

ต่อมาให้เปิดไปที่ Folder ไฟล์ Cocos2D HTML5 ที่เราดาวน์โหลดครับ แล้วเลือก Folder ดังต่อไปนี้

  • cocos2d
  • CocosDenshion
  • extensions

ทำการ Copy ไปวางบน Folder เกมของเรานั่นคือ “html5game/Platform/HTML5”

Copy ไปวางใน Folder "Platform/HTML5"

Copy ไปวางใน Folder “Platform/HTML5”

ต่อมาให้สร้างไฟล์ “index.html” ขึ้นมาบน Folder “html5game” ใส่คำสั่ง HTML ตามนี้
Path ที่ถูกต้องจะเป็น “html5game/index.html”

ส่วนที่เราจะแสดงผลคือ Canvas ตัวอย่างเกมนี้ผมจะใช้ขนาดดังต่อไปนี้คือ 800×450 pixels ครับ

ให้สร้างไฟล์ “cocos2d.js” ขึ้นมา Path เดียวกับ index.html
Path ที่ถูกต้องจะเป็น “html5game/cocos2d.js”

เพิ่มคำสั่ง JavaScript ลงไปในไฟล์ cocos2d.js ดังนี้

เข้าไปแก้ไขไฟล์ index.html เพิ่มคำสั่ง ต่อไปนี้ก่อนปิด </body>

ไปที่ Folder “Src” ทำการสร้างไฟล์ JavaScript ขึ้นมาใหม่ตั้ชื่อว่า “Main.js”
Path ที่ถูกต้องจะเป็น “html5game/Src/Main.js”

เพิมคำสั่งต่อไปนี้ลงไป

ทดสอบโปรเจ็คเว็บเกมบน html5 ของเรา โดยการเปิดไฟล์ index.html แล้วดูผลลัพธ์ของเราครับ

เรียกตัว Player มาโชว์ได้แล้ว

เรียกตัว Player มาโชว์ได้แล้ว

ในบทเรียนต่อไปจะเป็นการ เรียกกราฟฟิกศัตรูให้ปรากฏขึ้นมา แะใช้ฟังก์ชัน Interval บังคับให้ศัตรูเลื่อนไปมาในฉากได้ อ่านต่อได้ที่นี่

เขียนเกมบน HTML5 ด้วย Cocos2d X HTML และ JavaScript เพิ่มศัตรู และเวลา

Comments

daydevthailand@gmail.com

อาจารย์ประจำสาขาวิชาการออกแบบเชิงโต้ตอบ และการพัฒนาเกม วิทยาลัยครีเอทีฟดีไซน์ & เอ็นเตอร์เทนเมนต์เทคโนโลยี มหาวิทยาลัยธุรกิจบัณฑิตย์ ,ผู้ก่อตั้ง บริษัท Daydev Co., Ltd, (เดย์เดฟ จำกัด)

Review overview
NO COMMENTS

POST A COMMENT