Play YouTube videos with MPMoviePlayerController instead of UIWebView

IosVideoStreamingYoutubeMpmovieplayercontroller

Ios Problem Overview


I'm trying to stream some youTube videos using the MPMoviePlayerController but I'm having some problems. The code I'm using is pretty simple and I can play .m4v videos by passing a URL to initWithContentURL. When I launch the movie player the player comes up but just goes away after about 20 seconds. When I try it in the simulator I get an alert view that says the server is not configured correctly. Is there an argument I need to pass with the URL to get a specific type of video feed from google?

NSURL *videoURL = [NSURL URLWithString:@"http://www.youtube.com/v/HGd9qAfpZio&hl=en_US&fs=1&"];
MPMoviePlayerController *moviePlayer;
moviePlayer = [[MPMoviePlayerController alloc] initWithContentURL:videoURL];

[moviePlayer play];

I've also tried the following URL's http://www.youtube.com/watch?v=HGd9qAfpZio

I have also seen the argument &format=1 and tried to add that to the end of both of the strings but no luck.

Ios Solutions


Solution 1 - Ios

The only way to have a youtube video play inside your own app is to create a UIWebView with the embed tag from Youtube for the movie you want to play as the UIWebView's content. UIWebView will detect that the embedded object is a Youtube link, and the web view's content will be the youtube preview for the video. When your user clicks the preview, the video will be shown in an MPMoviePlayerController. This is the technique described at the link that Muxecoid provided (how to play youtube videos within an application), and this is (as far as I know of) the only way to have a youtube video play within an application. You can still have the Youtube application launch by passing the youtube URL to -[UIApplication openURL:], but of course this closes your own application which is often undesirable.

Unfortunately, there's no way to directly play a youtube video with MPMoviePlayerController because youtube does not expose direct links to the video files.

Solution 2 - Ios

If you are using Code:

- (void)embedYouTube:(NSString*)url frame:(CGRect)frame {  
     NSString* embedHTML = @"\ 
        <html><head>\ 
     <style type=\"text/css\">\ 
     body {\ 
     background-color: transparent;\ 
     color: white;\ 
    }\ 
   </style>\ 
    </head><body style=\"margin:0\">\ 
       <embed id=\"yt\" src=\"%@\" type=\"application/x-shockwave-flash\" \ 
    width=\"%0.0f\" height=\"%0.0f\"></embed>\ 
       </body></html>";  
   NSString* html = [NSString stringWithFormat:embedHTML, url, frame.size.width, frame.size.height];  
   if(videoView == nil) {  
      videoView = [[UIWebView alloc] initWithFrame:frame];  
     [self.view addSubview:videoView];  
    }  
    [videoView loadHTMLString:html baseURL:nil];  
  }

Source:

Just refer this link

Make sure that you test it on device and not on the simulator. Since simulator will always display question mark with blue box (it doesn't have quick-time player).

Solution 3 - Ios

As I wrote above in my comment I had to do this in a project I was working on. I've solved this problem and submitted the code on github.

You can check the source and fork it here.

It basically takes a youtube url and gets all the iOS compatible video urls.

Hope this is to any help!
Cheers

Solution 4 - Ios

I just stumbled across someone who was able to place a YouTube video inside an MPMoviePlayerController. It does appear possible now.

LBYouTubeView

Solution 5 - Ios

To play you tube videos you need to extract the url before passing the url into MPMoviePlayer. You can't play it directly.

My github repo has a demo implementation of this.

See:

https://github.com/DpzAtMicRO/IOSYoutubePlayer

Try it, this makes it possible to load and play youtube video directly in MPMoviePlayerlike any other video and is pretty good approach too.

EDIT: Make sure that you go through the Readme.md well before using this in your project

Solution 6 - Ios

It's as simple as taking the src element of the iframe for the new embed code and calling

[self.webView loadRequest:[NSURLRequest requestWithURL:self.url]];

Solution 7 - Ios

Check the following link. I think it will help you.

https://mobiletechfeast.blogspot.in/2014/08/youtube-player-for-ios.html

Solution 8 - Ios

There is an official way to embed YouTube video in iOS application which is provided by Google.

Install library via cocoapods: pod "youtube-ios-player-helper"

import by: #import “YTPlayerView.h” Use UIView and set class to YTPlayerView or create object of YTPlayerView programatically.

Load video: [self.playerView loadWithVideoId:@"M7lc1UVf-VE"];

There is also playVideo and stopVideo methods available. For more info visit this Link

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionjmurphyView Question on Stackoverflow
Solution 1 - IosBryan HenryView Answer on Stackoverflow
Solution 2 - IosJimitView Answer on Stackoverflow
Solution 3 - IoshellozimiView Answer on Stackoverflow
Solution 4 - IosTPoschelView Answer on Stackoverflow
Solution 5 - IosDD_View Answer on Stackoverflow
Solution 6 - IosjjxtraView Answer on Stackoverflow
Solution 7 - Iosarango_86View Answer on Stackoverflow
Solution 8 - IosGanpatView Answer on Stackoverflow