2014-10-22 4 views
0

У меня есть UIViewController, который состоит из двух половинок (они на самом деле находятся в UIContainerViews). 1 половина содержит UIWebView, который используется для отображения PDF, а другая половина содержит UIView, который используется для потоковой передачи видео.Видео не воспроизводится на mpmovieplayercontroller после модального полноэкранного iOS 8

Там есть навигационная панель с UIWebView с UIButton при нажатии на которую представляет модальный UIWebView в полноэкранном режиме:

- (IBAction)pressedFullscreenButton:(id)sender 
{ 
    // pause the video view controller 
    self.videoViewController.videoPlayer pause]; 

    // perform the segue - this is modal, full screen 
    [self performSegueWithIdentifier:@"FullscreenSegue" sender:self]; 
} 

Так я нажмите кнопку полного экрана, видео паузу, и мой PDF/UIWebView представлен в виде модального, полноэкранного. Когда я увольняю этот полноэкранный контроллер, чтобы вернуться на мой экран разделения, когда я нажимаю кнопку воспроизведения на видео, звук воспроизводится, но видео нет, и я не могу понять, почему жизнь - любая помощь будет действительно оценили.

Чтобы обойти это, и это не мое предпочтительное решение, я в основном получаю текущее время видео, останавливаю его, устанавливаю текущее время, воспроизвожу видео и мгновенно приостанавливаю его, когда появляется контроллер вида. Вот мой код:

Так я использую MPMoviePlayerController, который я завернутую в класс под названием StandardVideoPlayer:

@implementation StandardVideoPlayer 


-(id)initWithParentView:(UIView *)parent andAutoPlay:(BOOL)autoPlay andFullScreen:(BOOL)fullScreen andAnimated:(BOOL)animated 
{ 
    // Call superclass's initializer 
    self = [super init]; 
    if(!self || !parent) 
    { 
    return nil; 
    } 
    else 
    { 
    if (!_moviePlayerController) 
    { 
     _moviePlayerController = [[MPMoviePlayerController alloc] init]; 
    } 

    _moviePlayerController.controlStyle = MPMovieControlStyleDefault; 
    [_moviePlayerController.view setFrame:parent.frame]; 
    [_moviePlayerController.view setCenter:parent.center]; 
    _moviePlayerController.allowsAirPlay = YES; 
    _moviePlayerController.shouldAutoplay = autoPlay; 
    [_moviePlayerController setFullscreen:fullScreen animated:animated]; 

    [parent addSubview: [self videoView]]; 
    } 

    return self; 
} 

-(void)loadFromFile: (NSString*) filePath; 
{ 
    if (_moviePlayerController) 
    { 
    NSURL *fileUrl = [NSURL fileURLWithPath:filePath]; 
    [_moviePlayerController setContentURL:fileUrl]; 
    [_moviePlayerController prepareToPlay]; 
    } 
} 

- (void)loadFromURL: (NSString*) urlString 
{ 
    if ([[ConnectionManager sharedInstance] canConnect]) 
    { 
    if (_moviePlayerController) 
    { 
     NSURL *url = [NSURL URLWithString:urlString]; 
     [_moviePlayerController setContentURL:url]; 
     [_moviePlayerController prepareToPlay]; 
    } 
    } 
    else 
    { 
    [[ConnectionManager sharedInstance] displayConnectionWarningWithText:@"Ok" andDelegate:nil]; 

    } 

} 

-(void)loadFromHTML:(NSString *)html 
{ 
    // NSString *h = [NSString stringWithFormat:html, ] 
} 

-(void)play 
{ 
    if (_moviePlayerController) 
    { 
    [_moviePlayerController prepareToPlay]; 
    [_moviePlayerController play]; 
    } 
} 

-(void)stop 
{ 
    if (_moviePlayerController) 
    { 
    [_moviePlayerController stop]; 
    } 
} 

-(void)pause 
{ 
    if (_moviePlayerController) 
    { 
    [_moviePlayerController pause]; 
    } 
} 

// use this to get the view form the moviePlayerController...... 
-(UIView*)videoView 
{ 
    UIView *view = nil; 
    if (_moviePlayerController) 
    { 
    view = _moviePlayerController.view; 
    } 

    return view; 
} 


@end 

, а затем в контроллере представления я есть:

@implementation VideoViewController 

// lazy initialiser 
- (StandardVideoPlayer*) videoPlayer 
{ 
    if (!_videoPlayer) 
    { 
    _videoPlayer = [[StandardVideoPlayer alloc] initWithParentView:self.view andAutoPlay:NO andFullScreen:NO andAnimated:YES]; 
    } 
    return _videoPlayer; 
} 

- (void) viewDidLoad 
{ 
    [super viewDidLoad]; 

    self.initialised = NO; 
    self.wasPDFScreen = NO; 
    self.isFullScreen = NO; 
    [self.spinner stopAnimating]; 
    self.spinner.hidesWhenStopped = YES; 

    [GlobalStore sharedInstance].videoViewController = self; 
} 

-(void) willEnterFullScreen 
{ 
    self.isFullScreen = YES; 
} 

-(void)loadStateChanged 
{ 
    MPMovieLoadState state = [self.videoPlayer.moviePlayerController loadState]; 
    if (state & MPMovieLoadStatePlayable) 
    { 
    [self.spinner stopAnimating]; 
    } 
} 

-(void) customInit 
{ 
    if (!self.initialised) 
    {   
    [self.view setBackgroundColor:[UIColor blackColor]]; 
    [self.videoPlayer.videoView setBackgroundColor:[UIColor blackColor]]; 

    // set a border 
    CGFloat borderWidth = 1.0f; 

    self.videoPlayer.videoView.frame = CGRectInset(self.videoPlayer.videoView.frame, -borderWidth, -borderWidth); 
    self.videoPlayer.videoView.layer.borderColor = BORDER_COLOUR; 
    self.videoPlayer.videoView.layer.borderWidth = borderWidth; 

    self.view.frame = CGRectInset(self.view.frame, -borderWidth, -borderWidth); 
    self.view.layer.borderColor = BORDER_COLOUR; 
    self.view.layer.borderWidth = borderWidth; 

    // set this to be able to exit the video player properly 
    [[NSNotificationCenter defaultCenter] addObserver:self 
              selector:@selector(willEnterFullScreen) 
               name:MPMoviePlayerWillEnterFullscreenNotification 
               object:_videoPlayer.moviePlayerController]; 

    // set this to be able to start/stop the spinner 
[[NSNotificationCenter defaultCenter] addObserver:self 
              selector:@selector(loadStateChanged) 
               name:MPMoviePlayerLoadStateDidChangeNotification 
               object:_videoPlayer.moviePlayerController]; 

    // make sure the views are always at the front 
    [self.view bringSubviewToFront:self.videoPlayer.videoView]; 
    [self.view bringSubviewToFront:self.spinner]; 

    self.initialised = YES; 
    } 
} 

-(void)viewDidAppear:(BOOL)animated 
{ 
    [super viewDidAppear:animated]; 

    [self customInit]; 
} 

-(void) viewWillAppear:(BOOL)animated 
{ 
    [super viewWillAppear:animated]; 

    [self.spinner stopAnimating]; 

    if (_videoPlayer && self.wasPDFScreen) 
    { 
    NSTimeInterval time = [self.videoPlayer.moviePlayerController currentPlaybackTime]; 
    if (time != 0) 
    { 
     // So to ge the video to play properly, i have to uncommment the lines below, but this loses the cache and isn't quite as smooth as i would like. 

     //[self stopVideo]; 
     //self.videoPlayer.moviePlayerController.currentPlaybackTime = time; 
     //[self.videoPlayer.moviePlayerController prepareToPlay]; 
     //[self.videoPlayer.moviePlayerController play]; 
     //[self.videoPlayer.moviePlayerController pause]; 
    } 
    } 

    self.isFullScreen = NO; 
    self.wasPDFScreen = NO; 
} 

-(void)viewDidDisappear:(BOOL)animated 
{ 
    [super viewDidDisappear:animated]; 

    // only stop the video when we mean to - not when we go into full screen mode 
    if (!self.isFullScreen && !self.wasPDFScreen) 
    [self stopVideo]; 
} 

- (void)playVideo 
{ 
    [self.spinner startAnimating]; 

    [self.videoPlayer loadFromURL:@"someurl"];  

    // and play!! 
    [self.videoPlayer play]; 
} 

-(void)stopVideo 
{ 
    [self.videoPlayer stop]; 
} 

@end 

ответ

0

Я закончил вместо этого реализует контроллер AV Kit View Controller. Работает отлично.

Смежные вопросы