题
我有一个简单的视图,当用户按下按钮时,使用 PresentMoviePlayerViewControllerAnimated 创建 MPMoviePlayerViewController:方法。新的视图控制器滑入并显示电影播放器,到目前为止一切顺利。
但是,当按下按钮时,当前视图控制器会滑出底部,显示丑陋的(可能是默认的)白色视图,该视图会在任何地方停留半秒到几秒,直到显示电影视图控制器。看起来它依赖于我的网络连接,就好像电影视图控制器在显示播放器之前下载电影的部分内容一样。
我做错了什么吗,或者我该如何解决这个问题?我真的更喜欢直接显示电影视图控制器,甚至可能不需要滑出之前保存播放按钮的视图控制器,但仍然像模态视图控制器一样进行动画处理。
谢谢!
克里斯托夫
解决方案 2
我最终只是将视图的背景设置为黑色。不修复延迟,但使其看起来更好:
theMovieVC.view.backgroundColor = [UIColor blackColor];
其他提示
解决方案是在创建父视图时初始化播放器视图控制器,然后调用 prepareToPlay
于 moviePlayer
在里面。这消除了按下播放按钮时的延迟,并且(我猜)将其移动到用户到达可以播放电影的父视图时。
编辑:这消除了延迟,但由于某种原因,初始化电影视图控制器也会在加载时自动播放它,所以这不是一个好的解决方案。
这就是我为 iOS > 3.2 所做的:
- (void) play {
mMoviePlayer = [[MPMoviePlayerController alloc] initWithContentURL:mMovieURL];
if ([mMoviePlayer respondsToSelector:@selector(loadState)])
{
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(moviePreloadDidFinishIOS32:)
name:MPMoviePlayerContentPreloadDidFinishNotification
object:nil];
[mMoviePlayer prepareToPlay];
[mMoviePlayer play];
mMoviePlayer.controlStyle = MPMovieControlStyleEmbedded;
[mMoviePlayer setMovieControlMode:MPMovieControlModeDefault];
[mMoviePlayer setBackgroundColor:[UIColor clearColor]];
}
}
和
- (void) moviePreloadDidFinishIOS32:(NSNotification*)notification;
{
// Remove observer
[[NSNotificationCenter defaultCenter]
removeObserver:self
name:MPMoviePlayerContentPreloadDidFinishNotification
object:nil];
self.view = mMoviePlayer.view;
}
因此,在 viewdidload 中,您可以实例化您想要的内容(例如 UIActivityIndicatorView)。仅当预加载完成后,视图控制器才会被替换。
我在我的应用程序中注意到同样的问题。有人有避免这个问题的建议吗?
就我而言,我将 MPMoviePlayerViewController 作为模式弹出窗口推送到 UI。
// build the movie player
[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
MPMoviePlayerViewController *movieViewController = [[[MPMoviePlayerViewController alloc] initWithContentURL:request.URL] autorelease];
[movieViewController.moviePlayer prepareToPlay];
movieViewController.view.backgroundColor = [UIColor blackColor];
// show the movie player view
[self.parentViewController presentModalViewController:movieViewController animated:YES];
不隶属于 StackOverflow