Home / Developer  / Xcode5 (GM Seed) กับการดึง Web Service มาลงบน UITableViewCell

Xcode5 (GM Seed) กับการดึง Web Service มาลงบน UITableViewCell

หลังจากที่ Apple เปิดตัว iOS7 ไปหมาดๆ XCode ก็ได้ก้าวเข้าสู่ เวอร์ชัน 5 จาก Developer Preview เป็น GM Seed ก็เลยขอประเดิมพาทำแอพเชื่อม Web Service สักหน่อย

ก่อนอื่นใครที่ยังไม่มี XCode 5 GM Seed ให้ไปดาวน์โหลดที่ http://developer.apple.com ก่อนนะครับ (เฉพาะผู้ที่มี Developer Program เท่านั้น) เมื่อดาวน์โหลดเสร็จแล้วก็มาเริ่มทำแอพ เล็กๆ กันหน่อยดีกว่า

Screen Shot 2556-09-13 at 4.08.33 PM

ทำการ New Project ขึ้นมาใหม่เลือกเป็น Single View Application ครับ

Screen Shot 2556-09-13 at 12.18.01 PM

ตั้งชื่อ Project เหมือนเดิมๆ ปรกติครับ

Screen Shot 2556-09-13 at 12.18.36 PM

เมื่อเสร็จแล้วเรามาว่ากันด้วยเรื่องของ Web Service กันหน่อย ซึ่งแต่เดิมเราจะคุ้นตากับ XML และต่อมาก็เป็นแบบ JSON ซึ่งจะได้รับความนิยม และนักพัฒนาชอบกันมากครับ สำหรับข้อมูล Web Service หลังบ้านที่ผมจะเอามาใช้นั้นคือ JSON ที่มาจาก Plugin ของ WordPress แปลง Feed ปรกติให้เป็น JSON รองรับ Web Service

ผมใช้ URL ของ Web Service ของเว็บไซต์ผมเอง http://www.gooruism.com/feed/json

จะมีโครงสร้างดังนี้

Screen Shot 2556-09-13 at 3.59.55 PM

ต่อมาก็คือการเอา Web Service ส่วนนี้มาแสดงผลผ่านหน้าแอพพลิเคชันของเราครับ เปิดไฟล์ MainStoryBoard แล้วให้ทำการลาง Object อย่าง UITableView มาวางบน ViewController ทำการ Delegate และ Datasource ให้เรียบร้อย

Screen Shot 2556-09-13 at 12.19.16 PM

เปิด XCode5 GM Seed ขึ้นมา

Screen Shot 2556-09-13 at 12.19.32 PM

ไปที่ MainStoryBoard

Screen Shot 2556-09-13 at 12.20.03 PM

 

 

Screen Shot 2556-09-13 at 1.19.08 PM

นำ UITableView มาวาง ที่ ViewController ทำการ Delegate และ Datasource

Screen Shot 2556-09-13 at 12.20.11 PM

 

เพิ่ม Prototype Cell มาสัก 1 แถว

เปิดไฟล์ ViewController.h ขึ้นมาแก้ไข คำสั่งจาก

ให้กลายเป็น

นั่นคือเราสร้าง ตัวแปล tableData มาเพื่อใช้งานกับ UITableView นั่นเอง ต่อไปให้ไปแก้ไขไฟล์ ViewController.m โดยเพิ่ม Method ต่อไปนี้ลงไป

เพิ่มต่อท้าย Method ของ viewDidLoad()

เป็นเรียกข้อมูล title, thumbnail และ author มาทำการแสดงผลร่วมกับ UITableViewCell นั่นเองต่อจากนั้นเพิ่มคำสั่งของ UITableViewCell ออกมาตามนี้ เป็นการเรียกค่าต่างๆ มาเก็บลงในตัวแปร

เป็นการรันตัว Web Service ไปเก็บไว้ในตัวแปร เล็กน้อย

แล้วใช้ UITableViewCell แสดงผล ค่าตัวแปรต่างๆ ออกมา ใน Code ส่วนนี้

สุดท้ายให้ทำการลิงค์จาก File Owner หรือไอคอน ViewController กลับไปยัง UITableView แล้วเลือก tableData ก็เป็นอันเรียบร้อย ทดลอง Run ตัว Project เพื่อดูผลลัพธ์

จะเห็นว่าในช่อง Console ของตัว XCode5 GM Seed จะดึงข้อมูลสำเร็จเรียบร้อย

Screen Shot 2556-09-13 at 12.28.31 PM

และหน้าจอ แอพพลิเคชันบน iOS Simulator จะแสดงผลแบบนี้

iOS Simulator Screen shot Sep 13, 2556 BE 3.16.08 PM

 

หน้าจอแอพพลิเคชันของเราที่ดึง Web Service

 

สิ่งที่ได้จากบทเรียนนี้คือการ ดึงข้อมูล Web Service ในรูปแบบ JSON จากฐานข้อมูล MySQL ให้มาแสดงผลอย่างเป็นระเบียบและสวยงามผ่าน UITableView บนแอพพลิเคชัน iPhone ของเรา เพื่อที่จะได้นำข้อมูลทั้งหลายไปประยุกต์ใช้งาน พัฒนาแอพพลิเคชันที่ซับซ้อนในรูปแบบต่อๆ ไปในอนาคต

Comments

daydevthailand@gmail.com

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

Review overview