Friday, November 17, 2006

IBOutlet

เมื่อวานไป train เรื่อง cocoa ที่ทาง Apple จัดให้ฟรีมา
มีประเด็นติดใจเรื่อง IBOutlet
ว่าจริงๆแล้วมันคืออะไร
ประเด็นหลักๆที่เป็นจุดเริ่มต้น ก็คือ
ใน XCode การ paint หน้าจอ gui เราจะทำผ่าน Interface Builder
ทุกอย่างที่ paint หรือ compose จะเก็บไว้ pack ในโครงสร้างที่เรียกว่า NIB file
ซึ่งมันตรงข้ามกับ approch ของ java ที่เวลาเรา paint gui
สิ่งต่างๆที่ paint หรือ setting จะถูก generate ออกมาในรูป java code
,ดังนั้นพวก widget ต่างๆของ swing
ที่เราเลือก paint ลงไป จะเห็นเป็นตัวแปรกันจะๆ ใน source code เลย
ถ้าอยาก customize widget ไหน
ก็สามารถเขียน code เข้าไปแก้ได้ทันที

ประเด็นคำถามที่เกิดขึ้นเมื่อวาน ก็คือ แล้วถ้าเราอยาก access object ต่างๆ
ที่อยู่ใน gui หล่ะ เราจะทำอย่างไร
เช่นอยากเข้าไป customize format ของ NSTextfield
มีคำตอบหนึ่งที่ได้มา ก็คือการใช้ IBOutlet
แต่ก็เป็นคำตอบที่เลาๆ คือไม่ exactly ว่า IBOutlet คืออะไร

Note: สำหรับคนที่ไม่รู้จัก IBOutlet
ลองดูตัวอย่างภาพการใช้งาน

@interface ConverterController : NSObject
{
IBOutlet NSTextField *amountField;
IBOutlet Converter *converter;
IBOutlet NSTextField *dollarField;
IBOutlet NSTextField *rateField;
}


ลองหานิยามของ IBOutlet ใน AppKit ดู
จะพบว่ามันอยู่ใน file
<AppKit/NSNibDeclarations.h>
และมีนิยามแบบนี้

#ifndef IBOutlet
#define IBOutlet
#endif

Bingo, มันคือ macro เปล่าๆ ที่ไม่มีผลในการ compile
ดังนั้นสำหรับผมแล้ว IBOutlet คือ marker อันหนึ่งใน source code
ที่ถูกใช้โดย interface builder
(IB ที่เห็นเป็น prefix ของ IBOutlet ย่อมาจาก Interface Builder)
ทำให้เราสามารถลากโยง(ผ่านทาง GUI)
ให้ instance (controller)
สามารถ access UI widget ที่เราต้องการได้
หรือถ้าพูดในมุมมองของ oop, IBOutlet
ช่วยให้เรากำหนด relationship ระหว่าง object
ผ่านทาง GUI tool (drag-drop).

สำหรับประเด็นในตอน runtime
นั้นขึ้นอยู่กับ strategy การเก็บ Nib file
ของ apple ว่าเป็นแบบ pure serialize, pure definition,
หรือ definition + serialize
(pure definition ถ้ายกตัวอย่างก็เช่น xul ของ mozzila)
ถ้าการเก็บมีรูปแบบของ definition เข้ามาปน
ก็จะมีประเด็นว่า หลังจาก initialize object ขึ้นมา จาก definition file แล้ว
ก็จะต้องมีการ set dependency ตาม relationshipt ที่ได้ define ไว้

Related link from Roti

1 comment:

Isriya said...

รอบนี้มันจัดวันธรรมดา (ยัง) ไม่กล้าโดนงานไป

แต่เพิ่งมีคนบอกว่าผมเหมาะกับเป็น community builder มากกว่า ไม่ต้องเขียนหรอกโปรแกรมน่ะ เชื่อใครดีฟะ