Лист действий попадает на вкладку - PullRequest
0 голосов
/ 09 декабря 2010

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

Я недавно изменил способ отображения листа действий с «showInView» на «showFromTabBar» и не уверен, что это создает проблему.

Спасибо, William

Edit:

Ниже приведен код, который я использую для отклонения моего списка действий:

-(void)doneButtonPressed:(id)sender{



    if ([[self viewWithTag:1] isKindOfClass:[PickerView class]]) {

        PickerView *picker = (PickerView *)[self viewWithTag:1];

        if (picker.selectedRow == nil) {
            [picker populateSelectRowForRow:0 andComponent:0];
        }

        NSNotification *note = [NSNotification notificationWithName:@"doneButtonPressed" object:self.indexPath userInfo:picker.selectedRow];

        [[NSNotificationCenter defaultCenter] postNotification:note];

    }else {

        DatePickerView *picker = (DatePickerView *)[self viewWithTag:1];

        NSDictionary *extraInfo = [[NSDictionary alloc] initWithObjects:[[NSArray alloc] initWithObjects:[self formatDateToString:[picker date]], nil] forKeys:[[NSArray alloc] initWithObjects:@"value", nil]];

        NSNotification *note = [NSNotification notificationWithName:@"doneButtonPressed" object:self.indexPath userInfo:extraInfo];

        [[NSNotificationCenter defaultCenter] postNotification:note];
    }


    [self dismissWithClickedButtonIndex:0 animated:YES];
}

и метод уведомления, который вызывается:

-(void)pickerUpdate:(NSNotification *)note{

    NSIndexPath *indexPath = [note object];
    NSDictionary *extraInfo = [note userInfo];

    NSDictionary *dict = [[tableController.sectionAndFields objectAtIndex:indexPath.section] objectAtIndex:(indexPath.row + kHeaderAndFooterOffset)];

    [tableController.formDetails setObject:[extraInfo objectForKey:@"value"] forKey:[dict objectForKey:@"key"]];

    NSArray *reloadArray = [[NSArray alloc] initWithObjects:indexPath, nil];
    [indexPath release];

    [self.tv reloadRowsAtIndexPaths:reloadArray withRowAnimation:NO];
    [reloadArray release];


}

1 Ответ

0 голосов
/ 13 января 2011

Мне удалось решить эту проблему, но это очень похоже на взлом, я ввел задержку в код, используя:

[self performSelector:@selector(dismissFromActionSheet) withObject:nil afterDelay:0.2];

с dismissFromActionSheet, являющимся:

-(void)dismissFromActionSheet{
 [self dismissWithClickedButtonIndex:0 animated:YES];
}
...