รู้จัก IBOutlet และ IBAction กับ Interface Builder (iOS , iPhone , iPad) |
รู้จัก IBOutlet และ IBAction กับ Interface Builder (iOS , iPhone , iPad) ก่อนหน้านี้เราได้ทดสอบการเรียนโปรแกรมเพื่อทำงานบน iPhone แบบง่าย ๆ ด้วยการรับค่าจาก Textbox และสั่งให้ปุ่มทำงานพร้อม ๆ กับแสดงข้อความโต้ตอบ กับผู้ใช้แบบง่าย ๆ แล้ว และศัพท์ที่เราอาจจะยังงง ๆ ว่ามันคืออะไร จะมีอยู่ 2 ตัว ที่ต่อไปนี้อราอาจจะต้องใช้งานมันบ่อย หรือแทบว่าจะทุก ๆ ครั้งเลยก็ได้ เราเรียกมันว่า IBOutlet และ IBActtion โดยทั้ง 2 ตัวนี้จะมีความหมายเหมือน ๆ กัน โดย IB ย่อมาจาก Interface Builder ส่วนความหมายเต็ม ๆ เรามาดูรายละเอียดแต่ล่ะหัวข้อ
User Interface and Interface Builder
ก่อนอื่นเราจะต้องทำความเข้าใจก่อนว่า หน้าจอที่เป็น App ของ iPhone เราเรียกว่า UI (User Interface) ส่วน Object ต่าง ๆ เราเรียกว่า Object Library เราเรียกรวม ๆ กันทั้ง 2 นี้เมื่อทำการออกแบบเรียบร้อยแล้วว่า Interface Builder (IB)
IBOutlet (Interface Builder Outlet)
เป็นการประกาศให้ Interface Builder หรือ Object ต่าง ๆ เช่น Label , Textbox เชื่อมต่อหรือรู้จักกับตัวแปรที่เราประกาศขึ้นในส่วนต่าง ๆ ของ Object ถ้ายังไม่เข้าใจจะอธิบายเปรียบเทียบพวกโปรแกรมบน ASP.NET / VB.NET ที่ Object ต่า ๆ ที่อยู่ในหน้า Form เราจะสามารถเรียกใช้ได้ทันที แต่ใน Xcode สำหรับ iOS รายการ Object ต่าง ๆ ที่อยู่บน Interface Builder เราจะไม่สามารถเรียกใช้ได้ทันที แต่เราจะต้องประกาศตัวแปรที่ไฟล์ .h (header) จากนั้นทำการเชื่อมตัวแปร กับ Object ใน Interface Builder เราถึงจะสามารถเขียนโปรแกรมเพื่อควบคุมการทำงานของ Object นั้น ๆ ได้
IBAction (Interface Builder Action)
สำหรับ IBAction ความหมายเหมือน ๆ กับ IBOutlet แต่จะเป็นการเชื่อม หรือประกาศ Event ต่าง ๆ ระหว่าง Object ที่อยุ่ใน Interface Builder กับ Event หรือเหตุการณ์ที่เกิดขึ้น ถ้าเปรียบเทียบใน ASP.NET / VB.NET ก็คือการสร้าง Event Handler ให้กับ Button หรือเหตุการณ์ต่าง ๆ
การสร้าง IBOutlet และ IBAction บน Xcode สามารถสร้างได้หลากหลายวิธี แต่วิธีที่นิยมมากที่สุดก็คือใช้แบบ Drag and Drop ตามตัวอย่างนี้
data:image/s3,"s3://crabby-images/eacbc/eacbcdc5e7ac0a1571c65152ae3381134d4abfb8" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
ภายใต้ Project ของเราให้เลือก xib ไฟล์ หรือไฟล์ที่เป็น User Interface และคลิกที่วงกลมดังรูป
data:image/s3,"s3://crabby-images/a5f28/a5f28705963cda0f774cb0f57f8dc7cff93f0c44" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
คลิกที่ File's Owner
data:image/s3,"s3://crabby-images/e7316/e7316d9a05a26da3656fb71ddd24efc101357347" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เลือกมุมมองของ Editor ที่เป็นระหว่าง .xib และ .h
โดยในตัวอย่างที่จะเห็นว่าเราจะมี Textbox และ Label โดย Textbox จะรับค่า และ Label จะแสดงผล ส่วน Button จะเป็น Action หรือ Event ในขั้นตอนนนี้เราจะสร้าง IBOutlet ให้กับ Textbox และ Label
data:image/s3,"s3://crabby-images/5589e/5589e8b13244bbd1edb9a4c719c03f4f4fc30ac1" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
คลิกที่ Textbox จากนั้นให้คลิกปุ่ม Control (ที่ Keyboard) แล้วลากไปไว้ในตำแหน่ง {.....} ดังรูป (ถ้ายังไม่มีให้ใส่ปีกกาให้เรียบร้อยก่อน)
data:image/s3,"s3://crabby-images/2a23f/2a23f0f99620c71a1521d0835c98e98d0ade721f" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
กรอกชื่อว่า txtName และเลือก Connect
data:image/s3,"s3://crabby-images/79f65/79f654af5ff11d11d8bc4223c7adec1bb0416373" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เราได้ค่าตัวแปรที่ชื่อว่า txtName เป็นชนิดแบบ UITextField ที่เชื่อมกับ Interface Buillder ของ Textbox เรียบร้อยแล้ว
data:image/s3,"s3://crabby-images/d3a70/d3a70efd701dbd580973481fe0515d6a5e5d01ad" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
Label ก็ทำเช่นเดียวกัน
data:image/s3,"s3://crabby-images/c5408/c5408a729d2d3c09f8a81fe3e277b9909ca9a153" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
กรอกชื่อ lblResponse และเลือก Connect
data:image/s3,"s3://crabby-images/1ba67/1ba674ae511e636551faeff4e0e0c71bc4184447" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
ได้รายการตัวแปร Property เรียบร้อย
data:image/s3,"s3://crabby-images/ad26f/ad26f2b7c973e5ca9b88a441d9320d0b5b23a442" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
ต่อไปจะเป็น Button ให้ลากมาวางในตำแหน่งของนอกวงเล็บ ตัวนี้จะเป็น Action ซึ่งเราจะเรียกว่า Method หรือ Function ของ Class
data:image/s3,"s3://crabby-images/44d58/44d58299f8f8137623480b6cdd9b65bf935a9d0e" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เลือก Connection เป็นแบบ Action
data:image/s3,"s3://crabby-images/23df5/23df52926c595594faa3f29072ea8c2dd54b4706" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
กรอกชื่อในที่นี้ให้ลองใส่ว่า OKClick
data:image/s3,"s3://crabby-images/c8bd1/c8bd1b2a23eea9015f5dca9bc60a1f8e2caf76a9" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
รายการ Method ของ Action ได้ถูก Add ลงเรียบร้อยแล้ว
data:image/s3,"s3://crabby-images/6f5c2/6f5c26492dc816ac0f02a788671d24db7be4d2e7" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เลื่อนมาข้างบนให้คลิกที่ .h
data:image/s3,"s3://crabby-images/f8465/f84653a2d1874b7cb53b8f4290eee9de3664bbdd" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เลือกไฟล์ที่เป็น .m โดยขั้นตอนถัดไปเราจะเขียนให้โปรแกรมทำงานตามที่เราต้องการ
data:image/s3,"s3://crabby-images/90779/9077949a1292883da2381047ffd728a82b142fd1" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
สังเกตุว่าทีไฟล์ .m (implement) จะมีการสร้าง Method ให้อัตโนมัติ เราแค่ใส่คำสั่งอื่น ๆ เข้าไปก็ใช้ได้ทันที
data:image/s3,"s3://crabby-images/053cd/053cdda41e8e05c58d732563a717f6961f5b4d69" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
ทดสอบใส่คำสั่งในการแสดงผลง่าย ๆ
- (IBAction)OKClick:(id)sender
{
NSMutableString *text;
text = [NSString stringWithFormat:@" สวัสดีครับคุณ %@",[txtName text]];
lblResponse.text = text;
}
เพิ่มเติม
data:image/s3,"s3://crabby-images/af1fd/af1fd778caf5232d2d6d66e800c4393afc723dfa" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
เมื่อดูในมุมมองของ Outlet จะเห็นว่ารายการ Interface Buillder ได้ทำการเชื่อมไว้กับ Object ต่าง ๆ ได้ ในกรณีที่เราลบ Object ในหน้า Interface Builder ทิ้งไป เราจะต้องมาลบในนี้ด้วย มิฉะนั้นโปรแกรมจะ Error แล้วทำการ Build หรือ รันไม่ผ่านครับ
Screenshot
data:image/s3,"s3://crabby-images/c60fd/c60fd37c9a4c4367e8ed7c5575ccc07761c35754" alt="Objective-C IBOutlet and IBAction Objective-C IBOutlet and IBAction"
ได้ผลง่าย ๆ ดังรูป
Code ทั้งหมด
ViewController.h
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController
{
__weak IBOutlet UITextField *txtName;
__weak IBOutlet UILabel *lblResponse;
}
- (IBAction)OKClick:(id)sender;
@end
ViewController.m
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (IBAction)OKClick:(id)sender
{
NSMutableString *text;
text = [NSString stringWithFormat:@" สวัสดีครับคุณ %@",[txtName text]];
lblResponse.text = text;
}
@end
หรือจะดาวน์โหลด Code ทั้งหมดได้จากส่วนท้ายของบทความ
บทความอื่น ๆ ที่เกี่ยวข้องที่ควรศึกษา
Go to : การเขียน Coding ด้วยภาษา Objective-C กับการแสดงผลง่าย ๆ บน iOS (iPhone,iPad)
Go to : Objective-C กับการสร้าง Event และ Action (IBAction) โต้ตอบ บน iOS (iPhone,iPad)
Go to : Objective-C และ Outlet (IBOutlet) Action(IBAction) แบบง่าย ๆ ผ่าน Xcode (iPhone,iPad)
.
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/2d4e3/2d4e35bc4c7324f7288ea00d29262acd856e7488" alt="" data:image/s3,"s3://crabby-images/2d4e3/2d4e35bc4c7324f7288ea00d29262acd856e7488" alt="" |
|
|
Create/Update Date : |
2012-10-21 22:15:38 /
2017-03-25 23:02:10 |
|
Download : |
|
|
Sponsored Links / Related |
|
|
|
|
|
|
|