之前的一个小应用中,需要通过网络下载xml文件。
在下载过程中,需要用户等待。
当时的做法是显示一个gif图片,这张图片就是一个圆圈在不停的转。数据读取结束,就删除该图片。
由于iPhone本身不支持gif图片,又去找了个开源的类专门用于显示gif。
整个过程,又长又臭。不过还算满足需求
今天看《iPhone开发秘籍》,有段代码非常优雅的完成了这个功能,如下:
- - (void) performDismiss
- {
- [baseAlert dismissWithClickedButtonIndex:0 animated:NO];
- }
- - (void) action: (UIBarButtonItem *) item
- {
- baseAlert = [[[UIAlertView alloc] initWithTitle:@"Please Wait" message:nil delegate:self cancelButtonTitle:nil otherButtonTitles: nil] autorelease];
- [baseAlert show];
- // Create and add the activity indicator
- UIActivityIndicatorView *aiv = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
- aiv.center = CGPointMake(baseAlert.bounds.size.width / 2.0f, baseAlert.bounds.size.height - 40.0f);
- [aiv startAnimating];
- [baseAlert addSubview:aiv];
- [aiv release];
- // Auto dismiss after 3 seconds
- [self performSelector:@selector(performDismiss) withObject:nil afterDelay:3.0f];
- }
首先,显示一个无按钮的alertView,然后添加一个UIActivityIndicatorView作为alertView的子视图
最后,通过alertView的dismissWithClickedButtonIndex:animated:取消显示alertView。
代码和显示效果都非常优雅
其中,UIActivityIndicatorView就是代替了我之前代码中gif图片的作用。