Я пытаюсь реализовать категорию viewcontroller, которая обрабатывает uialertview. Он должен реализовать -(void) alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
, а не беспорядок, если viewcontroller также должен отображать представление предупреждения. Для этого я устанавливаю делегат uialertview на фиктивный объект внутри категории вместо self. Но мое приложение падает с exc_bad_access
, когда нажата одна из кнопок в режиме alertview. В чем проблема с приведенным ниже кодом?Реализация метода делегата UIAlertView в категории
//Dummy handler .h
@interface dummyAlertViewHandler : NSObject <UIAlertViewDelegate>
@property (nonatomic, weak) id delegate;
//.m
-(id) initWithVC:(id) dlg
{
self = [super init];
if (self != nil)
{
self.delegate = dlg;
}
return self;
}
-(void) alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
if (buttonIndex == 1)
{
[self mainMenuSegue]; //There is no problem with the method
}
}
//Category .h
#define ALERT_VIEW_DUMMY_DELEGATE_KEY "dummy"
@property (nonatomic, strong) id dummyAlertViewDelegate;
//Category .m
@dynamic dummyAlertViewDelegate;
- (void)setDummyAlertViewDelegate:(id)aObject
{
objc_setAssociatedObject(self, ALERT_VIEW_DUMMY_DELEGATE_KEY, aObject, OBJC_ASSOCIATION_ASSIGN);
}
- (id)dummyAlertViewDelegate
{
id del = objc_getAssociatedObject(self, ALERT_VIEW_DUMMY_DELEGATE_KEY);
if (del == nil)
{
del = [[dummyAlertViewHandler alloc] initWithVC:self];
self.dummyAlertViewDelegate = del;
}
return del;
}
-(void) mainMenuSegueWithConfirmation
{
UIAlertView *ruSure = [[UIAlertView alloc] initWithTitle:@"Confirm leave"
message:@"Are you sure you want to leave this game?"
delegate:self.dummyAlertViewDelegate
cancelButtonTitle:@"No"
otherButtonTitles:@"Yes", nil];
[ruSure show];
}
Именно то, что линия делает крах произойдет дальше? – matt
он напрямую переходит на сборку, я не могу ее отслеживать. Я включил точку останова для всех исключений, я думаю, что она не вызывает исключения. – guenis