iOS/iPhone Table View(UITableView) Sections from an NSArray/NSMutableArray/NSDictionary (Objective-C,iPhone, iPad) |
iOS/iPhone Table View(UITableView) Sections from an NSArray/NSMutableArray/NSDictionary (Objective-C,iPhone, iPad) บทความกน่อนหน้านี้เราได้รู้วิธีการสร้าง Table View และ Section แบบ Static Cell แล้ว และบทความนี้เรามารู้วิธีการสร้างแบบ Dynamic Cell ที่ดึงและอ่านข้อมูลต่าง ๆ มาจาก Array จากนั้นก็ทำการแสดงผลตาม Section ของข้อมูลที่อยู่ในรูปแบบตามที่กำหนดขึ้น
iOS/iPhone Table View(UITableView) Sections from an NSArray/NSMutableArray/NSDictionary
และเพื่อให้ได้ข้อมูลที่อยุ่ในรุปแบบเป็นแบบ Array ที่ประกอบด้วยหลาย Key และ Value เราจะต้องใช้ NSMutableArray ทำงานรวมกับ NSDictionary ซึ่งภายในแต่ล่ะ Index ของ NSMutableArray ก็จะประกอบด้วย NSDictionary ที่ประกอบด้วย Key และ Value ต่าง ๆ ตามตัวอย่าง
//Initialize the array.
listOfItems = [[NSMutableArray alloc] init];
// Section Group 1
NSArray *arrGroup1 = [NSArray arrayWithObjects:@"Item 1", @"Item 2", @"Item 3", @"Item 4", nil];
NSDictionary *dictGroup1 = [NSDictionary dictionaryWithObject:arrGroup1 forKey:@"GroupItem"];
// Section Group 2
NSArray *arrGroup2 = [NSArray arrayWithObjects:@"Item 5", @"Item 6", @"Item 7", @"Item 8", nil];
NSDictionary *dictGroup2 = [NSDictionary dictionaryWithObject:arrGroup2 forKey:@"GroupItem"];
[listOfItems addObject:dictGroup1];
[listOfItems addObject:dictGroup2];
เริ่มต้นการสร้าง Project บน Xcode เพื่อสร้าง Dynamic Cell แบบ Sections
data:image/s3,"s3://crabby-images/66e01/66e010bd6db59b2bfd255062aff6aba2d2c8c74d" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
สร้าง Application แบบ Single View Application
data:image/s3,"s3://crabby-images/261e6/261e6bef3c27c5d86e3411d54feaa49ce060584e" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
เลือกและไม่เลือกรายการดังรูป
data:image/s3,"s3://crabby-images/60b60/60b60e55f5c7beabc50a145d622d6b04f18dea4f" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
หลังจากนั้นเราจะได้ View บนไฟล์ .xib ที่ยังเป็นหน้าจอขาว ๆ ว่างเปล่า ให้ลาก Table View มายังวางไว้ที่ View หลัก
data:image/s3,"s3://crabby-images/f8ce9/f8ce9bc305a8fba4fc9b3a49183812c211490b32" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
สร้าง IBOutlet ให้กับ Table View
data:image/s3,"s3://crabby-images/80778/8077838333e2bf8e83eabcd15bc50c035c75cb5e" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
ได้ IBOutlet ดังรูป
data:image/s3,"s3://crabby-images/28599/28599a03dc7d93e6c34603c1bff35409d0bc16d0" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
คลิกขวาที่ Table View จะได้หน้าจอดังรูป
data:image/s3,"s3://crabby-images/dcb4f/dcb4f1e6dda06bea38b6d6128f0a1170c642ba98" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
ทำการลาก dataSource ไปยังตำแหน่งของ File's Owner
data:image/s3,"s3://crabby-images/5674d/5674d72765bce9695bbe63cd351a233ea7f9a5b9" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
เชื่อม delegate ด้วย
data:image/s3,"s3://crabby-images/c91a7/c91a7070ebef16095c64385fa61fff9efd15cdc1" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
จะได้ผลลัพธ์ดังรูป จากนั้นจะเป้นส่วนของ Coding ด้วยภาษา Objective-C
ViewController.h
//
// ViewController.h
//
// Created by Weerachai on 11/3/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController
@property (retain, nonatomic) IBOutlet UITableView *myTable;
@end
ViewController.m
//
// ViewController.m
//
// Created by Weerachai on 11/3/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
{
NSMutableArray *listOfItems;
}
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
//Initialize the array.
listOfItems = [[NSMutableArray alloc] init];
// Section Group 1
NSArray *arrGroup1 = [NSArray arrayWithObjects:@"Item 1", @"Item 2", @"Item 3", @"Item 4", nil];
NSDictionary *dictGroup1 = [NSDictionary dictionaryWithObject:arrGroup1 forKey:@"GroupItem"];
// Section Group 2
NSArray *arrGroup2 = [NSArray arrayWithObjects:@"Item 5", @"Item 6", @"Item 7", @"Item 8", nil];
NSDictionary *dictGroup2 = [NSDictionary dictionaryWithObject:arrGroup2 forKey:@"GroupItem"];
[listOfItems addObject:dictGroup1];
[listOfItems addObject:dictGroup2];
//Set Title
self.navigationItem.title = @"Group Option Item";
}
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return [listOfItems count];
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
NSDictionary *dictionary = [listOfItems objectAtIndex:section];
NSArray *array = [dictionary objectForKey:@"GroupItem"];
return [array count];
}
- (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section {
if(section == 0)
return @"Group 1";
else
return @"Group 2";
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
// Use the default cell style.
cell = [[[UITableViewCell alloc] initWithStyle : UITableViewCellStyleSubtitle
reuseIdentifier : CellIdentifier] autorelease];
}
NSDictionary *dictionary = [listOfItems objectAtIndex:indexPath.section];
NSArray *array = [dictionary objectForKey:@"GroupItem"];
NSString *cellValue = [array objectAtIndex:indexPath.row];
cell.textLabel.text = cellValue;
return cell;
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (void)dealloc {
[_myTable release];
[super dealloc];
}
@end
สำหรับ Code ลองไล่ดูครับ ไม่ยากอะไรมากมาย
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
Screenshot
data:image/s3,"s3://crabby-images/bd317/bd3171ff2e7dbd0ae7fd449647787140e69717d6" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
ได้ Table View ที่แบางตาม Section ดังรูป
เพิ่มเติม
data:image/s3,"s3://crabby-images/66d43/66d438e582ee68bd0483bc11fed59b8b89130d5e" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
ลองเปลี่ยนมุมมอง Style ให้เป็นแบบ Grouped
data:image/s3,"s3://crabby-images/7a2d9/7a2d9e8431b492ef5d2c509bd1a6fb043fa0739f" alt="iOS/iPhone Table View(UITableView) Sections from an NSArray iOS/iPhone Table View(UITableView) Sections from an NSArray"
ได้ Sections ที่เป็นแบบ Group สวยงาม
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน 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="" |
|
|
Create/Update Date : |
2012-11-07 10:36:27 /
2017-03-26 09:44:01 |
|
Download : |
|
|
Sponsored Links / Related |
|
|
|
|
|
|
|