iOS中流媒体【视频】播放和下载【用到第三方的助手类】
-
iOS中关于流媒体的简介:介于下载本地播放与实时流媒体之间的一种播放形式,下载本地播放必须全部将文件下载完成后才能播放,而渐进式下载不必等到全部下载完成后再播放,它可以一边下载一边播放,在完成播放内容之后,整个文件会保存在手机上。
实时流媒体
实时流媒体是一边接收数据包一边播放,本地不保留文件副本,实时流式传输总是实时传送,可以实时实况转播,支持随机访问,用户可以快进或者快退以观看前面或后面的内容。实时流媒体传输必须保证数据包的传输速度大于文件的播放速度,否则用户看到的视频会出现暂停。当网络堵塞情况下视频质量会下降,所以要想保证视频的质量渐进式下载会更好一些。
下面是本人亲测的流媒体播放和下载教程:
1.界面搭建(如图)
2.用到的第三方助手类
下载地址:http://pan.baidu.com/s/1hrvqXA8
3.开始项目-头文件及相关宏
LO_ViewController.h
?123456789101112#
import
<uikit uikit.h=
""
>
#
import
<mediaplayer mediaplayer.h=
""
>
#
import
"M3U8Handler.h"
#
import
"VideoDownloader.h"
#
import
"HTTPServer.h"
@interface
LO_ViewController : UIViewController<m3u8handlerdelegate,videodownloaddelegate>
@property
(nonatomic, strong)HTTPServer * httpServer;
@property
(nonatomic, strong)VideoDownloader *downloader;
@end
</m3u8handlerdelegate,videodownloaddelegate></mediaplayer></uikit>
LO_ViewController.m
?12345678910111213141516171819202122232425262728293031323334353637#
import
"LO_ViewController.h"
@interface
LO_ViewController ()
@property
(weak, nonatomic) IBOutlet UIProgressView *progressView;
@property
(weak, nonatomic) IBOutlet UILabel *progressLabel;
@property
(weak, nonatomic) IBOutlet UIButton *downloadButton;
@property
(weak, nonatomic) IBOutlet UIButton *clearButton;
@end
@implementation
LO_ViewController
- (
void
)viewDidLoad
{
[
super
viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
//打开本地服务器
[self openHttpServer];
if
([[[NSUserDefaults standardUserDefaults] objectForKey:@
"isDownload"
] boolValue]) {
[self.downloadButton setTitle:@
"已完成"
forState:UIControlStateNormal];
self.downloadButton.enabled = NO;
self.clearButton.enabled = YES;
M3U8Handler *handler = [[M3U8Handler alloc] init];
[handler praseUrl:[NSString stringWithFormat:@
"http://v.youku.com/player/getM3U8/vid/XNjUxMTE4NDAw/type/mp4"
]];
handler.playlist.uuid = @
"XNjUxMTE4NDAw"
;
self.downloader = [[VideoDownloader alloc]initWithM3U8List:handler.playlist];
[self.downloader addObserver:self forKeyPath:@
"clearCaches"
options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];
// 判断是否清理缓存
}
}
#pragma mark - 打开本地服务器
?12345678910111213141516171819- (
void
)openHttpServer
{
self.httpServer = [[HTTPServer alloc] init];
[self.httpServer setType:@
"_http._tcp."
];
// 设置服务类型
[self.httpServer setPort:
12345
];
// 设置服务器端口
// 获取本地Library/Cache路径下downloads路径
NSString *webPath = [kLibraryCache stringByAppendingPathComponent:kPathDownload];
NSLog(@
"-------------\nSetting document root: %@\n"
, webPath);
// 设置服务器路径
[self.httpServer setDocumentRoot:webPath];
NSError *error;
if
(![self.httpServer start:&error])
{
NSLog(@
"-------------\nError starting HTTP Server: %@\n"
, error);
}
}
?1234#pragma mark - 清理缓存
- (IBAction)clearCaches:(id)sender {
[self.downloader cleanDownloadFiles];
}
#pragma mark - 在线流媒体播放
?1234567891011- (IBAction)playStreamingMedia:(id)sender {
// 优酷视频m3u8新地址格式如下:http://pl.youku.com/playlist/m3u8?vid=XNjUxMTE4NDAw&type=mp4
// 如果上面的链接不可用,那么使用这个链接http://v.youku.com/player/getM3U8/vid/XNjUxMTE4NDAw/type/mp4,如果两个连接都不可以用的话,那么很大可能是优酷的服务器挂掉了
// 如果上面的两种格式都不行的话,考虑用这个格式,当然如果这个格式不行的话,是上面的,或者直接换个对应的m3u8的地址 http://pl.youku.com/playlist/m3u8?vid=162779600&ts=1407469897&ctype=12&token=3357&keyframe=1&sid=640746989782612d6cc70&ev=1&type=mp4&ep=dCaUHU2LX8YJ4ivdjj8bMyqxJ3APXP8M9BiCiNRiANQnS%2B24&oip=2043219268
NSURL *url = [[NSURL alloc] initWithString:@
"http://pl.youku.com/playlist/m3u8?vid=162779600&ts=1407469897&ctype=12&token=3357&keyframe=1&sid=640746989782612d6cc70&ev=1&type=flv&ep=dCaUHU2LX8YJ4ivdjj8bMyqxJ3APXP8M9BiCiNRiANQnS%2B24&oip=2043219268"
];
MPMoviePlayerViewController *player = [[MPMoviePlayerViewController alloc] initWithContentURL:url];
[self presentMoviePlayerViewControllerAnimated:player];
}
#pragma mark - 视频下载
?12345678910111213141516171819202122232425- (IBAction)downloadStreamingMedia:(id)sender {
UIButton *downloadButton = sender;
// 获取本地Library/Cache路径
NSString *localDownloadsPath = [kLibraryCache stringByAppendingPathComponent:kPathDownload];
// 获取视频本地路径
NSString *filePath = [localDownloadsPath stringByAppendingPathComponent:@
"XNjUxMTE4NDAw/movie.m3u8"
];
NSFileManager *fileManager = [NSFileManager defaultManager];
// 判断视频是否缓存完成,如果完成则播放本地缓存
if
([fileManager fileExistsAtPath:filePath]) {
[downloadButton setTitle:@
"已完成"
forState:UIControlStateNormal];
downloadButton.enabled = NO;
}
else
{
M3U8Handler *handler = [[M3U8Handler alloc] init];
handler.delegate = self;
// 解析m3u8视频地址
[handler praseUrl:@
"http://pl.youku.com/playlist/m3u8?vid=162779600&ts=1407469897&ctype=12&token=3357&keyframe=1&sid=640746989782612d6cc70&ev=1&type=flv&ep=dCaUHU2LX8YJ4ivdjj8bMyqxJ3APXP8M9BiCiNRiANQnS%2B24&oip=2043219268"
];
// 开启网络指示器
[[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:YES];
}
}
#pragma mark - 播放本地缓存视频
?123456789101112131415161718192021222324252627282930313233- (IBAction)playVideoFromLocal:(id)sender {
NSString * playurl = [NSString stringWithFormat:@
"http://127.0.0.1:12345/XNjUxMTE4NDAw/movie.m3u8"
];
NSLog(@
"本地视频地址-----%@"
, playurl);
// 获取本地Library/Cache路径
NSString *localDownloadsPath = [kLibraryCache stringByAppendingPathComponent:kPathDownload];
// 获取视频本地路径
NSString *filePath = [localDownloadsPath stringByAppendingPathComponent:@
"XNjUxMTE4NDAw/movie.m3u8"
];
NSFileManager *fileManager = [NSFileManager defaultManager];
// 判断视频是否缓存完成,如果完成则播放本地缓存
if
([fileManager fileExistsAtPath:filePath]) {
MPMoviePlayerViewController *playerViewController =[[MPMoviePlayerViewController alloc]initWithContentURL:[NSURL URLWithString: playurl]];
[self presentMoviePlayerViewControllerAnimated:playerViewController];
}
else
{
UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@
"Sorry"
message:@
"当前视频未缓存"
delegate:self cancelButtonTitle:@
"确定"
otherButtonTitles:nil, nil];
[alertView show];
}
}
#pragma mark -
#pragma mark - 视频解析完成
-(
void
)praseM3U8Finished:(M3U8Handler*)handler
{
handler.playlist.uuid = @
"XNjUxMTE4NDAw"
;
self.downloader = [[VideoDownloader alloc]initWithM3U8List:handler.playlist];
[self.downloader addObserver:self forKeyPath:@
"currentProgress"
options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];
// 设置观察者用来得到当前下载的进度
[self.downloader addObserver:self forKeyPath:@
"clearCaches"
options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];
// 判断是否清理缓存
self.downloader.delegate = self;
[self.downloader startDownloadVideo];
// 开始下载
}
#pragma mark - 通过观察者监控下载进度显示/缓存清理
?1234567891011121314151617181920212223-(
void
)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(
void
*)context
{
if
([keyPath isEqualToString:@
"clearCaches"
]) {
self.downloadButton.enabled = YES;
[self.downloadButton setTitle:@
"下载"
forState:UIControlStateNormal];
self.clearButton.enabled = NO;
[[NSUserDefaults standardUserDefaults] setObject:[NSNumber numberWithBool:NO] forKey:@
"isDownload"
];
[[NSUserDefaults standardUserDefaults] synchronize];
self.progressView.progress =
0.0
;
self.progressLabel.text = [NSString stringWithFormat:@
"%.2f%%"
,
0.0
];
}
else
{
self.progressLabel.text = [NSString stringWithFormat:@
"%.2f%%"
,
100
* [[change objectForKey:@
"new"
] floatValue]];
self.progressView.progress = [[change objectForKey:@
"new"
] floatValue];
if
(self.progressView.progress ==
1
) {
[[NSUserDefaults standardUserDefaults] setObject:[NSNumber numberWithBool:YES] forKey:@
"isDownload"
];
[self.downloadButton setTitle:@
"已完成"
forState:UIControlStateNormal];
[[NSUserDefaults standardUserDefaults] synchronize];
self.clearButton.enabled = YES;
self.downloadButton.enabled = NO;
}
}
}
?12345#pragma mark - 视频解析失败
-(
void
)praseM3U8Failed:(M3U8Handler*)handler
{
NSLog(@
"视频解析失败-failed -- %@"
,handler);
UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"噢,NO~
iOS中流媒体【视频】播放和下载【用到第三方的助手类】相关推荐
- iOS m3u8本地缓存播放(控制下载并发、暂停恢复)
一m3u8缓存播放的整个流程 二控制媒体下载的并发数 三控制单个媒体的切片下载并发数 四下载的中断和恢复 总结下任务生命周期中的任务状态变化 五注意的问题与思路延伸 一.m3u8缓存播放的整个流程 1 ...
- 自媒体视频素材免费下载,简直是视频剪辑爱好者的福音
01.凌点视频素材网 这是一个免费的视频下载网站,不仅有上百万的免费视频素材可供你免费下载,付费素材现在限时注册也可以免费下载!并且还有Pr模板.AE模板.会声会影和EDIUS的模板可供你免费下载,简 ...
- 转:Android IOS WebRTC 音视频开发总结 (系列文章集合)
随笔分类 - webrtc Android IOS WebRTC 音视频开发总结(七八)-- 为什么WebRTC端到端监控很关键? 摘要: 本文主要介绍WebRTC端到端监控(我们翻译和整理的,译者: ...
- Android IOS WebRTC 音视频开发
转 自:http://www.cnblogs.com/lingyunhu/category/626157.html 作者:lingyunhu rtc.blacker@gmail.com 随笔分类 - ...
- iOS音视频实现边下载边播放
iOS音视频实现边下载边播放 近段时间制作视频播放社区的功能,期间查找了不少资料,做过很多尝试,现在来整理一下其中遇到的一些坑.由于考虑到AVPlayer对视频有更高自由度的控制,而且能够使用它自定义 ...
- h5 ios Safair下载文件自动添加.html导致文件乱码问题,ios不能使用接口播放视频的问题
需求:h5 页面 下载pdf,doc,docx,xlsx,xls 文件的功能 在安卓手机和 ios上的uc浏览器是可以正常的 下载或者预览的 但是在ios的Safair 下载时会被自动添加html尾缀 ...
- 如何使用VLC媒体播放软件下载网页上视频?
如何使用VLC媒体播放软件下载网页上视频? 已经成功利用VLC成功下载过知乎.新浪微博中的小视频: 工具:电脑安装VLC软件: 网络环境:电脑连接上Internet: 浏览器:google chrom ...
- iOS开发系列--音频播放、录音、视频播放、拍照、视频录制(转)
概览 随着移动互联网的发展,如今的手机早已不是打电话.发短信那么简单了,播放音乐.视频.录音.拍照等都是很常用的功能.在iOS中对于多媒体的支持是非常强大的,无论是音视频播放.录制,还是对麦克风.摄像 ...
- 牛人iOS开发系列--音频播放、录音、视频播放、拍照、视频录制
概览 随着移动互联网的发展,如今的手机早已不是打电话.发短信那么简单了,播放音乐.视频.录音.拍照等都是很常用的功能.在iOS中对于多媒体的支持是非常强大的,无论是音视频播放.录制,还是对麦克风.摄像 ...
最新文章
- python自学入门教程-Python基础教程,Python入门教程(非常详细)
- 华为研发出了哪些芯片?
- [转载] 百科全说——王晓斋:解析中西医应对肝肾问题(10-10-12)
- 用python计算2+4+6+…+20的值_计算2*3+(2*(5+6)*3)/2+4*6的值
- SAP Spartacus My Company url的数据源, 来自Sampledataaddon
- 【JavaWeb】石家庄地铁搭乘系统——第一版(功能尚未完善)
- P3455 [POI2007]ZAP-Queries
- 安装FFmpeg后,发现没有生成ffplay的解决办法
- Springcloud服务如何在Eureka安全优雅的下线
- 数据结构和算法———P2 算法概述
- apache简单安全配置
- java表示学生信息的类Student,并输出相关信息
- 【李宏毅机器学习】04:梯度下降Gradient Descent
- IIS7.5下的web.config 404应该如何配置
- RecyclerView 实现横向滚动效果
- 【防火墙_静态路由】
- maven Filtering true 作用
- Python 毕设精品实战案例——快速索引目录
- python求多叉树任意两点之间的距离
- 对学校的希望和寄语_家长写给孩子表达鼓励与期望的话
热门文章
- 【2021-08-05 修订】【梳理】计算机网络:自顶向下方法 第六章 链路层和LAN(docx)
- java如何实现系统定位_如何快速定位到系统中某一功能的具体实现
- 请说说自己对鲁迅本人他作品的了解计算机,26 回忆鲁迅先生课堂实录及点评
- Spirng的事务 方法A调用方法B,事务是否失效
- 青龙面板搭建及记录踩过的坑
- UNETR 医学图像分割架构 2D版 (Tensorflow2 Keras 实现UNETR)
- AS SSD软件查看信息说明
- 阿里图标字体库的动态使用Android
- C++动态分配内存空间
- 特征选择:11 种特征选择策略总结!