คนที่ติดตามข่าวของ Windows 8 คงเห็นแผนภาพ diagram แสดงโครงสร้างการพัฒนาแอพของ Windows 8 ที่แสดงใน keynote เปิดตัว
ไมโครซอฟท์แยกประเภทของแอพเป็น 2 อย่างคือ Desktop Apps ซึ่งหมายถึงแอพแบบเดิมๆ ที่เราใช้กันอยู่ทุกวันนี้ (ไม่ว่าจะเขียนเป็น native/.NET/web app ก็ตาม) และแอพชนิดใหม่ Metro Style Apps สำหรับใช้ในโหมดแท็บเล็ต (และมีเพียงแอพแบบหลังที่ย้ายไปรันบน ARM ได้ด้วย - ข่าวเก่า)
เพื่อความเข้าใจที่ดียิ่งขึ้น ก็ขอลงภาพ diagram ซ้ำอีกรอบ
บริเวณสีเขียวในภาพ คือ พื้นที่ใหม่หมดของการพัฒนาแอพในอาณาจักรของไมโครซอฟท์ ซึ่งก็คงทำให้หลายๆ คนเกิดคำถามว่าบทบาทของมันต่อการพัฒนาแอพแบบเดิมๆ อย่าง native/.NET จะเป็นอย่างไรบ้าง เช่น เราจะต้องเลิกเขียน native/.NET กันแล้วเปลี่ยนมาเขียน Metro แทนหรือเปล่า?
เท่าที่ผมหาข้อมูลได้ ก็ตอบแบบฟันธงได้เลยว่า มันไม่ได้มาแทน .NET
ถ้าจะให้อธิบายแบบรวบรัดที่สุด ต้องบอกว่า Metro Apps เกิดมาเพื่อแท็บเล็ตและจอสัมผัสเท่านั้น และเป็นแอพในฝั่ง client เพียงอย่างเดียวด้วย ทำงานได้เฉพาะบนแพลตฟอร์ม Windows (และ Windows Phone ในอนาคต) ไม่สามารถทำงานข้ามแพลตฟอร์มแบบ .NET ด้วยซ้ำ (อนาคตไม่แน่)
เราจะมองว่ามันเป็นคู่แข่งของ Android App หรือ iOS App จากฝั่งไมโครซอฟท์ก็พอได้
ก่อนจะลงลึกไปที่ Metro Style App เราต้องย้อนดู "ทางเลือก" ของการพัฒนาแอพในอาณาจักรของไมโครซอฟท์ก่อน
ปัจจุบันไมโครซอฟท์เปิดโอกาสให้เราพัฒนาแอพได้ 4 แบบ
การมาถึงของ Metro Style ถือเป็นวิธีการพัฒนาแอพแบบที่ 5 ของไมโครซอฟท์ มันจะมาพร้อมกับ API ตัวใหม่ที่เรียกว่า WinRT (ย่อมาจาก Windows Runtime) ซึ่งถือเป็น API ชุดใหม่ที่ไม่เกี่ยวข้องกับ Win32 และ .NET เดิมเลย
Metro/WinRT ถือเป็นแพลตฟอร์มการพัฒนาแบบใหม่ทั้งหมด แต่ก็อิงอยู่บนเทคโนโลยีเดิมหลายจุด
ในส่วนของ WinRT ที่อยู่ด้านล่าง ไมโครซอฟท์จะนำความสามารถใน Win32 และ .NET API มาจัดระเบียบใหม่ คัดเฉพาะสิ่งที่จำเป็นจริงๆ เพื่อให้เบา (เช่น ตัด WinForm ออกไป, ไม่มี GDI, ไม่มี XNA ต้องเรียก DirectX ตรงๆ - ดูรายการ API ทั้งหมดของ WinRT และ การเปรียบเทียบ API ระหว่าง WinRT กับ API แบบเดิมๆ)
ส่วนของภาษาที่ใช้พัฒนาแอพ Metro ก็มีให้เลือก 3 แนวทางตามชอบใจ
ตอนนี้เป้าหมายของแอพแบบ Metro คือการรันบน Windows 8 (ไม่ว่าจะเป็น x86/ARM) เท่านั้น แต่ใน keynote เราก็เห็นเดโมการพอร์ตแอพ Metro ไปอยู่บน Windows Phone ได้ด้วย (ซึ่งเดิมทีแอพ Windows Phone เป็น Silverlight) ตรงนี้คงเห็นชัดว่าไมโครซอฟท์เริ่มขยับหนี Silverlight ในความหมายเดิม และใน Windows Phone รุ่นถัดๆ ไป เราน่าจะเห็นการใช้ Metro/WinRT มากขึ้น
อธิบายง่ายๆ ว่า Metro/WinRT จะมาแทนวิธีการพัฒนาแบบที่สี่เป็นหลัก นั่นคือ Silverlight จะค่อยๆ ลดบทบาทลง ส่วนวิธีการพัฒนาโปรแกรม 3 แบบแรกคือ native/.NET/web app จะยังมีที่ทางของมันอยู่เหมือนเดิม (อย่างน้อยก็ใน Windows 8 แบบเดสก์ท็อป x86) เพียงแต่ในระยะยาว ไมโครซอฟท์น่าจะผลักดันให้แอพบนแพลตฟอร์มวินโดวส์หันมาใช้ Metro/WinRT มากขึ้น
ข้อมูลจาก ReadWriteWeb ระบุว่าตอนนี้ไมโครซอฟท์ยังไม่มีแผนจะทำ Metro/WinRT แบบข้ามแพลตฟอร์ม (เหมือนกับ .NET ที่มีรันไทม์ไปติดตั้งบนแพลตฟอร์มอื่นๆ ได้) และการนำ Metro/WinRT ไปรันบนกลุ่มเมฆ (เหมือนกับ .NET บน Azure) ในช่วงแรกคงเป็นเฉพาะสภาพแวดล้อมในการพัฒนาแบบ client บนแท็บเล็ตเท่านั้น
กระบวนการพัฒนาแอพ Metro นอกจากตัวแอพแล้ว ยังมีเรื่องการทำแพกเกจและส่งขึ้นไปขายบน Windows Store (ร้านขายแอพของ Windows 8 ซึ่งไม่ใช่ Windows Marketplace) แต่ตรงนี้คงไม่ต่างอะไรจากแอพบนมือถือในปัจจุบันมากนัก
ในสายตาของนักพัฒนาฝั่งไมโครซอฟท์ คงปรับตัวกันไม่ยากนักเพราะใช้เทคโนโลยีเดิมๆ อย่าง C#, VB, HTML/JavaScript, XAML แต่ก็มีส่วน WinRT และสไตล์ของ Metro ที่ต้องเรียนรู้ใหม่บ้าง และการพัฒนาโปรแกรมที่ต้องเริ่มใหม่ตั้งแต่แรก เครื่องมือพัฒนาเป็น Visual Studio 11 ซึ่งถ้าอยู่สายนี้ก็คงคุ้นมืออยู่แล้ว
ช่วงนี้ Metro/WinRT ยังเพิ่งเริ่มต้นเท่านั้น แต่ดูจากทิศทางของไมโครซอฟท์แล้ว ก็คงอยู่กับมันยาวทีเดียว
ข้อมูลจาก Tim Anderson’s ITWriting, ReadWriteWeb
เอกสารเพิ่มเติมของไมโครซอฟท์
หมายเหตุ: ในบทความข้างต้นผมไม่ได้พูดถึงการเขียนเกมบน Metro เพราะเดี๋ยวจะซับซ้อนเกินไป และเป็นหัวข้อค่อนข้างเฉพาะ วิธีการเขียนเกมบน Metro จะใช้ C++ เรียก native API อย่าง DirectX โดยตรง (ซึ่งปัจจุบันเกมจำนวนมากก็เขียนแบบนี้อยู่แล้ว) รายละเอียดอ่านใน Building your first Metro style game with C++
Comments
"Metro Apps เกิดมาเพื่อแท็บเล็ตและจอสัมผัสเท่านั้น"
พี่มาร์คลืมนึกถึงจอ TV เปล่าคับ :p
ขอบคุณครับ หาอ่านที่ไหน ยังไม่เข้าใจเท่านี้เลย..
ถวายบังคม..
Katinrun ชุมชน Blockchain Developer แห่งแรกในไทย
ใช้ Kinnect สัมผัส (อากาศ) เอามั้งครับ ...
เมื่อยแย่ - -
ผมตีความเอาเองว่า ถ้าเป็น TV (ซึ่งเป็น 10-foot interface) ไมโครซอฟท์น่าจะลุยด้วย Xbox/Kinect ซึ่งเป็น gesture + voice มากกว่านะครับ
เท่าที่ดูคือในตอนนี้ Metro จะเอาจอสัมผัสให้รอดก่อนน่ะครับ อนาคตก็ว่ากันอีกที
+1 ขอบคุณด้วยคร้าบ (ผมชอบอ่านแบบที่ไม่ยาวนัก ย่อยง่ายกำลังดี)
ใน Android TV BOX ก็มีรีโมตแบบ wi ขายราวๆ 5000 บาทน่าเล่น ขายที่ gadgetdor เป็น Android 2.2
โอ้! กลับมาคนแรกเลยทีเดียว นั่งเฝ้าเลยรึเปล่าครับเนี่ย
May the Force Close be with you. || @nuttyi
เปลี่ยนบรรยากาศจิบชาอ่าน Blognone เวปข่าว
นังเขียนไดรเวอจอมา2วันละไม่สำเร็จสักทีชักจะไม่ใหล่แล้ว
ตอนแรกผมคิดว่า Silverlight ได้เปรียบ flash ตรงยังพอมีที่ยืนในตลาด mobile (windows phone7) แต่วันนี้ท่าทางจะค่อยๆ ลดบทบาทลงแล้วละครับ ดูจากบทความนี้ WinRT มาแน่ๆ ครับ
อัลบัมรูปเล็กๆ ของผมครับ :: www.bank2u.net ::
จริงๆ เรื่องท่าทีที่เปลี่ยนไปของ Silverlight นี่มันก็ไม่ใช่ข่าวใหม่เท่าไรครับ ไมโครซอฟท์ยอมถอย Silverlight เปลี่ยนมาเน้น HTML5 สำหรับเว็บ ถ้าลองนึกย้อนๆ ดูก็เห็นแนวทางค่อนข้างชัดเหมือนกัน
สุดท้ายแล้ว Arm รุ่นปัจจุบันก็ตกไปตามคาดเท่าที่อ่านจากลิ้งแล้ววินโดวคงกำหนดมาตราฐานฮาดแวร์แบบเดียวกับ windows Mobile ใครคิดจะเอา board arm มาลง windows 8 แบบผมคงไม่มีหวังแล้ว และ spce ขั้นต่ำคงไม่ใช่เล่นๆแน่
เท่าที่ดูW8 Metro เน้นไปที่ ARM มากกว่าที่คิดที่เหลือก็แค่ราคาแล้ว
winRT สงสัยจะเป็น virtual machine ใช่ไหมครับ ใครรู้ตอบที
มีคนตั้งข้อสังเกตว่า Microsoft ไม่เรียก .NET แล้ว แต่ใช้คำว่า "C# กับ VB" แทน
เริ่มสงสัยว่าอนาคตความสามารถของ HTML5 มันจะเทียบเท่า Flash ได้ไหม?
อธิบายได้ดีเลยครับ น่าสนใจเรื่อง html + js engine ของ IE
แฟนพันธุ์แท้สตีฟจ็อบส์ | MacThai.com