web-dev-qa-db-ja.com

iPhoneのアプリケーション内でyoutube / vimeoビデオを再生する方法

Youtube、Vimeo、Direct URLなどのURLからビデオを再生するアプリケーションを作成しています。 AVPlayerを使用して、ビデオクリップの直接URL(www.abc/play.mp4など)からビデオを再生するカスタムプレーヤーを作成しています。しかし、後でYouTubeとvimeoビデオを再生するという大きな問題に直面しました。そして、多くを検索した後、UIWebviewを使用せずにYoutubeリンクを再生できないというリンクが見つかりました:

IWebViewの代わりにMPMoviePlayerControllerでYouTubeビデオを再生します

IWebViewを使用せずにYouTubeリンクからビデオを再生する

だから私はこのコードを使用しました:

NSString *youTubeVideoHTML = @"<html><head><style>body{margin:0;}</style></head> <body> <div id=\"player\"></div> <script> var tag = document.createElement('script'); tag.src = 'http://www.youtube.com/player_api'; var firstScriptTag = document.getElementsByTagName('script')[0]; firstScriptTag.parentNode.insertBefore(tag, firstScriptTag); var player; function onYouTubePlayerAPIReady() { player = new YT.Player('player', { width:\'100%%\', height:'200px', videoId:\'%@\', events: { 'onReady': onPlayerReady } }); } function onPlayerReady(event) { event.target.playVideo(); } </script> </body> </html>";

NSString *html = [NSString stringWithFormat:youTubeVideoHTML, videoId];
self.embedded_player_view.mediaPlaybackRequiresUserAction = NO;

[self.embedded_player_view loadHTMLString:html baseURL:[[NSBundle mainBundle] resourceURL]];

今、tableviewからyoutube/Vimeoのビデオリンクをクリックすると、デフォルトのプレーヤー、つまりquicktimeプレーヤーでビデオが再生されます。 UIWebviewフレーム自体内でビデオを実行していません。ただし、画面の前半、つまりUIWebviewフレームにビデオを表示したいと思います。それは可能ですか?

私のアプリではこれを見ることができます:

赤い再生ボタンをクリックすると、次のようにQuickTime Playerでフルスクリーンでビデオを見ることができます:

enter image description hereenter image description here

しかし、Quick Timeプレーヤー経由ではなく、同じwebViewフレーム内でビデオを表示したいです。次のように再生されます:

enter image description here

MusicTube および PlayTube でも同様です。

または、同じことを達成する他の方法はありますか?任意の助けをいただければ幸いです。前もって感謝します。

16
Avijit

enter image description hereenter image description here

私は このクラス をそのために使用しました。

UIViewController内に表示されるビデオは、現在のサイズで再生可能です。

それが私が使用した唯一のコードです:

UIView *videoContainerView = [[UIView alloc]initWithFrame:CGRectMake(0, 50, 320, 200)];
    [self.view addSubview:videoContainerView];        
    XCDYouTubeVideoPlayerViewController *videoPlayerViewController = [[XCDYouTubeVideoPlayerViewController alloc] initWithVideoIdentifier:@"_OBlgSz8sSM"];
    [videoPlayerViewController presentInView:videoContainerView];
    [videoPlayerViewController.moviePlayer play];
14
Segev

Vimeoプレーヤーの場合、このリンクを確認できます https://github.com/lilfaf/YTVimeoExtractor それは実際のプレーヤーでビデオを再生し、uiwebviewでビデオを実行したい場合は、ここにコードがあります https://stackoverflow.com/a/15918011/1865424

YouTubeビデオのURLを「urlStr」に渡します。

//In .h file
UIWebView *videoView;
// In .m file

videoView = [[UIWebView alloc] initWithFrame:CGRectMake(0, 0, 320, 385)];

[self embedYouTube :urlStr  frame:CGRectMake(0, 0, 320, 385)];

[self.view addSubview:videoView];

// methos to embed URL in HTML & load it to UIWebView

- (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];

}

コートジー:- http://nanostuffs.com/Blog/?p=641

これがあなたを助けることを願っています。それでも解決しない場合は、次のリンクをご覧ください。

http://blog.softwareispoetry.com/2010/03/how-to-play-youtube-videos-in-your.html

https://Gist.github.com/darkredz/5334409

http://maniacdev.com/2012/02/open-source-library-for-easily-playing-a-youtube-video-in-an-mpmovieplayer

7
Shivaay

私はプロジェクトでyoutubeとvimeoを使用しました。あなたのためにコーディングを共有します。

私のビューcontroller.mで

//Button action

- (IBAction)importAudioClip:(id)sender
{
flag = 0;
customActionSheet = [[UIActionSheet alloc]initWithTitle:@"Select Audio/Video from:" delegate:self cancelButtonTitle:@"Cancel" destructiveButtonTitle:nil otherButtonTitles:@"YouTube",@"Vimeo", nil];
[customActionSheet showInView:self.view];

}


#pragma ActionSheet Delegate Methods
-(void)actionSheet:(UIActionSheet *)actionSheet clickedButtonAtIndex:(NSInteger)buttonIndex
{
  NSLog(@"CLiekc button is %i",buttonIndex);

 if([actionSheet.title isEqualToString:@"Select Audio/Video from:"])
    {
        if (buttonIndex == 0)
        {
            videoStatus=0;

            webView.hidden = NO;

            [webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.youtube.com"]]];
            NSLog(@"Taking from Youtube");

        }
        else if (buttonIndex == 1)
        {
            videoStatus=1;
            UIAlertView *alertView=[[UIAlertView alloc]initWithTitle:@"Vimeo" message:@"Please enter Vimeo Username" delegate:self cancelButtonTitle:@"Cancel" otherButtonTitles:@"OK", nil];
            alertView.tag=123;
            alertView.alertViewStyle = UIAlertViewStylePlainTextInput;
            [alertView show];

        }
    }
}

- (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
if (alertView.tag==123)
    {
    if (buttonIndex==1)
    {
        templateText=[[UITextField alloc]init];
        templateText = [alertView textFieldAtIndex:0];
        templateText.autocapitalizationType=UITextAutocapitalizationTypeWords;
        templateText.delegate=self;
        if ([templateText.text length]!=0)
        {
            NSString *str=[templateText.text capitalizedString];
            NSLog(@"Str== %@",str);
            [self getVimeoDetails:str];

        }
    }
}
}


-(void)getVimeoDetails:(NSString*)userName
{
 NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:[NSString stringWithFormat:@"http://vimeo.com/api/v2/%@/videos.json",userName]]];
[request setHTTPMethod:@"GET"];
NSError *err;
NSURLResponse *response;
NSData *responseData = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&err];
NSString *resSrt = [[NSString alloc]initWithData:responseData encoding:NSASCIIStringEncoding];
NSLog(@"The value is==%@",resSrt);
vimeoDetailsArray =(NSArray*) [NSJSONSerialization JSONObjectWithData:responseData options:kNilOptions error:&err];
NSLog(@"jsonObject== %i",[vimeoDetailsArray count]);
NSString *theReply = [[NSString alloc] initWithBytes:[responseData bytes] length:[responseData length] encoding: NSASCIIStringEncoding];
NSLog(@"the reply == %@",theReply);
if(response)
{
    if (vimeoDetailsArray==NULL)
    {
        NSLog(@"its Null");
        NSLog(@"null response== %@",response);
        //                     UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"Alert!!!" message:[NSString stringWithFormat:@"%@",theReply] delegate:self
        //                                                        cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
        //                     [alert show];
        // [self performSelector:@selector(showAlertMessage:theReply withTitle:@"Alert!!!") withObject:nil afterDelay:5];
        vimeoVideoTable.hidden=YES;
        [self showAlertMessage:[NSString stringWithFormat:@"%@",theReply] withTitle:@"Alert!!!"];
    }
    else
    {
        [self createTableView];
        vimeoVideoTable.hidden=NO;
        [vimeoVideoTable reloadData];
        NSLog(@"got response== %@",response);
    }
}
else
{
    NSLog(@"faield to connect");
}


if ([responseData length] == 0 && err == nil)
{
    NSLog(@"Nothing was downloaded.");
}
else if (err != nil){

    if ([[err description] rangeOfString:@"The Internet connection appears to be offline"].location != NSNotFound)
    {
        NSLog(@"string does not contain ");
        UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"Alert!!!" message:@"Please Check your Internet Connection" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
        [alert show];
    }
    NSLog(@"Error = %@", err);
}

}

-(void)createTableView
{
if (vimeoVideoTable !=nil)
{
    [vimeoVideoTable removeFromSuperview];
    vimeoVideoTable=nil;
}
vimeoVideoTable=[[UITableView alloc]initWithFrame:CGRectMake(10, 20, 300, self.view.bounds.size.height-100)];
[vimeoVideoTable setDelegate:self];
[vimeoVideoTable setHidden:YES];
[vimeoVideoTable setDataSource:self];
[self.view addSubview:vimeoVideoTable];
//[vimeoVideoTable reloadData];

}
2
Anbu.Karthik

Vimeoについては知りませんが、ユーチューブビデオの場合は HCYouTubeParser を使用して、ユーチューブビデオのmp4 URLを取得し、後で要件に従ってAVPlayerまたはMpMoviePlayerVCで再生できます。

2
channi

Youtubeを再生したい場合は、githubのyoutube player project へのリンクがあります。これは非常に役立ちます。そして、はい、それはあなたのuiwebviewでそれを再生することは可能です、ただwebviewにurlを与えてロードするように伝えてください。

2
Nour1991

youtube_ios_player_helper 、 "sponsored by" Google をお勧めします。

import youtube_ios_player_helper

class YTViewController: YTPlayerViewDelegate {

    @IBOutlet weak var player: YTPlayerView!

    // MARK: - Public properties -

    var videoID = "k_okcNVZqqI"

    // MARK: - View life cycle -

    override func viewDidLoad() {
        super.viewDidLoad()
        self.player.delegate = self
    }

    override func viewDidAppear(animated: Bool) {
        super.viewDidAppear(animated)
        self.load()
        self.player.fadeOut()
    }

    /**
     Play video with the relative youtube identifier.
     */
    func load() {
        Utils.showHUD(self.view)
        let options = ["playsinline" : 1]
        self.player.loadWithVideoId(self.videoID, playerVars: options)
    }

    /**
     Stop video playing.
     */
    func stop() {
    }

    // MARK: - YOUTUBE video player delegate -

    func playerViewDidBecomeReady(playerView: YTPlayerView) {
        self.player.playVideo()
    }

    func playerView(playerView: YTPlayerView, didChangeToState state: YTPlayerState) {
        switch state {
        case .Playing:
            self.player.fadeIn(duration: 0.5)
            Utils.hideHUD(self.view)
            print("Started playback")
            break;
        case .Paused:
            print("Paused playback")
            break;
        default:
            break;
        }
    }
}
1
Luca Davanzo

ストーリーボードでWKWebViewを使用し、制約とコードを追加しました:

func playVideo() {

if yourLink.lowercased().contains("youtu.be"){
    getVideo(videoCode: yourVideoCode)
    if let range = yourLink.range(of: "be/"){
        let videoId = yourLink[range.upperBound...].trimmingCharacters(in: .whitespaces)
        getVideo(videoCode: videoId)
    }
} else if yourLink.lowercased().contains("youtube.com"){
    if let range = yourLink.range(of: "?v="){
        let videoId = yourLink[range.upperBound...].trimmingCharacters(in: .whitespaces)
        getVideo(videoCode: videoId)
    }
} else if yourLink.lowercased().contains("vimeo.com") {
    let url: NSURL = NSURL(string: yourLink)
    webKitView.contentMode = UIViewContentMode.scaleAspectFit
    webKitView.load(URLRequest(url: url as URL))
}
}

func getVideo(videoCode: String) {
    guard
    let url = URL(string: "https://www.youtube.com/embed/\(videoCode)")
    else { return }
    webKitView.load(URLRequest(url: url))
}

Youtube/VimeoリンクからvideoIdを取得するには、以下を参照してください。

RLからのYouTube動画ID-Swift

Swift 2 でvimeoビデオIDを取得するための正規表現

お役に立てば幸いです! :)

0
JaspreetKour

次の方法を使用して、同じ問題を正常に解決しました。

youtube-ios-player-helper を使用して、コードを追加します。

[_playerView loadWithVideoId:@"DmTzboEqfNk" playerVars:@{
                                                         @"playsinline" : @1
                                                         }];

Youtube> IFrame API でさらに変数を見つけることができます。

0
JonasChen

これを使って

NSMutableString *html = [[NSMutableString alloc] initWithCapacity:1] ;
[html appendString:@"<html><head>"];
[html appendString:@"<style type=\"text/css\">"];
[html appendString:@"body {"];
[html appendString:@"background-color: transparent;"];
[html appendString:@"color: white;"];
[html appendString:@"}"];
[html appendString:@"</style>"];
[html appendString:@"</head><body style=\"margin:0\">"];
[html appendString:@"<iframe src=\"//player.vimeo.com/video/84403700?autoplay=1&amp;loop=1\" width=\"1024\" height=\"768\" frameborder=\"0\" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>"];
[html appendString:@"</body></html>"];


[viewWeb loadHTMLString:html baseURL:urlMovie];