0

我有一个正在等待连接的应用程序。在应用程序等待时,我需要向用户显示 AlertView,它应该在某个时间后以编程方式或通过用户单击 AlertView 的取消按钮来关闭。

主线程正在等待客户端连接,而在另一个线程中,我正在创建并显示正在更新对话框时间的 AlertView。该线程有一个 NSRunLoop,它更新 AlertView 上的文本。

一切正常,除了 AlertView 不接收触摸事件,甚至它没有以编程方式被解雇。任何人都可以对我在这里可能做错的事情有所了解。

这是示例代码。

funcA() {

    [NSThread detachNewThreadSelector:@selector(createDialog) toTarget:self withObject:nil];

    [NSThread detachNewThreadSelector:@selector(updateDialog) toTarget:self withObject:nil];

    ..

    ..

    BlockingWait();

    ..

    ..

}

- (void) createDialog {

    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];

    alert = [[UIAlertView alloc] initWithTitle:@"Wait" message:@"\n" delegate:self cancelButtonTitle:@"Cancel" otherButtonTitles:nil];

    ...

    label = [[UILabel alloc] initWithFrame:CGRectMake(30.0f, 20.0f, 225.0f, 90.f)];

    [alert show];

    [alert release];

    [pool drain];

}

- (void) upDateDialog {

    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];

    NSRunLoop *loop = [NSRunLoop currentRunLoop];

    timer =  [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(updateText) userInfo:nil repeats:YES];

    [loop run];

    [pool drain];
}

- (void) updateText {

    label.text = " Wait for" + n +  "secs";

    n--;

    if ( n == 0 )
      [alert dismissWithClickedButtonIndex:0 animated:YES];  // Doesn't work
}


- (void) alertView: (UIAlertView *) alert clickedButtonAtIndex:(NSInteger) buttonIndex {
// Never Gets called
    NSLog(@"Alert is dissmissed with button index %d", buttonIndex);

    if (buttonIndex == 0) {

        [timer invalidate];
    }
}
4

2 回答 2

2

我什至没有阅读你的代码,只是标题已经表明你真的应该在你的架构上工作。您可以尝试破解 UIKit,但它被设计为仅由 UI 线程管理。因此,将您的阻塞调用移动到一个线程中并从主线程管理 UIAlertView。

于 2012-01-16T15:46:11.240 回答
0

永远不要阻塞主线程。永远不会。异步UIAlertView创建,在你做其他工作时将其保存在 ivar 中,并根据需要进行更新。您根本不太可能需要任何线程或阻塞。只需使用NSURLConnection异步来管理连接而不会阻塞。

于 2012-01-16T15:50:10.277 回答