iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) |
iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) จากบทความก่อนหน้านี้เราได้รู้วิธีการสร้าง View บน Storyboard ด้วยวิธีอันแสนง่าย ภายในไม่กี่นาทีเราก็สามารถสร้างสรร Application ที่ประกอบด้วยหลาย View ได้อย่างง่ายดายและรวดเร็ว และผมเองก็ยอมรับว่าเป็น Tools ที่สุดยอดจริง ๆ และจากบทความที่แล้วได้พูดถึงเรื่องการสร้าง Class (Objective-C)ที่เป็น .h และ .m แล้วทำการเชื่อมโยงให้กับแต่ล่ View
iOS Storyboard View and Class
จากขั้นตอนการสร้าง Storyboard ที่เราสร้าง View ขึ้นมาต่าง ๆ บน Storyboard แต่ View เหล่านั้นจะทำการเชื่อมโยงไปยัง Class ที่เป็น .h และ .m ได้อย่างไร และเหตุผลที่จะต้องเชื่อมโยงระหว่าง View กับ Class ก็คือ ในการเขียน Application ที่มีความซับซ้อน ที่ไม่ใช่แค่แสดงข้อความบน Label ที่เป็น Static View แต่เราต้องการให้มันฉลาดขึ้นและโต้ตอบกับผู้ใช้ เราไม่สามารถจัดการส่วนต่าง ๆ ผ่าน Interface Builder ได้ทั้งหมด เหตุผลนี่เองเราจึงจำเป็นจะต้องสร้าง Class ให้กับ View แต่ล่ะตัว และ Class นั้นเราจะใช้ภาษา Objective-C ในการที่จะเขียน Code และเงื่อนไขต่าง ๆ ให้ View ในหน้านั้น ๆ ทำงานตามที่ต้องการ
iOS/iPhone Storyboard and View , Multiple View (Objective-C, iPhone, iPad)
เพื่อไม่ให้เกิดความสสับสนจะขอเริ่มต้นตั้งแต่ขั้นตอนการเริ่มสร้าง App
data:image/s3,"s3://crabby-images/7f305/7f305e6c7e4c7317df601dc583a376abadbc49be" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
เลือก Proejct เป็นแบบ Single View Application
data:image/s3,"s3://crabby-images/1d015/1d015e2000f3c46df5e3a4544677a86a64e45ad5" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ขั้นตอนนี้อย่าลืมว่าจะต้องเลือก Use Storyboards ด้วย
data:image/s3,"s3://crabby-images/d1792/d1792701f9cad2a90c6fddf42ac03297de5b1300" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
หลัก ๆ แล้วหลัวจากที่ Project ถุกสร้างไฟล์ที่ใช้จริง ๆ จะมีอยู่แค่ 3 ไฟล์คือ AppDelegate.h , AppDelegate.m และ MainStoryboard.storyboard ส่วนไฟล์ที่เป็น ViewController.h , ViewController.m เราสามารถทำการลบมันทิ้งได้
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
data:image/s3,"s3://crabby-images/1b9f3/1b9f313c08b8a57bf47b9d7c38bbcd857d3956e1" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ลบไฟล์ ViewController.h และ ViewController.m ทิ้ง
data:image/s3,"s3://crabby-images/b642d/b642d3fe2e2bf0af9b2db771317b371db8e7e0f8" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
คลิกขวาเลือก Delete ไฟล์ทั้ง 2 ทิ้ง
data:image/s3,"s3://crabby-images/f733b/f733b48e175e25b9b12b870173582b0a21ffb4c3" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
เลือก Remove References (ลบออกจาก Project แต่ยังอยู่ในโฟเดอร์ App เพียงแต่ไม่ถูก Include เข้ามา หรือมองไม่เห็น) หรือ Move to Trash (ลบทิ้งทั้งใน Project และ App)
data:image/s3,"s3://crabby-images/a598c/a598c5cb7f274e5a1093747e0b6438b4864b5847" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ไฟลืได้ถูกลบไปเรียบร้อยแล้ว และเลือกหลัก ๆ แค่ 3 ไฟล์ AppDelegate.h , AppDelegate.m และ MainStoryboard.storyboard
data:image/s3,"s3://crabby-images/00b5a/00b5a32012d3a14bd12dd8d0cb34190f274662f4" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
กลับมายังหน้า Storyboard เราจะทดสอบสร้าง View ขึ้นมา 3 ตัวบน Storyboard
data:image/s3,"s3://crabby-images/26527/265277d364f1aef6be6d4a80a8995820bb6ca8f8" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ได้ View ทั้ง 3 ตัวอยู่บน Storyboard
data:image/s3,"s3://crabby-images/9c509/9c509004b53692e962e953b576dc0ff126171695" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ถ้าต้องการสร้าง Object ต่าง ๆ ด้วย Interface Builder ลงในแต่ล่ะ View ก็สามารถหาอ่านได้จากบทความก่อน ๆ ที่ได้เขียนไว้
ขั้นตอนการสร้าง Class (.h และ .m)
ใน Stroyboard เรามี View อยู่ 3 ตัว เฉพาะฉะนั้นเราจะสร้าง Class Class (.h และ .m) ขึ้นมา 3 ชุด ซึ่งปกติการสร้าง Objective-C Class ขึ้นมาแต่ล่ะครั้งจะได้ไฟล์ .h และ .m ขึ้นมาพร้อมกันในทันที
data:image/s3,"s3://crabby-images/cbb12/cbb129dffe3d8661a80e987cae1fbf8e5d5c8fdd" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
คลิกขวาที่ Folder App เลือก New File...
data:image/s3,"s3://crabby-images/756fe/756fe849dba05f6ac5f3af65f7ebca16def923d8" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ภายใต้ iOS -> Cocoa Touch ให้เลือก Objective-C Class และเลือก Next
data:image/s3,"s3://crabby-images/8f264/8f264ee75fbaf4b7ead44270f62702fc67908e6e" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ให้ใส่ชื่อ Class และเลือก Subclass เป็น UIViewController อย่าลืมว่า Checkbox จะต้องไม่เลือกตั้งสองรายการ
data:image/s3,"s3://crabby-images/6874a/6874aebe9753d3cae33a55e4141b2d7f2f87c7c6" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
เลือก Path ที่จัดเก็บ
data:image/s3,"s3://crabby-images/80f7a/80f7ad7b74a84dbcb087d77328ba4252c2ff4823" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
เราจะได้ไฟล์ .h และ .m ขึ้นมา 1 ชุด
data:image/s3,"s3://crabby-images/42b87/42b87be27135cc331f069de5478044e2f163dbbc" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
จากนั้นให้สร้างขึ้นมาอีก 2 ชุด ซึ่งตอนนี้เราได้ไฟล์ Class ทั้งหมด 3 ชุด สำหรับ View 3 ตัว เป็นที่เรียบร้อยแล้ว
ขั้นตอนการเชื่อมโยง View ใน Storybord กับ Class
หลังจากที่ได้ Class ขึ้นมา 3 ชุด พราก็พร้อมที่จะเชื่อมโยง View ที่อยู่บน Storyboard กับ Class ทั้ง 3 ตัว
data:image/s3,"s3://crabby-images/2c5d8/2c5d8de4ac42b3142bce49f51d6b94faa570039d" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ให้เลือก View ที่ต้องการและคลิกที่ File's Owner (Icons สีแดง) จากนั้นให้ไปที่ Inspector ที่อยู่มุมขวาบน ในรูป
data:image/s3,"s3://crabby-images/0e1cc/0e1ccc5dd308a73d57d098bcf83b7a074452be50" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
ตรง Custom Class ให้เลือกทำการ Map เชื่อม View กับ Class ที่ต้องการ และให้ทำจนครบทั้ง 3 View หลังจากเรียบร้อยแล้ว เราก็ได้ View บน Storyboard ที่เชื่อมโยงกับ Class ต่าง ๆ แล้ว
data:image/s3,"s3://crabby-images/dc7cc/dc7cc212ce91c2b51b6c75ffc0d1b0203260173c" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
สังเกตุว่าต่อไปนี้ถ้าเราเลือกมุมมองของ UI และ Coding บน Class จะมีการเชื่อมโยงกับไฟล์ Class ที่เป็น .h และ .m ให้ทันที
data:image/s3,"s3://crabby-images/8da46/8da46a5605183ce41a13019fe8994c8706007793" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
มุมมอง UI กับ Class
data:image/s3,"s3://crabby-images/54cb8/54cb8872a3d21d663d22e7cd7f05ee5ce8dc5d27" alt="iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad) iOS/iPhone Storyboard and Custom Class in View (Objective-C, iPhone, iPad)"
มุมมอง UI กับ Class
วิธีข้างต้นเป็นเพียงการเชื่อมโยง View ที่อยู่บน Storyboard กับ Class ที่สร้างขึ้นมาใหม่ ด้วยวิธีง่าย ๆส่วนการเขียน Code ต่าง ๆ ให้ Class ควบคุมการทำงานของ View ก็สามารถเขียนได้เช่นเดียวกับ Class ควบคุมการทำงานของ .xib ไฟล์ ซึ่งรูปแบบและวิธีการนั้น ทั้งการออกแบบ UI ด้วย Interface Builder และการเขียน Code ต่าง ๆ ด้วยภาษา Objectve-C ก็เหมือนกันทุกประการ
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
|
Create/Update Date : |
2012-10-23 21:55:03 /
2017-03-25 23:51:53 |
|
Download : |
|
|
Sponsored Links / Related |
|
|
|
|
|
|
|