data:image/s3,"s3://crabby-images/8666c/8666c4aa01f03b0b2ac28feecec3938afff9a139" alt="หน้าจอสบายๆ ของ Widget เรา"
บทเรียนการเขียน Widget บน iOS8 สำหรับผู้เริ่มต้นด้วยภาษา Swift แบบง่ายเหมาะกับการสร้าง UI ในหน้าจอ Lock Screen หรือส่วนที่เราต้อง Pull Down ลงมาจากตำแหน่งบนสุดของหน้าจอ
ส่วนมาก หน้าจอของ Widget นั้นเราจะไม่เน้นการออกแบบที่ซับซ้อน UI ของส่วนนี้จะต้องเป็นอะไรที่ อ่านง่าย เข้าใจง่าย เช่นพวก Stock หุ้น หรือ Calendar เป็นต้น ดังนั้น Widget จึงต้องเป็นอะไรที่ใช้ง่าย และต้องคำนึงถึงฟังก์ชันของมันนั่นคือการ “เตือน” หรือ “แจ้ง” นั่นเอง
Widget นั้นก็ไม่ใช่อะไรที่จะพัฒนายากเย็นหรอกครับ บทเรียนนี้จึงนำเสนอวิธีการสร้าง Widget เกี่ยวกับ แจ้งเวลา หรือเตือนเวลามาให้รู้ว่ามันทำงานง่าย
เปิด XCode ขึ้นมา
data:image/s3,"s3://crabby-images/42022/42022a91663b5a31f019a6ff41c9087c1b97631b" alt="เปิด Xcode 6.0.1 ขึ้นมา"
สร้าง New Project ขึ้นมาเป็น Single View Application ครับ เลอกเป็นภาษา Swift ในการพัฒนา
data:image/s3,"s3://crabby-images/34595/34595c00a6adf14d7afbdc994ed7ddca90f04cef" alt="เปิด Single View Application"
data:image/s3,"s3://crabby-images/5bec2/5bec2a95c3378074d5e8aebbf6ea968d5a7b37e8" alt="ตั้งชื่อ เลือก Swift"
เมื่อพร้อมแล้วให้ไปที่ File > New > Target อีกรอบ
data:image/s3,"s3://crabby-images/b0b31/b0b31b0d6b91f9d7ededecdb8fb314c4e0dce7c5" alt="สร้าง Target ใหม่ขึ้นมา"
เลือก Template ของ Application Extension เป็น Today Extension ครับ
data:image/s3,"s3://crabby-images/39652/3965237ef5f1ff8e3e3bf4e8f8dcab914c715740" alt="ที่อื่นเค้าเน้น Keyboard ของเราเน้นไร้สาระ"
ตั้งชื่อให้สอดคล้องกับ แอพพลิเคชันของเราสักหน่อย
data:image/s3,"s3://crabby-images/34f85/34f851b9984fabd829615d9cb51743ce18e67073" alt="ตั้งชื่อให้แตกต่างกันเล็กน้อย"
data:image/s3,"s3://crabby-images/08a26/08a266a73970180df97984d1ddd6663da14968b1" alt="ยืนยันการสร้าง"
เราจะได้ Extension เพิ่มมาใน Project ของเราพร้อมไฟล์ MainStoryInterface.StoryBoard และ Swift File
data:image/s3,"s3://crabby-images/a9396/a9396b5cd00a1458a5433a06691992824a42c05d" alt="ได้ไฟล์ Target มาและ"
เปิด MainStoryInterface.StoryBoard ขึ้นมาให้เคลียร์ หรือลบข้อความ Hello world ออกไปเลยครับไม่ใช้และ
data:image/s3,"s3://crabby-images/302a5/302a568ebad5d7a8a49c0ca18045920e3d5c0d3d" alt="ลบ Hello World ออกไป"
ทำการปรับความสูงตามใจชอบครับผ่าน Inspector ด้านข้าง
data:image/s3,"s3://crabby-images/4d869/4d869287f593bbd288b933da5ee8b44683088983" alt="ปรับขนาดความสูงหน่อย"
ตัวอย่างแอพพลิเคชัน Widget นี้ผมจะทำ แอพเตือนว่าถูกหวยหรือเปล่าง่ายๆ ก็ใช้ UILabel มาวางตามรูปแบบที่ต้องการ แล้วทำการ Link ตัว UILabel ไปสร้าง IBOutlet ของ TodayViewController.swift
data:image/s3,"s3://crabby-images/2f1d9/2f1d9210f81e8301dba5e93f83719ec0609a6976" alt="สร้าง iBOutlet"
ผมสร้าง UI ตามนี้
data:image/s3,"s3://crabby-images/14072/140725a722749477883c5f2a9d491051b644ebcd" alt="วางๆ ไปเถอะ"
ส่วนของ Code ที่สร้าง IBoutlet คือ
import UIKit import NotificationCenter class TodayViewController: UIViewController, NCWidgetProviding { @IBOutlet weak var toDayLabel: UILabel! @IBOutlet weak var toMorrowLabel: UILabel! @IBOutlet weak var nextTwoDayLabel: UILabel!
ทำการเซ็ตค่า CGSizeMake ให้พอดีกับหน้าจอ ใน viewDidLoad() สักหน่อย
override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view from its nib. self.preferredContentSize = CGSizeMake(320,50) }
เขียน Function เพิ่มขึ้นมาเพื่อเรียกให้ UILabel ของเราแสดงค่า ก็เป็นฟังก์ชันง่าย สามารถสร้างตัวแปร หรือดึงฐานข้อมูลได้ตามที่เราต้องการครับ ในตัวอย่างผมก็ใส่ Static Value ตามนี้
func showFuckinDay(){ var lotto:Int = 467 toDayLabel.text = "หวยออก \(lotto)" toMorrowLabel.text = "โดนแดก" nextTwoDayLabel.text = "มึงจะหวังอีก?" }
กลับไปที่ viewDidLoad() เพิ่มการเรียกทำงานของ function showFuckinDay() ลงไป
override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view from its nib. self.preferredContentSize = CGSizeMake(320,50) self.showFuckinDay() }
ภาพรวมของ Code ใน TodayViewController.Swift จะต้องเป็นดังนี้ครับ
// // TodayViewController.swift // LuckyWidgetiOS // // Created by DAYDEV on 10/21/2557 BE. // Copyright (c) 2557 DAYDEV. All rights reserved. // import UIKit import NotificationCenter class TodayViewController: UIViewController, NCWidgetProviding { @IBOutlet weak var toDayLabel: UILabel! @IBOutlet weak var toMorrowLabel: UILabel! @IBOutlet weak var nextTwoDayLabel: UILabel! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view from its nib. self.preferredContentSize = CGSizeMake(320,50) self.showFuckinDay() } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } func widgetPerformUpdateWithCompletionHandler(completionHandler: ((NCUpdateResult) -> Void)!) { // Perform any setup necessary in order to update the view. // If an error is encountered, use NCUpdateResult.Failed // If there's no update required, use NCUpdateResult.NoData // If there's an update, use NCUpdateResult.NewData completionHandler(NCUpdateResult.NewData) } func showFuckinDay(){ var lotto:Int = 467 toDayLabel.text = "หวยออก \(lotto)" toMorrowLabel.text = "โดนแดก" nextTwoDayLabel.text = "มึงจะหวังอีก?" } }
ทดสอบให้ลอง Run ตัวแอพพลิเคชัน และตัว Widget ของเราได้เลยครับ วิธีใช้คือ Pull Down สว่นบนหน้าจอลงมา แล้วแตะที่ชื่อ LuckyWidgetiOS เลยครับ
data:image/s3,"s3://crabby-images/d877e/d877e05cabb4873a6ad43f77d33ea3588672204e" alt="ทำการ Pull down widget ลงมา"
ผลลัพธ์ที่ได้ ก็ตามที่เขียนนั่นแหละครับ คงไม่มีอะไรยากหรอกมั้ง?
data:image/s3,"s3://crabby-images/8666c/8666c4aa01f03b0b2ac28feecec3938afff9a139" alt="หน้าจอสบายๆ ของ Widget เรา"
ดาวน์โหลด Source Code ไปศึกษาได้ที่ https://www.daydev.com/download/LuckyWidget.zip