IOS Как отклонить UIAlertView одним нажатием в любом месте?

Я хочу отклонить UIAlertView где-нибудь за его пределами одним нажатием. Я хочу показать UIAlertView без кнопки.

У меня есть стандартные коды UIAlertView здесь, но мне нужно указать, как отменить его, если это возможно.

С UITouch? С UITapGestureRecognizer?

Спасибо.


EDIT:

in viewDidLoad

инициализация alertview здесь с именем "alert"

     if (alert)
     {
    emptyview = [[UIView alloc]initWithFrame:CGRectMake(0,0,320,480)];
    emptyview.backgroundColor = [UIColor clearColor];
    [self.view addSubview:emptyview];
         [emptyview addSubview:alert];
    NSLog (@"emptyview is there!");

         UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleSingleTap:)];
         [emptyview addGestureRecognizer:singleTap];
         [singleTap release];            
     }

Но это пустое окно вообще не отвечает и не отвечает на селектор handleSingleTap, который я немного переписал:

-(void)handleSingleTap:(UITapGestureRecognizer *)sender{
    [alert dismissWithClickedButtonIndex:0 animated:YES];
    [emptyview removeFromSuperview];
}

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

Я пробовал:

     if (alert)
     {
    emptyview = [[UIView alloc]initWithFrame:CGRectMake(0,0,320,480)];
    emptyview.backgroundColor = [UIColor clearColor];
    [self.view addSubview:emptyview];
         [emptyview addSubview:alert];
    NSLog (@"emptyview is there!");

         UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleSingleTap:)];
         [alert addGestureRecognizer:singleTap];
         [singleTap release];            
     }

Конечно, alert реагировал на функцию handleSingleTap. Что я ошибся с пустым просмотром?


ВТОРОЙ РЕДАКТИРОВАНИЕ:

В этом случае я хочу показать небольшое представление с объяснением после выбора слова, аналогичной функции в приложении Kindle, если оно у вас есть. Может быть, я должен создать UIView вместо UIAlertView? Но маленький вид в приложении Kindle настолько хорош с тенью под ним, как это возможно?

Ответ 1

Похоже, вы пытаетесь воссоздать "Toast" на iOS. Хорошие новости, кто-то уже это сделал. Посмотрите этот проект.

Изменить: Не использовать iToast. Мне нравится ваш стиль, меньше кода. Вот что я придумал. Казалось бы очевидным, поскольку другие говорили, что единственный способ преодолеть модальный характер UIAlertView - добавить супервизор для обработки событий касания. Но вам не нужно делать это вручную каждый раз, подумайте о подклассе UIAlertView. Попробуйте что-то вроде этого:

Изменить: @wagashi, Спасибо, что согласился с моим ответом, и спасибо за то, что хедшоты о setFrame: были хорошим местом для настройки размера. Ваш код делает очень тосты, как маленькое предупреждение, однако, когда я его пробовал, я обнаружил, что если сообщение должно было долго смотреть, казалось, что развалилось. Поэтому я изменил setFrame:, чтобы просто уменьшить размер оповещения примерно на величину одной кнопки и оставаться в центре на экране. Так что класс точно отвечает на заголовок вопроса "iOS Как убрать UIAlertView с одним нажатием в любом месте?"

NoButtonAlertView.h

#import <UIKit/UIKit.h>
@interface _NoButtonAlertViewCover : UIView
@property (nonatomic,assign) UIAlertView *delegate;
@end
@interface NoButtonAlertView : UIAlertView
-(id)initWithTitle:(NSString *)title message:(NSString *)message;
@end

NoButtonAlertView.m

#import "NoButtonAlertView.h"
@implementation _NoButtonAlertViewCover
@synthesize delegate = _delegate;
-(void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event{
    [self removeFromSuperview];
    [_delegate dismissWithClickedButtonIndex:0 animated:YES];
}
@end
@implementation NoButtonAlertView
-(void)show{
    [super show];
    _NoButtonAlertViewCover *cover = [[_NoButtonAlertViewCover alloc] initWithFrame:[UIScreen mainScreen].bounds];
    cover.userInteractionEnabled = YES;
    cover.backgroundColor = [[UIColor lightGrayColor] colorWithAlphaComponent:.01];
    cover.delegate = self;
    [self.superview addSubview:cover];
}
-(id)initWithTitle:(NSString *)title message:(NSString *)message{
    if ((self = [super initWithTitle:title message:message delegate:nil cancelButtonTitle:nil otherButtonTitles:nil, nil])){
    }
    return self;
}
- (void)setFrame:(CGRect)rect {
    // Called multiple times, 4 of those times count, so to reduce height by 40
    rect.size.height -= 10;
    self.center = self.superview.center;
    [super setFrame:rect];
}
@end

С помощью этого простого подкласса UIAlertView и его подкласса UIView для обложки вы можете использовать его так же просто, как и стандартный UIAlertView. Например:

NoButtonAlertView *alert = [[NoButtonAlertView alloc] initWithTitle:@"Hello" message:@"I am the very model of a modern major general; I'm information, vegitable, animal, and mineral."];
[alert show];

Уступит:

Custom AlertView

Ответ 2

После отображения UIAlertView добавьте к вашему контроллеру (или даже к окну) новый пустой UIView с полным размером экрана. Прикрепите к этому wiew UITapGestureRecognizer

UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleSingleTap:)];
[view addGestureRecognizer:singleTap];
[singleTap release];

Теперь в методе handleSingleTap вы можете отменить UIAlertView и удалить это представление из окна

-(void)handleSingleTap:(UITapGestureRecognizer *)sender{
    [myAlert dismissWithClickedButtonIndex:0 animated:YES];
    [view removeFromSuperView];
}