zoukankan      html  css  js  c++  java
  • iOS的影片播放 MediaPlayer 和 AVPlayer

    在iOS開發上,如果遇到需要播放影片,如開機動畫…,我們很習慣地會使用MediaPlayer來播放影片,因為很方便使用,所以就一直使用下去。但是隨著客戶的要求越來越嚴苛,尤其是過場動畫或互動效果上的表現。所以如果在一些動畫中還挾帶影片一起運算,那勢必機器會跑不動。所以在iOS 4之後,我們可以使用AVPlayer這個類別來進行更細微的操作。

    備註:

    • MediaPlayer的影片是放在UIView 裡面,而AVPlayer是放在AVPlayerLayer裡面,AVPlayerLayer是CALayer 的子類別。
    • 使用MediaPlayer前,要記得加入MediaPlayer.framework及#import <MediaPlayer/MediaPlayer.h>
    • 使用AVPlayer前,要記得加入AVFoundation.frameworkk及#import <AVFoundation/AVFoundation.h>

    請參考以下的範例:

    使用MediaPlayer來播放影片

    1. NSString *filePath = [[NSBundle mainBundle] pathForResource:@"backspace" ofType:@"mov"];  
    2. NSURL *sourceMovieURL = [NSURL fileURLWithPath:filePath];  
    3.   
    4. moviePlayer = [[MPMoviePlayerController alloc] initWithContentURL:sourceMovieURL];  
    5. moviePlayer.view.frame=CGRectMake(0, 0, 1024, 768);  
    6. moviePlayer.controlStyle=MPMovieControlStyleNone;  
    7.   
    8. // Play the movie!  
    9. [self.view addSubview:moviePlayer.view];  


    使用AVPlayer來播放影片

      1. NSString *filePath = [[NSBundle mainBundle] pathForResource:@"backspace" ofType:@"mov"];  
      2. NSURL *sourceMovieURL = [NSURL fileURLWithPath:filePath];  
      3.   
      4. AVAsset *movieAsset = [AVURLAsset URLAssetWithURL:sourceMovieURL options:nil];  
      5. AVPlayerItem *playerItem = [AVPlayerItem playerItemWithAsset:movieAsset];  
      6. AVPlayer *player = [AVPlayer playerWithPlayerItem:playerItem];  
      7. AVPlayerLayer *playerLayer = [AVPlayerLayer playerLayerWithPlayer:player];  
      8. playerLayer.frame = self.view.layer.bounds;  
      9. playerLayer.videoGravity = AVLayerVideoGravityResizeAspect;  
      10.   
      11. [self.view.layer addSublayer:playerLayer];  
      12. [player play];  
  • 相关阅读:
    随手记十——淘宝静态页面
    随手记九——溢出文字处理、背景图片填充、图片代替文字
    随手记八——关于伪元素和仿淘宝导航栏
    随手记七——关于float的一个上节没明白的问题
    随手记六——两个经典BUG和bfc
    随手记五——盒子模型和层模型
    随手记四——一些课堂笔记和小技巧、总结
    随手记三——理解相邻兄弟选择器的辛酸过程
    随手记二——CSS样式和选择器
    jQuery实现手风琴效果
  • 原文地址:https://www.cnblogs.com/yulang314/p/3710379.html
Copyright © 2011-2022 走看看