Question

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

je veux le alerview après avis de rejeter cela montrant pendant un certain temps, mais quand le alertview n'a pas de bouton, il ne fonctionne pas si j'invoquais -dismissWithClickedButtonIndex:animated: methodand-performSelector:withObject:afterDelay: est-il une autre façon de le rejeter? merci pour toutes les idées!

Était-ce utile?

La solution

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

que it.i est le fixer

Autres conseils

Utilisez 10 secondes retards à rejeter

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
    }];
});

Dans Xamarin.iOS / MonoTouch cela a fonctionné pour moi:

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);
    }

Rappelez-vous que si une méthode async est appelée à partir d'un fil d'arrière-plan (pas le principal thread d'interface utilisateur), alors InvokeOnMainThread serait encore nécessaire. Ce juste signifie que vous appelez la méthode ci-dessus comme ceci:

 BeginInvokeOnMainThread(() =>
 {
   ShowToast(message);
 });
mise à jour

à la réponse ci-dessus UIAlertView est deprecated réponse à ce lien

la 2ème fonction doit être comme ceci

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

  [alertView dismissViewControllerAnimated:YES completion:nil];
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top