SwiftでAVPlayerViewController(AVKit)を使用してビデオを再生する方法


164

SwiftのAV Kit Player View Controllerでビデオをどのように再生しますか?

override func viewDidLoad() {
        super.viewDidLoad()
        let videoURLWithPath = "http://****/5.m3u8"
        let videoURL = NSURL(string: videoURLWithPath)
        playerViewController = AVPlayerViewController()

        dispatch_async(dispatch_get_main_queue()) {
            self.playerViewController?.player = AVPlayer.playerWithURL(videoURL) as AVPlayer
        }
    }

使用方法AVPlayer(コントロールがない場合)については、この回答を参照してください。
Suragch

回答:


532

Swift 3.x-5.x

必要に応じて:輸入AVKit輸入AVFoundation

AVPlayerを使用する場合でもAVFoundationフレームワークが必要です

AVPlayerViewControllerを使用する場合

let videoURL = URL(string: "https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4")
let player = AVPlayer(url: videoURL!)
let playerViewController = AVPlayerViewController()
playerViewController.player = player
self.present(playerViewController, animated: true) {
    playerViewController.player!.play()
}

または単にAVPlayer

let videoURL = URL(string: "https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4")
let player = AVPlayer(url: videoURL!)
let playerLayer = AVPlayerLayer(player: player)
playerLayer.frame = self.view.bounds
self.view.layer.addSublayer(playerLayer)
player.play()

このコードをメソッドに追加することをお勧めしますfunc viewDidAppear(_ animated:Bool)またはその後のどこかをオーバーライドします


Objective-C

AVPlayerViewController

NSURL *videoURL = [NSURL URLWithString:@"https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"];
AVPlayer *player = [AVPlayer playerWithURL:videoURL];
AVPlayerViewController *playerViewController = [AVPlayerViewController new];
playerViewController.player = player;
[self presentViewController:playerViewController animated:YES completion:^{
  [playerViewController.player play];
}];

または単にAVPlayer

NSURL *videoURL = [NSURL URLWithString:@"https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"];
AVPlayer *player = [AVPlayer playerWithURL:videoURL];
AVPlayerLayer *playerLayer = [AVPlayerLayer playerLayerWithPlayer:player];
playerLayer.frame = self.view.bounds;
[self.view.layer addSublayer:playerLayer];
[player play];

@pikisコード例をありがとう。奇妙なことに、私たちはAVPlayerControllerを書いたとおりに試し、SIGABRTを取得しました。
Praxiteles、2015

@Praxiteles、それはiOS8以降で動作し、おそらくそれが理由です。
pkis 2015

8
また必要 インポートAVFoundation私のために
リッチフォックス

1
@ Nick89、AVPlayerは直接リンクで正しく動作しますが、YouTube、Vimeoなど(間接リンクがある)などのサービスを使用する必要がある場合は、独自のライブラリまたはSDKを使用する必要があります。(例:YouTubeの場合:ガイド)。
pkis

2
指示の順序は重要です。また、AVKitをインポートする必要がありました
htafoya

30

これを試してください、間違いなく動作します Swift 2.0

 let player = AVPlayer(URL: url)
    let playerController = AVPlayerViewController()

    playerController.player = player
    self.addChildViewController(playerController)
    self.view.addSubview(playerController.view)
    playerController.view.frame = self.view.frame

    player.play()  

1
ありがとう。addChildViewControllerは、必要なものだけを埋め込みました。:)
SDW 2016年

1
埋め込みは問題なく機能しますが、向きの変更をどのように処理しますか?たとえば、プレーヤーが画面の半分を縦向きに表示し、View Controllerは縦向きしかサポートしていないが、ほとんどのアプリがそうであるように、ビデオは縦向きで見ることができるとします。たとえば、youtube、vimeoなど
Abid Hussain

注:addChildViewControllerが必要です。それなしで試したところ、ほぼ動作しました-一度再生すると、フルスクリーンに拡大します。しかし、それは再び再生されないか、全画面モードから抜け出しません。だから子ビューコントローラが必要です。
n13

self.addChildViewController(playerController)is self.addChild(playerController)fyi
Marquis103

12

これを試して

var player:AVPlayer!
var avPlayerLayer:AVPlayerLayer = AVPlayerLayer(player: player)
avPlayerLayer.frame = CGRectMake(your frame)
self.view.layer .addSublayer(avPlayerLayer)
var steamingURL:NSURL = NSURL(string:playerURL)
player = AVPlayer(URL: steamingURL)
player.play()

このコードを実行すると、空のビューコントローラーが表示されます
orazz

@OnePlayerLayerフレームを設定しますか?
Ramesh 2014

1
@Oneperson ok set this avPlayerLayer.frame = CGRectMake(50,50,100,100)
Ramesh

コード変数プレーヤー:AVPlayer!var playerItem:AVPlayerItem !; var avPlayerLayer:AVPlayerLayer = AVPlayerLayer(player:player)avPlayerLayer.frame = CGRectMake(50,50,100,100)self.view.layer .addSublayer(avPlayerLayer)let videoURLWithPath = "http://*****/45.m3u8" var steamingURL:NSURL = NSURL(string:videoURLWithPath)player = AVPlayer(URL:steamingURL)player.play()code
orazz

@Oneperson edge.tolkun.tv/45.m3u8が機能していません。完全なURLを教えてもらえますか
Ramesh 2014

11

Swift 3.0完全なソースコード:

import UIKit
    import AVKit
    import AVFoundation

    class ViewController: UIViewController,AVPlayerViewControllerDelegate
    {
        var playerController = AVPlayerViewController()


        @IBAction func Play(_ sender: Any)
        {
            let path = Bundle.main.path(forResource: "video", ofType: "mp4")

            let url = NSURL(fileURLWithPath: path!)

            let player = AVPlayer(url:url as URL)

            playerController = AVPlayerViewController()


            NotificationCenter.default.addObserver(self, selector: #selector(ViewController.didfinishplaying(note:)),name:NSNotification.Name.AVPlayerItemDidPlayToEndTime, object: player.currentItem)

            playerController.player = player

            playerController.allowsPictureInPicturePlayback = true

            playerController.delegate = self

            playerController.player?.play()

            self.present(playerController,animated:true,completion:nil)
        }

        func didfinishplaying(note : NSNotification)
        {
            playerController.dismiss(animated: true,completion: nil)
            let alertview = UIAlertController(title:"finished",message:"video finished",preferredStyle: .alert)
            alertview.addAction(UIAlertAction(title:"Ok",style: .default, handler: nil))
            self.present(alertview,animated:true,completion: nil)
        }


        func playerViewController(_ playerViewController: AVPlayerViewController, restoreUserInterfaceForPictureInPictureStopWithCompletionHandler completionHandler: @escaping (Bool) -> Void) {
                let currentviewController =  navigationController?.visibleViewController

                if currentviewController != playerViewController
                {
                    currentviewController?.present(playerViewController,animated: true,completion:nil)
                }


            }
    }

こんにちはロナック、ビデオの終わりを処理するために迅速にオブザーバーを紹介してくれてありがとう!私はあなたの答えの上に提供されたコード(最初のコードスニペット)でAVPlayerViewControllerを作成することによってそれを機能させることができませんでした、何が違うのですか?あなたのメソッドのオブザーバーを機能させるために私が見逃したもの、または実装すべきものは何ですか?
Manu

6

目的c

これはでのみ機能します Xcode 7

.hファイルに移動してインポートAVKit/AVKit.hしてください AVFoundation/AVFoundation.h。次に、.mファイルに移動してこのコードを追加します。

NSURL *url=[[NSBundle mainBundle]URLForResource:@"arreg" withExtension:@"mp4"];
AVPlayer *video=[AVPlayer playerWithURL:url];
AVPlayerViewController *controller=[[AVPlayerViewController alloc]init];
controller.player=video;
[self.view addSubview:controller.view];
controller.view.frame=self.view.frame;
[self addChildViewController:controller];
[video play];

4

MPMoviePlayerControllerの使用:

 import UIKit
 import MediaPlayer

 class ViewController: UIViewController {

     var streamPlayer : MPMoviePlayerController =  MPMoviePlayerController(contentURL: NSURL(string:"video url here"))
     override func viewDidLoad() {
         super.viewDidLoad()
         streamPlayer.view.frame = self.view.bounds
         self.view.addSubview(streamPlayer.view)

         streamPlayer.fullscreen = true
         // Play the movie!
         streamPlayer.play()
}
}

AVPlayerの使用:

import AVFoundation

var playerItem:AVPlayerItem?
var player:AVPlayer?

override func viewDidLoad() {
        super.viewDidLoad() 
      let url = NSURL(string: "url of the audio or video") 
      playerItem = AVPlayerItem(URL: url!)
      player=AVPlayer(playerItem: playerItem!)
      let playerLayer=AVPlayerLayer(player: player!)
      playerLayer.frame=CGRectMake(0, 0, 300, 50)
      self.view.layer.addSublayer(playerLayer)
}

ボタンタップを操作するための再生ボタンがあります。

playButton.addTarget(self, action: "playButtonTapped:", forControlEvents: .TouchUpInside)

func playButtonTapped(sender: AnyObject) {
        if player?.rate == 0
        {
            player!.play()
            playButton.setImage(UIImage(named: "player_control_pause_50px.png"), forState: UIControlState.Normal)
        } else {
            player!.pause()
            playButton.setImage(UIImage(named: "player_control_play_50px.png"), forState: UIControlState.Normal)
        }
    }

AVPlayerItemDidPlayToEndTimeNotificationをリッスンするオブザーバーを追加しました。

override func viewWillAppear(animated: Bool) {
        NSNotificationCenter.defaultCenter().addObserver(self, selector: "finishedPlaying:", name: AVPlayerItemDidPlayToEndTimeNotification, object: playerItem)
    }

override func viewWillDisappear(animated: Bool) {
        NSNotificationCenter.defaultCenter().removeObserver(self)
    }

ビデオ/オーディオの再生が終了したら、ボタンの画像と通知をリセットします

  func finishedPlaying(myNotification:NSNotification) {
        playButton.setImage(UIImage(named: "player_control_play_50px.png"), forState: UIControlState.Normal)

        let stopedPlayerItem: AVPlayerItem = myNotification.object as! AVPlayerItem
        stopedPlayerItem.seekToTime(kCMTimeZero)
    }

2
MPMoviePlayerControllerは非推奨であり、おそらく今後使用しないでください。
Skywalker

ローカル動画を使用する例など、URLを使用しない例を挙げてください。
nyxee 2017

4

iOS10 / Swift3 / Xcode 8のバグ(?!)

if let url = URL(string: "http://devstreaming.apple.com/videos/wwdc/2016/102w0bsn0ge83qfv7za/102/hls_vod_mvp.m3u8"){
    let playerItem = AVPlayerItem(url: url)
    let player = AVPlayer(playerItem: playerItem)
    let playerLayer = AVPlayerLayer(player: player)
    playerLayer.frame=CGRect(x: 10, y: 10, width: 300, height: 300)
    self.view.layer.addSublayer(playerLayer)
}

動作しません(空のrect ...)

これは機能します:

if let url = URL(string: "http://devstreaming.apple.com/videos/wwdc/2016/102w0bsn0ge83qfv7za/102/hls_vod_mvp.m3u8"){

            let player = AVPlayer(url: url)
            let controller=AVPlayerViewController()
            controller.player=player
            controller.view.frame = self.view.frame
            self.view.addSubview(controller.view)
            self.addChildViewController(controller)
            player.play()
        }

同じURL ...


:この行を追加 player.play():後にself.view.layer.addSublayer(playerLayer)して、やり直してください
orazz

4

スウィフト3:

import UIKit
import AVKit
import AVFoundation

class ViewController: UIViewController {

    @IBOutlet weak var viewPlay: UIView!
    var player : AVPlayer?

    override func viewDidLoad() {
        super.viewDidLoad()

        let url : URL = URL(string: "http://static.videokart.ir/clip/100/480.mp4")!
        player = AVPlayer(url: url)
        let playerLayer = AVPlayerLayer(player: player)
        playerLayer.frame = self.viewPlay.bounds
        self.viewPlay.layer.addSublayer(playerLayer)

    }

    @IBAction func play(_ sender: Any) {
        player?.play()
    }

    @IBAction func stop(_ sender: Any) {
        player?.pause()
    }

}

答えのどこを使用しましたAVPlayerViewControllerか?
AnBisw

1

これは私にとって Swift 5 でうまくいきました

ちょうどからプロジェクトにサンプル動画を追加したサンプルビデオ

次の迅速なコード例を使用して、ウェブサイトとローカルから動画を再生するためのアクションボタンを追加しました

import UIKit
import AVKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        //TODO : Make Sure Add and copy "SampleVideo.mp4" file in project before play
    }

    @IBAction func playWebVideo(_ sender: Any) {

        guard let url = URL(string: "https://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4") else {
            return
        }
        // Create an AVPlayer, passing it the HTTP Live Streaming URL.
        let player = AVPlayer(url: url)
        let controller = AVPlayerViewController()
        controller.player = player
        present(controller, animated: true) {
            player.play()
        }
    }

    @IBAction func playLocalVideo(_ sender: Any) {

        guard let path = Bundle.main.path(forResource: "SampleVideo", ofType: "mp4") else {
            return
        }
        let videoURL = NSURL(fileURLWithPath: path)

        // Create an AVPlayer, passing it the local video url path
        let player = AVPlayer(url: videoURL as URL)
        let controller = AVPlayerViewController()
        controller.player = player
        present(controller, animated: true) {
            player.play()
        }
    }

}

0

スウィフト5

  @IBAction func buttonPressed(_ sender: Any) {
    let videoURL = course.introductionVideoURL
    let player = AVPlayer(url: videoURL)
    let playerViewController = AVPlayerViewController()
    playerViewController.player = player

    present(playerViewController, animated: true, completion: {

        playerViewController.player!.play()
    })

//ここでは、コースにモデルファイルが含まれており、その中にURLを指定しているので、コース関数を使用してモデルから関数を呼び出しています。

//また、introductionVideoUrlは、モデル内で宣言したURLです。

 var introductionVideoURL: URL

また、モデルから関数を呼び出す代わりに、以下のコードを使用することもできます

このコードを置き換える

  let videoURL = course.introductionVideoURL

  guard let videoURL = URL(string: "https://something.mp4) else {
        return

0
let videoUrl = //URL: Your Video URL

//Create player first using your URL
let yourplayer = AVPlayer(url: videoUrl)

//Create player controller and set it’s player
let playerController = AVPlayerViewController()
playerController.player = yourplayer


//Final step To present controller  with player in your view controller
present(playerController, animated: true, completion: {
   playerController.player!.play()
})

0

Swift 5.0

@ingcontiの回答から改善されました。これでうまくいきました。

 if let url = URL(string: "urUrlString"){
            let player = AVPlayer(url: url)
            let avController = AVPlayerViewController()
            avController.player = player
            // your desired frame
            avController.view.frame = self.view.frame
            self.view.addSubview(avController.view)
            self.addChild(avController)
            player.play()
        }

0

Swift 5+

まず最初に、ビューコントローラ内でグローバルに2つの変数を定義する必要があります。

var player: AVPlayer!
var playerViewController: AVPlayerViewController!

ここでは、目的のビューにプレーヤーを追加しています。

@IBOutlet weak var playerView: UIView!

次に、次のコードをviewDidLoadメソッドに追加します。

let videoURL = URL(string: "videoUrl")
self.player = AVPlayer(url: videoURL!)
self.playerViewController = AVPlayerViewController()
playerViewController.player = self.player
playerViewController.view.frame = self.playerView.frame
playerViewController.player?.pause()
self.playerView.addSubview(playerViewController.view)

playerplayerViewControllerをグローバルに定義していない場合、playerを埋め込むことはできません。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.