Tags:
Node Thumbnail

คนที่ติดตามข่าวของ Windows 8 คงเห็นแผนภาพ diagram แสดงโครงสร้างการพัฒนาแอพของ Windows 8 ที่แสดงใน keynote เปิดตัว

ไมโครซอฟท์แยกประเภทของแอพเป็น 2 อย่างคือ Desktop Apps ซึ่งหมายถึงแอพแบบเดิมๆ ที่เราใช้กันอยู่ทุกวันนี้ (ไม่ว่าจะเขียนเป็น native/.NET/web app ก็ตาม) และแอพชนิดใหม่ Metro Style Apps สำหรับใช้ในโหมดแท็บเล็ต (และมีเพียงแอพแบบหลังที่ย้ายไปรันบน ARM ได้ด้วย - ข่าวเก่า)

เพื่อความเข้าใจที่ดียิ่งขึ้น ก็ขอลงภาพ diagram ซ้ำอีกรอบ

alt="windows8platform"

บริเวณสีเขียวในภาพ คือ พื้นที่ใหม่หมดของการพัฒนาแอพในอาณาจักรของไมโครซอฟท์ ซึ่งก็คงทำให้หลายๆ คนเกิดคำถามว่าบทบาทของมันต่อการพัฒนาแอพแบบเดิมๆ อย่าง native/.NET จะเป็นอย่างไรบ้าง เช่น เราจะต้องเลิกเขียน native/.NET กันแล้วเปลี่ยนมาเขียน Metro แทนหรือเปล่า?

เท่าที่ผมหาข้อมูลได้ ก็ตอบแบบฟันธงได้เลยว่า มันไม่ได้มาแทน .NET

ถ้าจะให้อธิบายแบบรวบรัดที่สุด ต้องบอกว่า Metro Apps เกิดมาเพื่อแท็บเล็ตและจอสัมผัสเท่านั้น และเป็นแอพในฝั่ง client เพียงอย่างเดียวด้วย ทำงานได้เฉพาะบนแพลตฟอร์ม Windows (และ Windows Phone ในอนาคต) ไม่สามารถทำงานข้ามแพลตฟอร์มแบบ .NET ด้วยซ้ำ (อนาคตไม่แน่)

เราจะมองว่ามันเป็นคู่แข่งของ Android App หรือ iOS App จากฝั่งไมโครซอฟท์ก็พอได้

ก่อนจะลงลึกไปที่ Metro Style App เราต้องย้อนดู "ทางเลือก" ของการพัฒนาแอพในอาณาจักรของไมโครซอฟท์ก่อน

ปัจจุบันไมโครซอฟท์เปิดโอกาสให้เราพัฒนาแอพได้ 4 แบบ

  1. native code เขียนเชื่อมต่อกับ Win32 API ที่อยู่คงกระพันมานาน เป้าหมายของมันก็คือแอพที่ทำงานบนเดสก์ท็อปวินโดวส์ ไม่รันข้ามแพลตฟอร์ม
  2. .NET เขียนเชื่อมต่อกับ .NET API (เช่น WPF, WCF) เลือกภาษาได้หลายภาษา (ที่นิยมคือ C#/VB) ทำงานข้ามแพลตฟอร์มได้ (อย่างน้อยก็บนแมค)
  3. web app เขียนด้วย HTML/JavaScript รันผ่านเบราว์เซอร์ทั้งหมด ไม่ต้องติดตั้ง (อันนี้เหมือนกับ web app บนแพลตฟอร์มอื่นๆ) ทำงานข้ามแพลตฟอร์ม ไม่ต้องคอมไพล์ แต่ความสามารถอาจจะน้อยไปบ้าง และต้องต่อเน็ตเพื่อใช้งาน
  4. Silverlight/WP7 เป็นเวอร์ชันลดรูปของข้อ (2) และใช้งานบนมือถือ Windows Phone เท่านั้น

การมาถึงของ 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 แนวทางตามชอบใจ

  1. HTML + JavaScript (โดยเชื่อมกับ WinRT API ลักษณะเดียวกับ webOS หรือ Silverlight รุ่นแรกๆ ซึ่งแน่นอนว่ามันเอาไปรันบนแพลตฟอร์มอื่นๆ ไม่ได้) รันผ่านเอนจินจาวาสคริปต์ของ IE
  2. XAML + C/C++ รันแบบ native
  3. XAML + C#/VB โดยรันผ่าน CLR ของ .NET

ตอนนี้เป้าหมายของแอพแบบ 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++

Get latest news from Blognone

Comments

By: tonhor
ContributorAndroidRed Hat
on 16 September 2011 - 21:46 #334221
tonhor's picture

"Metro Apps เกิดมาเพื่อแท็บเล็ตและจอสัมผัสเท่านั้น"
พี่มาร์คลืมนึกถึงจอ TV เปล่าคับ :p

ขอบคุณครับ หาอ่านที่ไหน ยังไม่เข้าใจเท่านี้เลย..
ถวายบังคม..


Katinrun ชุมชน Blockchain Developer แห่งแรกในไทย

By: mr_tawan
ContributoriPhoneAndroidWindows
on 17 September 2011 - 00:35 #334244 Reply to:334221
mr_tawan's picture

ใช้ Kinnect สัมผัส (อากาศ) เอามั้งครับ ...

เมื่อยแย่ - -


  • 9tawan.net บล็อกส่วนตัวฮับ
By: mk
FounderAndroid
on 17 September 2011 - 00:45 #334247 Reply to:334221
mk's picture

ผมตีความเอาเองว่า ถ้าเป็น TV (ซึ่งเป็น 10-foot interface) ไมโครซอฟท์น่าจะลุยด้วย Xbox/Kinect ซึ่งเป็น gesture + voice มากกว่านะครับ

เท่าที่ดูคือในตอนนี้ Metro จะเอาจอสัมผัสให้รอดก่อนน่ะครับ อนาคตก็ว่ากันอีกที

By: gab
Windows PhoneAndroidWindows
on 17 September 2011 - 01:02 #334253 Reply to:334221
gab's picture

+1 ขอบคุณด้วยคร้าบ (ผมชอบอ่านแบบที่ไม่ยาวนัก ย่อยง่ายกำลังดี)

By: gololo
iPhoneWindows PhoneAndroidBlackberry
on 17 September 2011 - 06:17 #334263 Reply to:334221

ใน Android TV BOX ก็มีรีโมตแบบ wi ขายราวๆ 5000 บาทน่าเล่น ขายที่ gadgetdor เป็น Android 2.2

By: iStyle
ContributoriPhoneAndroidSymbian
on 17 September 2011 - 06:28 #334264 Reply to:334263
iStyle's picture

โอ้! กลับมาคนแรกเลยทีเดียว นั่งเฝ้าเลยรึเปล่าครับเนี่ย


May the Force Close be with you. || @nuttyi

By: gololo
iPhoneWindows PhoneAndroidBlackberry
on 17 September 2011 - 07:02 #334266 Reply to:334264

เปลี่ยนบรรยากาศจิบชาอ่าน Blognone เวปข่าว

นังเขียนไดรเวอจอมา2วันละไม่สำเร็จสักทีชักจะไม่ใหล่แล้ว

By: bank2u
ContributorAndroidUbuntuWindows
on 16 September 2011 - 22:51 #334231
bank2u's picture

ตอนแรกผมคิดว่า Silverlight ได้เปรียบ flash ตรงยังพอมีที่ยืนในตลาด mobile (windows phone7) แต่วันนี้ท่าทางจะค่อยๆ ลดบทบาทลงแล้วละครับ ดูจากบทความนี้ WinRT มาแน่ๆ ครับ


อัลบัมรูปเล็กๆ ของผมครับ :: www.bank2u.net ::

By: mk
FounderAndroid
on 17 September 2011 - 00:47 #334248 Reply to:334231
mk's picture

จริงๆ เรื่องท่าทีที่เปลี่ยนไปของ Silverlight นี่มันก็ไม่ใช่ข่าวใหม่เท่าไรครับ ไมโครซอฟท์ยอมถอย Silverlight เปลี่ยนมาเน้น HTML5 สำหรับเว็บ ถ้าลองนึกย้อนๆ ดูก็เห็นแนวทางค่อนข้างชัดเหมือนกัน

By: gololo
iPhoneWindows PhoneAndroidBlackberry
on 17 September 2011 - 06:53 #334265

สุดท้ายแล้ว Arm รุ่นปัจจุบันก็ตกไปตามคาดเท่าที่อ่านจากลิ้งแล้ววินโดวคงกำหนดมาตราฐานฮาดแวร์แบบเดียวกับ windows Mobile ใครคิดจะเอา board arm มาลง windows 8 แบบผมคงไม่มีหวังแล้ว และ spce ขั้นต่ำคงไม่ใช่เล่นๆแน่

เท่าที่ดูW8 Metro เน้นไปที่ ARM มากกว่าที่คิดที่เหลือก็แค่ราคาแล้ว

By: leonoinoi
AndroidUbuntuWindows
on 17 September 2011 - 10:41 #334290

winRT สงสัยจะเป็น virtual machine ใช่ไหมครับ ใครรู้ตอบที

By: sake on 18 September 2011 - 08:38 #334426

มีคนตั้งข้อสังเกตว่า Microsoft ไม่เรียก .NET แล้ว แต่ใช้คำว่า "C# กับ VB" แทน

By: F16
iPhoneWindows PhoneAndroidIn Love
on 18 September 2011 - 21:19 #334511

เริ่มสงสัยว่าอนาคตความสามารถของ HTML5 มันจะเทียบเท่า Flash ได้ไหม?

By: khajochi
WriteriPhoneIn Love
on 19 September 2011 - 19:09 #334703
khajochi's picture

อธิบายได้ดีเลยครับ น่าสนใจเรื่อง html + js engine ของ IE


แฟนพันธุ์แท้สตีฟจ็อบส์ | MacThai.com