ПРОГРАММИРОВАНИЕ ПОД IPHONE, IPAD OBJECTIVE-C часть 2

Добавляем таблицу на View

Часто случается так, что у нас уже есть готовый проект, в нем отсутствует UINavigationController, а нам нужно отобразить набор данных в таблице. В этом примере я покажу как это сделать.

 

 

Давайте создадим новый проект, но в котором не будет готового кода для работы с таблицами (на основе представления View-based Application). Я назвал свой проект AddTableView.

 

В первую очередь изменим интерфейс класса AddTableViewViewController:

 

<code data-result="[object Object]">#import &lt;UIKit/UIKit.h&gt;

@interface AddTableViewViewController : UIViewController 
&lt;UITableViewDelegate, UITableViewDataSource&gt; 
{
    UITableView *addTable;
    NSArray *students;
}

@property (nonatomic, retain) IBOutlet UITableView *addTable;
@property (nonatomic, retain) NSArray *students;

@end</code>

 

В момент объявления интерфейса, после указания от какого класса унаследован наш класс между знаками <> мы указываем протокол класса UITableView. Без указания протокола методы таблицы не будут вызываться. Затем мы создаем саму таблицу и создаем для нее источник данных. Затем прописываем свойства на только что объявленых переменных. В случае с addTable к свойствам мы добавили IBOutlet т. к. эта таблица будет связана с интерфейсом.

 

В реализации класса AddTableViewViewController следует синтезировать методы доступа для наших объектов и организовать очистку памяти. В методе viewDidLoad инициализируем и заполним наш массив, как мы это делали раньше.

 

<code data-result="[object Object]">- (void)viewDidLoad
{
    [super viewDidLoad];
    self.students = [NSArray arrayWithObjects:@"Tom", @"Bill", @"Tom", @"Joe", @"Tom", nil];
}</code>

 

Теперь добавим уже известные нам методы для работы с таблицами:

 

<code data-result="[object Object]">- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return students.count;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault 
                                       reuseIdentifier:CellIdentifier] autorelease];
    }

    cell.textLabel.text = [students objectAtIndex:indexPath.row];

    return cell;
}</code>

 

Я не буду описывать, что происходит в этих методах и за что они отвечают т. к. уже делал это в предыдущих примерах работы с таблицами.

 

Работа с кодом закончена, осталось добавить нашу таблицу в интерфейс и связать ее с написанным кодом. Для этого нажмите один раз левой кнопкой мышки на файл AddTableViewViewController.xib, который находится у вас в проекте и добавьте на него объект Table View с библиотеки объектов. Мой интерфейс выглядит вот так:

 

 

После добавления таблицы ее следует связать с кодом, для этого откройте правую панель и перейдите на вкладку инспектора соединений. Рядом с объектом New Referencing Outlet вы увидите круг. Щелкните на нем и перетащите на объект File’s Owner.

 

 

После того как вы отпустите кнопку мышки — появится всплывающее меню, в котором выберите только что созданную таблицу (addTable).

 

 

Как вы заметили, объекта Table View в инспекторе соединений присутствует еще два поля, это dataSource и delegate и возле них так же находится круг, такой же как возле New Referencing Outlet. Щелкните на нем и перетащите на объект File’s Owner (в момент отпускания мышки всплывающего меню не будет). На этом работа с интерфейсом закончена, можете запускать проект на выполнение.

 

Исходный код можно скачать здесь.