Как установить UIActivityIndicatorView при загрузке UITableViewCell - PullRequest
35 голосов
/ 27 августа 2011

У меня есть два UITableViewController s, A и B. Когда я нажимаю одну ячейку в таблице A, я буду использовать UINavigationController, чтобы протолкнуть контроллер представления таблицы B. Но данные B загружаются из Интернета, что занимает несколькосекунд.Поэтому я хочу добавить UIActivityIndicatorView при загрузке B. Как мне этого добиться?

Ответы [ 5 ]

51 голосов
/ 27 августа 2011

Вы можете добавить UIActivityIndicatorView как accessoryView ячейки .

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {

    UIActivityIndicatorView *spinner = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
    spinner.frame = CGRectMake(0, 0, 24, 24);
    UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
    cell.accessoryView = spinner;
    [spinner startAnimating];
    [spinner release];
}
30 голосов
/ 27 августа 2011

В viewDidLoad класса B. просмотра таблицы добавьте индикатор активности.

// Create the Activity Indicator.
    let activityIndicator = UIActivityIndicatorView(activityIndicatorStyle: .gray)
    activityIndicator.hidesWhenStopped = true
    view.addSubview(activityIndicator)

    // Position it at the center of the ViewController.
    activityIndicator.translatesAutoresizingMaskIntoConstraints = false
    NSLayoutConstraint.activate([
        activityIndicator.centerXAnchor.constraint(equalTo: view.centerXAnchor),
        activityIndicator.centerYAnchor.constraint(equalTo: view.centerYAnchor)])
    activityIndicator.startAnimating()

Теперь вызовите свой метод для загрузки данных из сети.

myDownloadMethod()

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

прочитайте эту ветку для этого. Можно ли использовать фоновый поток для анализа данных?

Когда вы получите уведомление о загрузке содержимого, остановите индикатор.

activityIndicator.stopAnimating()

Теперь вы можете позвонить tableview.reloadData() для перезагрузки таблицы для отображения нового содержимого.

8 голосов
/ 11 апреля 2013
UIActivityIndicatorView * activityindicator1 = [[UIActivityIndicatorView alloc]initWithFrame:CGRectMake(150, 200, 30, 30)];
[activityindicator1 setActivityIndicatorViewStyle:UIActivityIndicatorViewStyleWhiteLarge];
[activityindicator1 setColor:[UIColor orangeColor]];
[self.view addSubview:activityindicator1];
[activityindicator1 startAnimating];

[self performSelector:@selector(callfunction) withObject:activityindicator1 afterDelay:1.0];

-(void)callfunction
{
// Here your stuf
}
4 голосов
/ 01 июня 2015

Это хорошо для меня, вы можете попробовать это:
[activityIndicator startAnimating ], когда didHighlightRowAtIndexPath , [activityIndicator stopAnimating ], когда didUnhighlightRowAtIndexPath полезнее, чем didSelectRowAtIndexPath.

- (void)runIndicatorAtIndexPath:(NSIndexPath *)indexPath display:(BOOL)playing{ 
    UIActivityIndicatorView *activityIndicator = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
    UITableViewCell *cell = [self.tableView cellForRowAtIndexPath:indexPath];
    cell.accessoryView = activityIndicator;
    playing == YES ?[activityIndicator startAnimating]:[activityIndicator stopAnimating];
}
- (void)tableView:(UITableView *)tableView didHighlightRowAtIndexPath:(NSIndexPath *)indexPath {
    [self runIndicatorAtIndexPath:indexPath display:YES];
}
- (void)tableView:(UITableView *)tableView didUnhighlightRowAtIndexPath:(NSIndexPath *)indexPath{
    [self runIndicatorAtIndexPath:indexPath display:NO];
}
3 голосов
/ 31 августа 2016

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

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    /* set cell attributes here */
    NSInteger lastSectionIndex = [tableView numberOfSections] - 1;
    NSInteger lastRowIndex = [tableView numberOfRowsInSection:lastSectionIndex] - 1;
    if ((indexPath.section == lastSectionIndex) && (indexPath.row == lastRowIndex)) {
           if(isMoreDataAvailableOnserver)
           {
            [self showSpinnerAtFooter];
            [self getMoreDataFromServer];
           }
           else
           {
            [self hideSpinnerAtFooter];
           }
    }
    return cell;
}
-(void) hideSpinnerAtFooter {
    self.tableView.tableFooterView =nil;
}
-(void) showSpinnerAtFooter {
    UIActivityIndicatorView *spinner = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
    [spinner startAnimating];
    spinner.frame = CGRectMake(0, 0, 320, 44);
    self.tableView.tableFooterView = spinner;
}
...