Есть ли способ убрать кнопку UIalertView через некоторое время?

UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"tittle"
               message:@""
                 delegate:self
              cancelButtonTitle:@""
              otherButtonTitles:nil];
  [alertView show];
  [alertView release];

Я хочу смягчить alerview после его отображения в течение некоторого времени, но когда у alertview нет кнопки, это не работает, если я вызывал -dismissWithClickedButtonIndex:animated: method и performSelector:withObject:afterDelay: есть ли другой способ отклонить его? спасибо за любые идеи!

Ответ 1

-(void)xx  {
     [self performSelector:@selector(dismissAlertView:) withObject:alertView afterDelay:2];
}
-(void)dismissAlertView:(UIAlertView *)alertView{
    [alertView dismissWithClickedButtonIndex:0 animated:YES];
}

что it.i исправить его

Ответ 2

Использовать 10 секунд задержки для отклонения

UIAlertController *alertController = [UIAlertController alertControllerWithTitle:@"" message:@"" preferredStyle:UIAlertControllerStyleAlert];
[self presentViewController:alertController animated:YES completion:nil];

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(10.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    [alertController dismissViewControllerAnimated:YES completion:^{
        p\Perform Action after dismiss alertViewController
    }];
});

Ответ 3

В Xamarin.iOS/Monotouch это сработало для меня:

private async Task ShowToast(string message, UIAlertView toast = null)
    {
        if (null == toast)
        {
            toast = new UIAlertView(null, message, null, null, null);
            toast.Show();
            await Task.Delay(2000);
            await ShowToast(message, toast);
            return;
        }

        UIView.BeginAnimations("");
        toast.Alpha = 0;
        UIView.CommitAnimations();
        toast.DismissWithClickedButtonIndex(0, true);
    }

Помните, что если асинхронный метод вызывается из фонового потока (а не основного потока пользовательского интерфейса), то InvokeOnMainThread все равно потребуется. Это означает, что вы вызываете вышеупомянутый метод следующим образом:

 BeginInvokeOnMainThread(() =>
 {
   ShowToast(message);
 });

Ответ 4

обновить ответ выше, поскольку UIAlertView есть deprecated Отвечать на эту ссылку

вторая функция должна быть такой

-(void)dismissAlertView:(UIAlertController *)alertView{

  [alertView dismissViewControllerAnimated:YES completion:nil];
}