那些年,追逐过的小视频

最近公司快不行了,又有空闲的时间了😳,对之前做的一些功能做一些总结,微信小视频,曾经热火朝天的功能,许多社交类app都想着模仿。下面就来解析下小视频功能特点。
1.小视频没有声音
2.小视频在cell中无限循环播放
3.性能要求,滑动需要顺畅(线程设计)。

最早接触iOS,我只知道播放视频通常有两种方式,一种是 AVPlayer,另一种是MPMoviePlayerController 。现在 ios9之后苹果已推荐播放视频使用 AVPlayer。

下面介绍下简单的说下 AVPlayer 视频播放器使用时的相关知识,具体的参见官方文档

//创建一个AVPlayer播放类
@property(nonatomic,strong) AVPlayer *player;

//AVPlayerItem(多媒体资源)
@property(nonatomic,strong) AVPlayerItem *playerItem;

//AVAsset(音视频当中单个资源,例如声道,影片)
@property (nonatomic, strong) AVAsset

AVPlayer功能很强大,音视频都可以播放,但像小视频功能我们只需要他的视频功能, 音频功能不需要,如果小视频功能用AVPlayer来实现,系统开销可能就有点浪费了,因为AVPlayer实现了Video+Audio ,而且AVPlayer的音频对AudioSession也有影响,如果app其他地方有使用到声音的,需要注意它的使用了。

后来追求性能,发现了AVAssetReader
AVAssetReader用于从AVAsset资源中读取媒体样本,可以读取出视频和音频

//从媒体中得到声音轨道   AVMediaTypeVideo 视频
 AVAssetTrack *track = [[asset tracksWithMediaType:AVMediaTypeAudio] firstObject];

AVAssetReaderOutput输出资源并通过copyNextSampleBuffer方法将我们需要的数据给弄一份出来。注意读取的过程是分帧(音频是分块)读取,并不是一次性将将所有数据读取去完毕。结束时,AVAssetReader的status属性 会变成AVAssetReaderStatusCompleted,通过此属性来判断是否读取完毕。

//从媒体中得到视频轨道   AVMediaTypeAudio 音频
    AVAssetTrack *track = [[self.asset tracksWithMediaType:AVMediaTypeVideo] objectAtIndex:0];
 
 //读取配置
NSDictionary *setting = @{
                              (id)kCVPixelBufferPixelFormatTypeKey:@(kCVPixelFormatType_32BGRA),
                              (id)kCVPixelBufferWidthKey:@(self.size.width),
                              (id)kCVPixelBufferHeightKey:@(self.size.height),
                              };

//读取输出,在相应的轨道和输出对应格式的数据
    self.assetReaderOutput = [[AVAssetReaderTrackOutput alloc] initWithTrack:track outputSettings:setting];
//赋给读取并开启读取
    if ([self.assetReader canAddOutput:self.assetReaderOutput]) {
        [self.assetReader addOutput:self.assetReaderOutput];
    }
    [self.assetReader startReading];//开始读取

小视频功能可以通过AVPlayer和AVAssetReader 两种途径实现,
我写了个简单的demo,但里面还是有很多学问的。下面简述下demo中的3中实现方式:

实现方式1:用过AVPlayer的 可能都遇到过这么一个现象:黑屏。黑屏的原因是app最多支持16个AVPlayerLayer同时存在,等到17个的时候就会出现黑屏,解决这个问题需要及时释放AVPlayer相关资源。 如果一屏需要展示的播放个数大于16,那么AVPlayer就不适合用来实现小视频,当然实际过程中1屏幕就最多6,7个人视频同时播放了。

实现方式2:利用AVAssetReader 中的获取到的CGImageRef
将每一帧都放到layer.contents中展示

    self.videoImageView.layer.contents = (__bridge id)(imageRef);

实现方式3:实际开发中 gif图 你可以是服务器下载下来的,也可以是通过AVAssetReader 获取到所需要的UIImages,制作成gif,然后保存展示。

以上3中方式,1的性能较差。2,3各有优点。

这3种方式都有一个最大的特点,cell滑动过程中不做视频的加载,这样做为了滑动更流畅,结束的时候再加载当前屏幕中的cell视频。对于gif和customPlayerLayer如果想要修改成滑动时播放,需要修改timer的runloop的model。

//cell 不在可视区域内 可以暂停播放 释放资源
- (BOOL)currentCellIsNotShowedInScreen
{
    UITableView *table;
    for (UIView* next = [self superview]; next; next = next.superview) {
        UIResponder* nextResponder = [next nextResponder];
        if ([nextResponder isKindOfClass:[UITableView class]]) {
            table = (UITableView *)nextResponder;
            break;
        }
    }
    if (table) {
        CGRect cellR = [table rectForRowAtIndexPath:self.currentIndexPath];
        if ((table.contentOffset.y + table.frame.size.height) < CGRectGetMinY(cellR) || table.contentOffset.y > CGRectGetMaxY(cellR)) {
            return true;
        }
    }
    return false;
}

demo
总结:demo中cell元素比较简单,但也能比较不同方式的性能差异,视频播放其实并不难实现,主要是注意性能,利用线程的特性,处理好视频播放。视频播放肯定还有其他实现方式。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 韩信北伐平定魏国,接下来倒霉的是代国。这场平定代国的战争悬念重重,我所说的悬念重重是指在史书上实在找不到什么细致的...
    8ab8acb9105c阅读 927评论 1 1
  • Weex 入门新手安装问题 -IOS 之前在网上找了很多很多文档,包括官方的文档都写的不是很详细 而且随着版本更迭...
    半块阅读 1,304评论 1 0
  • 题目:任选一款互联网产品,使用任一分析理论,分析该产品可监控的数据指标,报告包含: 1、所选取的互联产品简介 2、...
    小遥yao阅读 3,507评论 2 20
  • 那年春暖花开时, 用一元的酬金迎得了你 _狸猫。 你初来乍到, 一点也不怯生, 扑闪扑闪着一双大眼睛, 左顾右盼。...
    寒桦阅读 465评论 23 52