Reputation: 586
I need to play a video inside a view not in full screen(like facebook)! Can anyone help? I'm using swift 2 and xcode 7. I've googled about it but all I find is run with AVPlayerViewController and fullscreen.
Ps: Sorry for the bad english.
Upvotes: 16
Views: 17079
Reputation: 11
@IBOutlet weak var backView: UIView!
override func viewDidLoad() {
super.viewDidLoad()
playVideo()
}
private func playVideo() {
guard let path = Bundle.main.path(forResource: "video", ofType:"mp4") else {
debugPrint("video.mp4 not found")
return
}
let player = AVPlayer(url: URL(fileURLWithPath: path))
let playerController = AVPlayerViewController()
playerController.player = player
--- start from here :
let playerLayerAV = AVPlayerLayer(player: player)
//now we set the size of frame to be like the view ("backview")
playerLayerAV.frame = backView.bounds
// the backview is the view i'm using it to insert a video
backView.layer.addSublayer(playerLayerAV)
player.play()
}
Upvotes: 1
Reputation: 902
import AVFoundation
import AVKit
var player = AVPlayer()
var playerController = AVPlayerViewController()
func playVideo() {
let videoURL = NSURL(string: videoUrl)
player = AVPlayer(url: videoURL! as URL)
let playerController = AVPlayerViewController()
playerController.player = player
self.addChildViewController(playerController)
// Add your view Frame
playerController.view.frame = self.view.frame
// Add sub view in your view
self.view.addSubview(playerController.view)
player.play()
}
for player stop or pause
func stopVideo() {
player.pause()
}
This Code is work for me please try it.
Upvotes: 4
Reputation: 3645
Swift 3 apply pod Player
Podfile:
platform :ios, '10.0'
use_frameworks!
def pods
pod "Player", "~> 0.5.0"
end
target 'YourProject' do
pods
end
YourViewController:
import Player
// Player
var player:Player
// MARK: object lifecycle Player
convenience init() {
self.init(nibName: nil, bundle:nil)
}
required init?(coder aDecoder: NSCoder) {
self.player = Player()
super.init(coder: aDecoder)
}
override init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: Bundle?) {
self.player = Player()
super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil)
}
deinit {
self.player.willMove(toParentViewController: self)
self.player.view.removeFromSuperview()
self.player.removeFromParentViewController()
}
private func playeVideo(url: URL) {
player.playerDelegate = self
player.playbackDelegate = self
player.view.frame = self.view.bounds // your frame here
self.addChildViewController(self.player)
self.view.insertSubview(player.view, at: 0)
player.url = url
self.player.playFromBeginning()
}
Please more details here https://github.com/piemonte/Player
Upvotes: 0
Reputation: 586
This works:
class BeginController: UIViewController {
@IBOutlet weak var videoPreviewLayer: UIView!
var player: AVPlayer!
var avpController = AVPlayerViewController()
override func viewDidLoad() {
super.viewDidLoad()
let moviePath = NSBundle.mainBundle().pathForResource("Hello Moto", ofType: "mp4")
if let path = moviePath {
let url = NSURL.fileURLWithPath(path)
self.player = AVPlayer(url: url)
self.avpController = AVPlayerViewController()
self.avpController.player = self.player
avpController.view.frame = videoPreviewLayer.frame
self.addChildViewController(avpController)
self.view.addSubview(avpController.view)
}
// Do any additional setup after loading the view.
}
Upvotes: 27
Reputation: 3252
You can try to use AVPlayerLayer
with desired size and position and play video on it.
Example code setting player and layer:
- (void)setupPlayer
{
AVPlayerItem *playerItem = [AVPlayerItem playerItemWithURL:<Your video item URL>];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(playFinished:) name:AVPlayerItemDidPlayToEndTimeNotification object:playerItem];
self.player = [AVPlayer playerWithPlayerItem:playerItem];
self.playerLayer = [AVPlayerLayer playerLayerWithPlayer:self.player];
self.playerLayer.videoGravity = AVLayerVideoGravityResizeAspectFill;
[self.view.layer addSublayer:self.playerLayer];
}
More about AVPlayer and AVPlayerLayer
Upvotes: 3