บทความชุดนี้มีจุดประสงค์เพื่อเป็นแหล่งข้อมูลเริ่มต้นสำหรับผู้ที่สนใจพัฒนาแอพบน Windows 8 ซึ่งเป็นเทคโนโลยีการพัฒนาซอฟต์แวร์แบบใหม่ที่เพิ่งเผยแพร่สู่ตลาดพร้อมกับ Windows 8 และยังขาดเอกสารหรือคู่มือภาษาไทยอีกมาก
บทความชุดนี้ได้รับการสนับสนุนจากบริษัทไมโครซอฟท์ ประเทศไทย จำกัด แต่เนื้อหาทั้งหมดเขียนโดยทีมงาน Blognone
แอพบน Windows 8 (เดิมทีเรียก Metro app แต่ภายหลังไมโครซอฟท์เปลี่ยนคำเรียกเป็น Windows Store app) ต่างไปจากแอพบนวินโดวส์แบบเดิมๆ มาก โดยมีลักษณะคล้ายกับแอพบนอุปกรณ์พกพามากกว่า
เทคโนโลยีเบื้องหลังของแอพเหล่านี้คือ WinRT ซึ่งเป็น API ชุดใหม่ที่เพิ่งมีใน Windows 8 และเทียบได้ใกล้เคียงกับ Win32 API ในวินโดวส์รุ่นก่อนๆ
รายละเอียดของ WinRT อ่านเพิ่มเติมได้จากบทความเก่าของ Blognone คือ รู้จักกับ Metro Style App และ WinRT คู่หูของการพัฒนาโปรแกรมบน Windows 8
การพัฒนาแอพบน Windows 8 สามารถเลือกภาษาโปรแกรมได้ทั้งหมด 3+1 แบบ ได้แก่
บทความชุดนี้จะใช้แนวทาง JavaScript/HTML เป็นหลัก เนื่องจากเป็นภาษาที่เข้าใจง่ายและใช้กันแพร่หลายในกลุ่มนักพัฒนาเว็บ ส่วนผู้ที่ต้องการใช้ภาษาโปรแกรมแบบอื่นๆ สามารถอ่านรายละเอียดได้เองจาก Getting started with Windows Store apps แล้วเลือกภาษาโปรแกรมที่ต้องการ
รายละเอียดเพิ่มเติมของกระบวนการพัฒนาแอพบน Windows 8 นอกเหนือจากบทความชุดนี้ สามารถอ่านได้จากหน้าเว็บ Windows Dev Center ซึ่งเป็นศูนย์รวมข้อมูลด้านการพัฒนาแอพบน Windows 8 อย่างเป็นทางการของไมโครซอฟท์ (บทความชุดนี้จะอ้างอิงเอกสารเพิ่มเติมบนเว็บไซต์แห่งนี้เป็นระยะๆ เท่าที่จำเป็น)
สำหรับนักพัฒนาที่มีประสบการณ์สร้างแอพบน iOS มาก่อน ไมโครซอฟท์เตรียมเอกสารสอนการใช้งานมาให้เป็นกรณีพิเศษ โดยสอนการพอร์ตแอพจาก iOS ในแง่มุมต่างๆ เช่น การเปลี่ยนจากภาษา Objective-C มาเป็น C#, การแปลงดีไซน์แอพบน iPad มาเป็น Windows 8 หรือการเทียบ API ของทั้งสองแพลตฟอร์มให้ค้นหาได้ง่าย เป็นต้น ผู้ที่เข้าข่ายเข้าไปดูได้ที่ Resources for iOS developers
นอกจากข้อมูลบนหน้าเว็บแล้ว ไมโครซอฟท์ยังแจกอีบุ๊กสอนการเขียนโปรแกรมบน Windows 8 ฟรี โดยมีเนื้อหาครอบคลุมการสร้างแอพด้วย HTML, CSS, JavaScript สามารถดาวน์โหลดได้ที่ Microsoft Press (มีทั้งแบบ PDF, EPUB, MOBI)
ซอฟต์แวร์ที่จำเป็นสำหรับการพัฒนาแอพบน Windows 8 มีดังนี้
การพัฒนาแอพสำหรับ Windows 8 จำเป็นต้องทำบนระบบปฏิบัติการ Windows 8 เท่านั้น ไม่สามารถพัฒนาบนวินโดวส์รุ่นเก่ากว่านี้ได้
ปัจจุบันไมโครซอฟท์ตั้งราคาขาย Windows 8 ต่ำลงมากเมื่อเทียบกับราคาของวินโดวส์รุ่นก่อนๆ การลงทุนซื้อหามาใช้งานพัฒนาแอพจึงง่ายกว่าเดิมมาก อย่างไรก็ตาม ถ้ายังไม่อยากเสียเงินจริงๆ ไมโครซอฟท์ก็มี Windows 8 Enterprise รุ่นใช้งานได้ฟรี 90 วันให้ดาวน์โหลดไปทดลองได้ก่อน (ข่าวเก่า Blognone)
ผู้ที่ต้องการดาวน์โหลด Windows 8 รุ่นทดสอบ สามารถเข้าไปดาวน์โหลดได้ที่ Windows 8 evaluation for developers
สำหรับวิธีการดาวน์โหลดและติดตั้ง Windows 8 อ่านรายละเอียดได้จากบทความ ขั้นตอนการดาวน์โหลดและติดตั้ง Windows 8 แบบ Upgrade
เครื่องมือพัฒนาแอพบน Windows 8 มีทางเลือกให้นักพัฒนา 2 ทาง ได้แก่ การใช้ Visual Studio 2012 ตัวเต็ม (ไม่ว่าจะเป็น edition ใดก็ตาม) ซึ่งต้องเสียเงินซื้อ หรือใช้ Visual Studio Express 2012 ที่ดาวน์โหลดมาใช้งานได้ฟรี (ในบทความชุดนี้จะอ้างอิงจาก Visual Studio Express 2012 เป็นหลัก)
โปรแกรมในชุดที่มากับ Visual Studio Express 2012 มีดังนี้
ตัว Visual Studio Express 2012 เองก็มีหลาย edition ให้เลือกใช้งาน ซึ่งกรณีนี้ต้องเป็น Visual Studio Express 2012 for Windows 8 เท่านั้น ดาวน์โหลดกันได้จาก Visual Studio Download แล้วเลือกรุ่นให้ตรงกับที่ระบุ
วิธีการดาวน์โหลดและติดตั้งมี 2 แบบให้เลือกคือ Install now (ดาวน์โหลดไฟล์ .exe ขนาดเล็กก่อน ตัวติดตั้งจะดาวน์โหลดไฟล์ที่เหลือให้) และ Download now (ดาวน์โหลดไฟล์ .iso ให้ครบแล้วค่อยติดตั้งทีเดียว) ถ้าไม่มีความจำเป็นอะไรพิเศษ ก็ควรเลือกใช้วิธีแรก
เมื่อดาวน์โหลดตัวติดตั้งเสร็จและเรียกขึ้นมาทำงาน จะเห็นหน้าจอดังภาพ ตัวโปรแกรมต้องใช้พื้นที่ขนาด 2.71GB เพื่อติดตั้งไฟล์ทั้งหมด (อย่าลืมคลิก agree เพื่อติดตั้งด้วย)
หลังดาวน์โหลดและติดตั้งโปรแกรมเรียบร้อย เมื่อรันโปรแกรม Visual Studio Express 2012 (ต่อไปจะย่อว่า VS2012) ขึ้นมาครั้งแรก ตัวโปรแกรมจะแจ้งให้เราลงทะเบียน มิฉะนั้นจะใช้งานได้เพียง 30 วันเท่านั้น ให้กดลิงก์ Register online เพื่อลงทะเบียนผ่านหน้าเว็บของไมโครซอฟท์
เมื่อกรอกข้อมูลส่วนตัวเล็กน้อย จะได้ Product Key เพื่อกรอกลงใน VS2012 ให้เสร็จสิ้นกระบวนการ
ผู้ที่สร้างแอพบน Windows 8 จำเป็นต้องมี “ใบอนุญาตนักพัฒนา” (developer license) เพื่อติดตั้งและทดสอบแอพของตัวเองภายในเครื่อง มิฉะนั้นตัวระบบปฏิบัติการ Windows 8 จะไม่ยอมให้ติดตั้งแอพนอก Windows Store หรือที่ไมโครซอฟท์เรียกว่า sideload ได้
กระบวนการขอใบอนุญาตไม่เสียค่าใช้จ่ายและไม่มีอะไรซับซ้อน สามารถทำได้เลยจากตัวโปรแกรม VS2012 โดยตรง ขอเพียงแค่มี Microsoft Account เท่านั้น (ซึ่งผู้ที่ติดตั้ง Windows 8 ย่อมมีอยู่แล้ว)
เมื่อกรอก Product Key ของ VS2012 เรียบร้อยแล้ว และเปิดโปรแกรมขึ้นมาครั้งแรก จะเห็นหน้าต่างบอกให้เรายื่นขอใบอนุญาตนักพัฒนา ดังภาพ
กดปุ่ม Agree แล้วโปรแกรมจะให้เราล็อกอินด้วย Microsoft Account ที่ต้องการใช้เป็นบัญชีนักพัฒนา
เพียงแค่นี้เราจะได้ใบอนุญาตนักพัฒนาจากไมโครซอฟท์แล้ว โดยใบอนุญาตจะมีวันหมดอายุ (เบื้องต้นคือสิ้นปี 2012) ซึ่งกดต่อใหม่ได้เรื่อยๆ
เมื่อติดตั้ง VS2012 และได้ใบอนุญาตนักพัฒนาเรียบร้อย ก็เป็นอันเสร็จสิ้นกระบวนการเตรียมเครื่องมือสำหรับพัฒนาแอพแล้ว
หมายเหตุ:
ผู้ที่เพิ่งเคยใช้ Visual Studio เป็นครั้งแรกอาจต้องทำความคุ้นเคยกับตัวโปรแกรมอยู่บ้าง แต่คนที่เคยใช้ Visual Studio หรือเครื่องมือพัฒนาโปรแกรมแบบ IDE มาก่อน (เช่น Eclipse, NetBeans หรือ Xcode) คงหัดใช้ได้ไม่ยากนัก เพราะแนวคิดของโปรแกรมใกล้เคียงกันมาก
Visual Studio 2012 ใช้อินเทอร์เฟซแบบ multi-pane ใกล้เคียงกับโปรแกรมกราฟิกของ Adobe โดยสามารถเปิดไฟล์ซอร์สโค้ดได้หลายไฟล์พร้อมกัน และสลับไฟล์ที่ใช้งานด้วยอินเทอร์เฟซแบบแท็บ
ขั้นตอนแรกคือสร้าง “โครงการ” หรือ Project สำหรับพัฒนาแอพขึ้นมาใหม่ โดยคลิกที่ลิงก์ New Project… ในหน้า Start Page ที่แสดงให้เห็นตั้งแต่เปิดโปรแกรม หรือผ่านเมนู File > New Project ก็ได้
ในหน้าต่าง New Project ให้เลือก Template ในคอลัมน์ด้านซ้ายมือเป็น JavaScript > Windows Store และเลือก Blank App ในคอลัมน์ตรงกลาง ที่สำคัญอย่าลืมตั้งชื่อโครงการตามต้องการ ซึ่งในบทความชุดนี้จะใช้แอพตัวอย่างชื่อ CloudEditor สาธิต
หลังกด OK เพื่อสร้างโครงการใหม่ หน้าจอของ VS2012 จะเปลี่ยนไปจากเดิม โดยแสดงโค้ดของเทมเพลตพื้นฐานให้แทน ซึ่งรายละเอียดการสร้างแอพจะกล่าวถึงต่อไปในตอนหน้า
หมายเหตุ: บทความชุดนี้จะไม่สอนการสร้างแอพ Hello, world และจะใช้ตัวอย่างเป็น CloudEditor แทน ผู้ที่สนใจศึกษาการสร้างแอพด้วยตัวเองก่อน สามารถอ่านเองได้ที่ Create a "Hello, world" app (Windows Store apps using JavaScript and HTML)
บทความชุด การเขียนแอพลิเคชันสำหรับ Windows 8 App Store
Comments
เยี่ยมครับ
ขอบคุณครับ ตอนนี้เขียนแอพบน vs2010 บน windows 7 อยู่ สงสัยคงต้องก้าวข้าม generation เร็วๆนี้
น่ารักมากครับไมโครซอฟท์
เพิ่งรู้ว่า Win8 sideload ไม่ได้
โห่ได้ไหมนี่
ต้องทำใจครับ มันควบคุมง่ายกว่าสำหรับเค้า ไม่งั้นก็ต้องเลือกเป็นโปรแกรมแทนแอพ
หรือไม่ก็รอวันโดน Unlock/Jailbreak (ไม่มี root นะครับ :p)
สิ่งที่ผมแอนตี้ที่สุดของ iOS คือเรื่องนี้แหละ เครื่องเราเอง ทำไมต้องขออนุญาติเขียนโปรแกรมมาใช้เองด้วย
แต่โปรแกรมลงได้ก็ยังดี นึกว่าโปรแกรมก็ sideload ไม่ได้
เคยลอง VS2012 ช่วง Windows 8 consumer preview ออกมาใหม่ๆ มี template ให้หมด เขียนสะดวกดี ผมว่าเค้าปูทางให้นักพัฒนามาดีมากๆ เลย เหลือแต่ marketing นี่แหละ ว่าจะไปได้ดี + ไวแค่ไหน สำหรับตัว windows 8 (ในใจคิดว่าคงต้องรอรุ่นถัดไปอีกรุ่นเหมือน windows 7 :P)
ขอบคุณครับ
ดีครับ อยากกระตุ้นให้appเยอะ ก็ต้องแบบนี้และ win-win
ผมมีทั้ง Windows 8 ทั้ง VS2012 ขาดแต่ความรู้ในการเขียนโปรแกรมแค่นั้นครับ สงสัยต้องไปศึกษา แต่ขอผ่านช่วงปลายปีไปก่อน เจอสอบกลางภาค ไม่มีเวลาทำอยากอื่น มากนัก
ดีครับที่กระตุ้นครับ
ปล. แต่จะดีกว่านี้มากถ้า Windows Store ยกเว้นค่าสมัครนักพัฒนาให้ :P
I'm ordinary man; who desires nothing more than just an ordinary chance to live exactly what he likes and do precisely what he wants.
เสียดาย Windows 7 เพิ่งซื้อกลางปีเอง
Windows 7 เพิ่งซื้อกลางปี <== ไม่ได้ pro สิทธิ์อัพเปน win8 หรอ :?
เพิ่งไปทำมาครับ กำลังโหลด Windows 8 อยู่เลย
ของเขาดีนะ แต่มาไวไป - -*
product cycle ยังไม่ครบรอบก็มีตัวใหม่มา
มันไม่ง่ายเลยที่จะทำ GIF ให้มีขนาดน้อยกว่า 20kB
อื้อหือ ซื้อโฆษณามาเลยทีเดียว เจ๋งมากๆ
เยี่ยมครับ
ไม่เข้าใจ ทำไมต้องซ่อนบทความ
Ad-Block?
Dream high, work hard.
จริงด้วยครับ Ad-Block บล็อคหายทั้งบทความเลย เหอะๆ
ลง ad block ไว้หรือเปล่า ผมเห็นบทความนี้ตอนไปเล่นเครื่องคอมพิวเตอร์เพื่อน เหมือนกัน
JavaScript ได้อย่างเดียวเรา -.-
เขียน Windows 8 app
ไม่ยากจริงๆครับ
สำหรับคนที่ยังไม่ชำนาญ หา Template มาลองทำ ลองดัดแปลงดูก่อนก็ดีนะครับ
http://channel9.msdn.com/Series/Windows-Store-apps-for-Absolute-Beginners-with-C-
ลองดูตามนี้
ขออนุญาตครับ
สวัสดีชาว windows phone8 กรุ้ป
มีอะไรที่เกี่ยวกับ wp8 มาคุยในนี้ได้หมดครับ
ช่วยๆกันแชร์นะครับ คนจะได้เยอะๆ
http://www.facebook.com/groups/wpthailand/
ซึ่งเราจะเห็นกรุ๊ปอีกกรุ๊ปนึงที่มี wp7 และ wp7.8 รวมอยู่ด้วย ผมจึงขออนุญาตแยกออกมาอีกทีเพื่อให้ได้รับข้อมูลตรงจุด wp8 เท่านั้นครับ
ผมว่าเริ่มฝากบ่อยเกินไปแล้วล่ะครับ
แนะนำว่าไผฝากใน forum ดีกว่ามาแปะแบบนี้บ่อยๆ นะครับ ก่อนจะโดนข้อหาสแปมซะก่อน
Dream high, work hard.
เจ๋งงง มาแล้วๆๆ