1. 这里的流媒体地址是指服务端那边已经调好格式的可以在ios上播放的视频流。

下面提供几个视频流的地址:

NSString *linkStr =

http://61.160.227.6/rtencode_m3u8?bl=/f4v/61/140783661.h264_2.f4v&t=8&em=1&se=c629000050724fef&k=8bb5b375af9ab17fa859074fb394455fcd7505",

@"http://61.160.230.12/rtencode_m3u8?bl=/f4v/85/140698785.h264_2.f4v&t=8&em=1&se=b245000050723fb4&k=0dfa39da8293f0684c6cd84fb395905fcd7505",

@"http://58.215.144.42/rtencode_m3u8?bl=/f4v/46/140739646.h264_1.f4v&t=8&em=1&se=751300005072e2d8&k=8d77cf2355c3bf817f6e364fb396005fcd7505“

@"http://ocj2.smgbb.cn/ocj1/ocj1.m3u8"

@"http://ocj2.smgbb.cn/ocj2/ocj2.m3u8"

2.播放视频

CustomPlayerView.h 文件

  #import <UIKit/UIKit.h>

  #import <AVFoundation/AVFoundation.h>

  @interface CustomPlayerView : UIView

  @property(nonatomic,retain) AVPlayer *player;

  @end

CustomPlayerView.m 文件

  #import "CustomPlayerView.h"

  @implementation CustomPlayerView

  +(Class)layerClass{

  return [AVPlayerLayerclass];

  }

  -(AVPlayer*)player{

   return [(AVPlayerLayer*)[self layer]player];

  }

  -(void)setPlayer:(AVPlayer *)thePlayer{

   return [(AVPlayerLayer*)[self layer]setPlayer:thePlayer];

  }

  @end

  CustomMoviePlayerController.h 文件

  #import <UIKit/UIKit.h>

  #import "CustomPlayerView.h"

  #import "MBProgressHUD.h"

  @interface CustomMoviePlayerController : UIViewController<UIPopoverControllerDelegate>{

   IBOutlet CustomPlayerView *moviePlayeView;

   IBOutlet UIButton *playButton;

   IBOutlet UISlider *movieProgressSlider;

  //视频的总时间

   CGFloat totalMovieDuration;

  IBOutlet UILabel *currentTimeLabel;

  IBOutlet UILabel *totalTimeLabel;

  MBProgressHUD *loadingView;

  }

  @property(nonatomic,retain) NSURL *movieURL;

  -(IBAction)doneClick:(id)sender;

  -(IBAction)playClick:(id)sender;

  -(IBAction)movieProgressDragged:(id)sender;

  @end

CustomMoviePlayerController.m文件

//

//  CustomMoviePlayerController.m

//  VideoStreamDemo2

//

//  Created by 刘 大兵 on 12-5-17.

//  Copyright (c) 2012年 中华中等专业学校. All rights reserved.

//

#import "CustomMoviePlayerController.h"

@interfaceCustomMoviePlayerController()

-(void)initPlayer;

-(void)monitorMovieProgress;

-(NSString*)convertMovieTimeToText:(CGFloat)time;

-(void)initMoviewPreview;

-(CustomPlayerView*)previewViewCreate:(CGFloat)xOffsetInSlider;

@end

@implementation CustomMoviePlayerController

@synthesize movieURL;

#pragma mark - View lifecycle

- (void)viewDidLoad

{

[superviewDidLoad];

// Do any additional setup after loading the view from its nib.

loadingView = [[MBProgressHUDalloc]initWithView:self.view];

loadingView.labelText = @"正在加载...";

[self.viewaddSubview:loadingView];

[selfinitPlayer];

[selfmonitorMovieProgress];

[selfinitMoviewPreview];

}

- (void)dealloc {

[movieURL release];

[loadingViewrelease];

//释放对视频播放完成的监测

[[NSNotificationCenterdefaultCenter]removeObserver:selfname:AVPlayerItemDidPlayToEndTimeNotificationobject:moviePlayeView.player.currentItem];

//释放掉对playItem的观察

[moviePlayeView.player.currentItemremoveObserver:self

forKeyPath:@"status"

context:nil];

[moviePlayeViewrelease];

[super dealloc];

}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation

{

// Return YES for supported orientations

return interfaceOrientation!=UIInterfaceOrientationPortraitUpsideDown;

}

-(void)initPlayer{

//显示loadingView

[loadingViewshow:YES];

//使用playerItem获取视频的信息,当前播放时间,总时间等

AVPlayerItem *playerItem = [AVPlayerItem playerItemWithURL:movieURL];

//player是视频播放的控制器,可以用来快进播放,暂停等

AVPlayer *player = [AVPlayer playerWithPlayerItem:playerItem];

[moviePlayeView setPlayer:player];

[moviePlayeView.playerplay];

//计算视频总时间

CMTime totalTime = playerItem.duration;

//因为slider的值是小数,要转成float,当前时间和总时间相除才能得到小数,因为5/10=0

totalMovieDuration = (CGFloat)totalTime.value/totalTime.timescale;

//NSLog(@"totalMovieDuration:%f",totalMovieDuration);

//在totalTimeLabel上显示总时间

totalTimeLabel.text = [selfconvertMovieTimeToText:totalMovieDuration];

//检测视频加载状态,加载完成隐藏loadingView

[moviePlayeView.player.currentItemaddObserver:self

forKeyPath:@"status"

options:NSKeyValueObservingOptionNew

context:nil];

//添加视频播放完成的notifation

[[NSNotificationCenterdefaultCenter]addObserver:selfselector:@selector(moviePlayDidEnd:)name:AVPlayerItemDidPlayToEndTimeNotificationobject:moviePlayeView.player.currentItem];

}

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context{

//    NSLog(@"keyPath:%@,object:%@",keyPath,NSStringFromClass([object class]));

if ([keyPath isEqualToString:@"status"]) {

AVPlayerItem *playerItem = (AVPlayerItem*)object;

if (playerItem.status==AVPlayerStatusReadyToPlay) {

//视频加载完成,隐藏loadingView

[loadingView hide:YES];

}

}

}

-(NSString*)convertMovieTimeToText:(CGFloat)time{

//把秒数转换成文字

if (time<60.f) {

return [NSString stringWithFormat:@"%.0f秒",time];

}else{

return [NSString stringWithFormat:@"%.2f",time/60];

}

}

-(void)monitorMovieProgress{

//使用movieProgressSlider反应视频播放的进度

//第一个参数反应了检测的频率

[moviePlayeView.playeraddPeriodicTimeObserverForInterval:CMTimeMake(1, 1)queue:NULLusingBlock:^(CMTime time){

//获取当前时间

CMTime currentTime = moviePlayeView.player.currentItem.currentTime;

//转成秒数

CGFloat currentPlayTime = (CGFloat)currentTime.value/currentTime.timescale;

movieProgressSlider.value = currentPlayTime/totalMovieDuration;

//用label显示当前播放的秒数

//判断秒数是否满一分钟,如果不满一分钟显示秒,如果满一分钟,显示分钟

currentTimeLabel.text = [self convertMovieTimeToText:currentPlayTime];

//NSLog(@"currentTimeLabel.text:%@",currentTimeLabel.text);

}];

}

-(void)moviePlayDidEnd:(NSNotification*)notification{

//视频播放完成,回退到视频列表页面

[self doneClick:nil];

}

-(IBAction)doneClick:(id)sender{

//停止播放,不然页面dimiss了以后,还有播放的声音

[moviePlayeView.playerpause];

[selfdismissModalViewControllerAnimated:YES];

}

-(IBAction)playClick:(id)sender{

//播放暂停控制,进入页面就开始播放视频,然后播放按钮的文字是暂停

//点击一下播放视频停止,按钮文字变成播放

//判断是播放还是暂停状态

if ([[playButtontitleForState:UIControlStateNormal]isEqualToString:@"暂停"]) {

//从播放状态进入暂停

[moviePlayeView.playerpause];

[playButtonsetTitle:@"播放"forState:UIControlStateNormal];

}else{

//从暂停状态进入播放

[moviePlayeView.playerplay];

[playButtonsetTitle:@"暂停"forState:UIControlStateNormal];

}

}

-(IBAction)movieProgressDragged:(id)sender{

//拖动改变视频播放进度

//计算出拖动的当前秒数

NSInteger dragedSeconds = floorf(totalMovieDuration*movieProgressSlider.value);

NSLog(@"dragedSeconds:%d",dragedSeconds);

//转换成CMTime才能给player来控制播放进度

CMTime dragedCMTime = CMTimeMake(dragedSeconds, 1);

[moviePlayeView.playerpause];

[moviePlayeView.player seekToTime:dragedCMTime completionHandler:^(BOOL finish){

[moviePlayeView.playerplay];

}];

}

//长按手势

-(void)initMoviewPreview{

UILongPressGestureRecognizer *longPress =          [[UILongPressGestureRecognizeralloc]initWithTarget:selfaction:@selector(progessSliderLongPress:)];

[movieProgressSlideraddGestureRecognizer:longPress];

[longPress release];

}

-(void)progessSliderLongPress:(UILongPressGestureRecognizer*)theLong{

//因为长按手势的方法最少会被调用两次,所以为了不重复弹出popOver进行判断,只调用一次弹出popOver

if (theLong.state==UIGestureRecognizerStateBegan) {

//长按以后弹出popView在长按的位置

CGPoint touchPoint = [theLong locationInView:self.view];

//只能显示在进度条上方

CGRect popOverFrame = CGRectMake(touchPoint.x-100, movieProgressSlider.frame.origin.y, 200,150);

UIViewController *previewMovieController = [[UIViewController alloc]init];

//通过长按手势在slider的位置,计算视频预览的时间

CGPoint touchPointInSlider = [theLong locationInView:movieProgressSlider];

CustomPlayerView *previewView = [self previewViewCreate:touchPointInSlider.x];

previewMovieController.view.backgroundColor = [UIColor whiteColor];

previewMovieController.view = previewView;

UIPopoverController *popoverController = [[UIPopoverControlleralloc]initWithContentViewController:previewMovieController];

//更改popover的contentSize

popoverController.delegate = self;

popoverController.popoverContentSize = CGSizeMake(200, 150);

//箭头向下,指向进度条

[popoverController presentPopoverFromRect:popOverFrameinView:self.viewpermittedArrowDirections:UIPopoverArrowDirectionDownanimated:YES];

//播放视频

[previewView.player play];

[previewMovieController release];

//不能在这里使用release和autorelease,因为popOver正在使用,release会导致crash

//[popoverController release];

}

}

//为了使调用视频预览的代码更清晰,把创建playerView的代码和创建popover的分开

-(CustomPlayerView*)previewViewCreate:(CGFloat)xOffsetInSlider{

//        NSLog(@"touchPoint:%@,touchPointInSlider:%@",NSStringFromCGPoint(touchPoint),NSStringFromCGPoint(touchPointInSlider));

//把touchPointInSlider。x除以slider的宽度可以计算出预览的进度

CGFloat previewValue = xOffsetInSlider/movieProgressSlider.bounds.size.width;

//如果长按在进度条的中间,那么previewValue就是0。5,乘以视频的总时间,就知道了视频预览的时间

NSInteger previewSeconds = floorf(previewValue*totalMovieDuration);

//秒数舍弃小数部分,转换成cmTime

CMTime previewCMTime = CMTimeMake(previewSeconds, 1);

//初始化视频预览的view

CustomPlayerView *previewView = [[CustomPlayerView alloc]initWithFrame:CGRectMake(0, 0, 200, 150)];

AVPlayerItem *playerItem = [AVPlayerItem playerItemWithURL:movieURL];

//跳到视频预览的时间

[playerItem seekToTime:previewCMTime];

//player是视频播放的控制器,可以用来快进播放,暂停等

AVPlayer *player = [AVPlayer playerWithPlayerItem:playerItem];

[previewView setPlayer:player];

return [previewView autorelease];

}

- (void)popoverControllerDidDismissPopover:(UIPopoverController *)popoverController{

//popOver已经使用完毕,release是可以的

[popoverController release];

}

@end

AVPlayer 多媒体播放器相关推荐

  1. 【Qt】Qt再学习(八):Media Player(Qt实现多媒体播放器)

    1.简介 Media Player演示了一个简单的多媒体播放器,该播放器可以使用各种编解码器播放音频和/或视频文件. 涉及到的类有 QMediaPlayer.QMediaPlaylist.QVideo ...

  2. 多媒体课程设计android,基于Android的多媒体播放器(课程设计)报告.doc

    基于Android的多媒体播放器(课程设计)报告 基于Android的多媒体播放器课程设计报告 (2014-01-02 22:46:52) HYPERLINK "javascript:;&q ...

  3. android应用课程设计报告,基于Android的多媒体播放器课程设计报告.doc

    基于Android的多媒体播放器课程设计报告.doc 基于Android的多媒体播放器课程设计报告2014-01-02 224652 转载标签 android多媒体播放器嵌入式课程设计报告it分类 我 ...

  4. 强力推荐几种多媒体播放器方案(jQuery、Flash、HTML5)

    记得以前我们想要在网页中插入一段音频或者视频时,首先,baidu或者google一下,目的是要找那段又长又臭的object和embed代码,然后再把它们贴到网页中,然后还发现不同的浏览器写法还不一样, ...

  5. iOS AVPlayer视频播放器

    代码地址如下: http://www.demodashi.com/demo/11168.html 一.运行效果 二.实现过程 ①.创建播放器avPlayer //创建播放器url = [url str ...

  6. VLC Player – 自由、开源的跨平台多媒体播放器

    现在市面上有许多播放器,大多都满足不了我的需求.要么少这个功能,要么少那个功能.找了好多播放器,VLC是最符合我要求的一款. VLC 是一款自由.开源的跨平台多媒体播放器及框架,可播放大多数多媒体文件 ...

  7. 04 Qt音视频多媒体播放器开发,Qt6.2.3 multimedia

    Q6.2.3 multimedia 音视频多媒体播放器开发 步骤: Qt6.2版本中已经有了播放器的Demo,亲测可用.先下载Qt并安装Qt6.2.3,或者更新到Qt6.2.3,直接在欢迎页找到Med ...

  8. 用html5实现一个播放器,6 个基于 HTML5 实现的多媒体播放器

    是 HTML5 中新增的标签,可用于在网页中嵌入视频播放功能,无需 Flash 和其他嵌入插件的支持.但是HTML5目前只有Firefox.Safari.Chrome.Opera.IE9以上支持.此外 ...

  9. 开源的多媒体播放器MPV

    最近在网上找到了一个很好用的开源多媒体播放器MPV,它功能强大.免费开源.支持多平台的极简播放器.底层采用了 MPlayer.mplayer2 和 FFmpeg 等开源项目,支持多种音视频格式.高清视 ...

最新文章

  1. Struts 2 --ONGL介绍
  2. 电脑连接到网络显示未连接到服务器未响应,电脑dns服务器未响应怎么办?
  3. 如何在Windows 7、8、10,Vista或XP中删除Windows服务
  4. 7. 整数反转 golang
  5. oracle的sga
  6. Pytest之skip、skipif、xfail
  7. 黑马程序员——C语言小节------字符串与指针
  8. 一文带你弄懂什么是索引二叉堆
  9. 对“被投诉”的最新解读(外四篇)
  10. 深度置信网络(DBN)【经典的DBN网络结构是由若干层 RBM(受限波尔兹曼机)和一层 BP 组成的一种深层神经网络】
  11. 大众新能源电动车ID.3ID.4技术培训教材手册维修手册电路图
  12. 2021-09-08Cloudera Manager集群报警,堆转储目录/tmp 或日志目录/var/log 可用空间小于 5.0 吉字节
  13. 【文献阅读】ERNIE: Enhanced Representation through Knowledge Integration
  14. 虚拟路由冗余协议(VRRP)
  15. 推荐!32个好用的百度网盘搜索引擎
  16. 2022年武汉市级产业化投资和技术改造专项以及工业智能化改造专项申报开始!13区申报条件、1千万补助
  17. 联想电脑快捷键的使用和通用设置
  18. Lottie 免费动画、在线预览
  19. 神经网络与深度学习学习笔记(一)——基本概念
  20. 淘宝店群玩法,双十一商家自运营,淘宝店群好处,建淘宝店群门槛条件

热门文章

  1. WPF开发学生信息管理系统【WPF+Prism+MAH+WebApi】(一)
  2. python导入模块失败_Python导入模块时遇到的错误分析
  3. elasticsearch集群搭建及springboot集成使用
  4. 关于肺结节和肺肿瘤检测分割
  5. Adobe After Effects(AE) v7.0 官方中文正式版
  6. OFDM数学原理及推导
  7. CAD中 OLE不能旋转_CAD制图初学入门教程:阵列功能的使用技巧
  8. python翻译器怎么下载_Python实现桌面版翻译工具教程
  9. 决策树中的CART树
  10. aps计划排程的生产工艺模型