Невозможно связать мой контроллер табличного представления на раскадровке с моим кодом

Я пишу приложение в XCode6. В настоящее время у меня есть "SelectionTableViewController.h" и "SelectionTableViewController.m", чтобы вы могли добавлять / удалять галочки на select. Кроме того, у меня есть контроллер представления таблицы в раскадровке, который запускается статической ячейкой в ​​предыдущем контроллере представления таблицы. Я установил триггер в раскадровке, чтобы не писать код для "подготовки к переходу" или чего-либо еще. Я хочу, чтобы ячейка была проверена по умолчанию, поэтому я сделал следующее:

  • Изменен контроллер представления на "SelectionTableViewController"
  • Установите идентификатор ячейки прототипа на моей раскадровке в "SelectionCell"
  • Изменен цвет фона ячейки на оранжевый и добавлен флажок

Ниже мой SelectionTableViewController.m:

@implementation SelectionTableViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    [self.tableView registerClass:[UITableViewCell class]
           forCellReuseIdentifier:@"SelectionCell"];
}

- (void)viewWillAppear:(BOOL)animated
{
    [super viewWillAppear:animated];
    [self.navigationController setNavigationBarHidden:NO];
    self.navigationItem.title = @"Select";
    [self.tableView reloadData];
}

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    // Return the number of sections.
    return [[[MyStore sharedStore] allCategories] count];
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // Return the number of rows in the section.
    NSString *category = [[[MyStore sharedStore] allCategories] objectAtIndex:section];
    return [[[MyStore sharedStore] allNamesForCategory: category] count];
}


- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath(NSIndexPath*)indexPath
{
    UITableViewCell *cell=[tableViewdequeueReusableCellWithIdentifier:@"SelectionCell"forIndexPath:indexPath];

    // Configure the cell...
    NSString *category = [[[MyStore sharedStore] allCategories] objectAtIndex:indexPath.section];
    NSArray *items = [[MyStore sharedStore] allNamesForCategory: category];

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

    return cell;
}
#pragma mark - Table view delegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
    if (cell.accessoryType == UITableViewCellAccessoryCheckmark) {
        cell.accessoryType = UITableViewCellAccessoryNone;
    } else {
        cell.accessoryType = UITableViewCellAccessoryCheckmark;
    }
}


- (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
{
    return [[[MyStore sharedStore] allCategories] objectAtIndex:section];
}

@end

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

Надеюсь, что кто-то может помочь мне в этом, так как я немного новичок в программировании на iOS, и я впервые использую раскадровку. Спасибо!

2 ответа

Решение

Я понял это сам! Я удалил код, который зарегистрирован "Выбор ячейки". Затем я сделал небольшие изменения в cellForRowAtIndexPath

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath(NSIndexPath*)indexPath
{
    Static NSString *selectionCell = @"SelectionCell"; 
    UITableViewCell *cell=[tableViewdequeueReusableCellWithIdentifier:selectionCell forIndexPath:indexPath];

    // Omit...
}

Проблема с вашей реализацией tableView:didSelectRowAtIndexPath будет вызван только взаимодействием с пользователем, поэтому первоначальный выбор не отображается. Вам нужно будет сделать tableView знать о состоянии выбора также во время инициализации, иначе отмена выбора не будет работать, как ожидалось.

class ViewController: UITableViewController {

    var selectedItem: Int = 5

    func updateSelection(selected: Bool, forCell cell: UITableViewCell) {
        cell.accessoryType = selected ? .Checkmark : .None
        // update other cell appearances here..
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell")
    }

    override func viewWillAppear(animated: Bool) {
        super.viewWillAppear(animated)
        // Note: happens after the initial tableView.reloadData()
        // Let tableView know who's selected before we appear, so that tableView is aware of the selection state.
        // Doing so will enable tableView to know which cell to deselect after a new selection.
        tableView.selectRowAtIndexPath(NSIndexPath(forItem: selectedItem, inSection: 0), animated: true, scrollPosition: .Middle)
    }

    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 10
    }

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("Cell") as UITableViewCell
        cell.textLabel?.text = "Item \(indexPath.item)"
        // Setup the selection appearance during cell creation
        updateSelection(indexPath.item == selectedItem, forCell: cell)
        return cell
    }

    override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        // Keep track of the selection, and update cell appearance
        selectedItem = indexPath.item
        updateSelection(true, forCell: tableView.cellForRowAtIndexPath(indexPath)!)
    }

    override func tableView(tableView: UITableView, didDeselectRowAtIndexPath indexPath: NSIndexPath) {
        // As above
        updateSelection(false, forCell: tableView.cellForRowAtIndexPath(indexPath)!)
    }

}
Другие вопросы по тегам