美文网首页
那些年,追逐过的小视频

那些年,追逐过的小视频

作者: wesk痕 | 来源:发表于2017-01-17 23:46 被阅读0次

最近公司快不行了,又有空闲的时间了😳,对之前做的一些功能做一些总结,微信小视频,曾经热火朝天的功能,许多社交类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元素比较简单,但也能比较不同方式的性能差异,视频播放其实并不难实现,主要是注意性能,利用线程的特性,处理好视频播放。视频播放肯定还有其他实现方式。

相关文章

  • 那些年,追逐过的小视频

    最近公司快不行了,又有空闲的时间了?,对之前做的一些功能做一些总结,微信小视频,曾经热火朝天的功能,许多社交类ap...

  • 那些年追逐过的

    在上小学时我们唱过一首歌《再过过二十年我们来相会》,常常幻想着什么时候能够楼上楼下电灯电话。那时家里用的是煤...

  • Brighter (Radio Edit)

    *本周推荐——Brighter (Radio Edit) - the two friends 那些年追逐过的...

  • 那些年

    那些年 我追逐过的风 迷恋过的笑容 到如今,你可曾遗忘 那些年 我始终的目光 为爱而痴狂 你可曾取笑 那些年 我说...

  • 那些年,我们一起追逐过的酒场

    晚风习习,树动月凝…… 夏天这个季节,怪有意思。白天的大街上,人少且疾行,宛如火上房。到了晚上,呼啦啦一下子全出来...

  • 远方

    总有一些句子 像是镌刻了岁月的故事 总有一些人 岁月为他们写下不朽的诗 那些年 我们暗恋过的男孩 那些年 我们追逐...

  • 那些追逐的日子

    那些追逐的日子 总未能好好欣赏身周更替的四季 把黑夜过成了虚拟 把白天活成了现实 那些追逐的日子 除了想方设法遮风...

  • 我交给你们一个孩子

    之前从来不曾留意那些自媒体网红,然而今天一整天,我都在刷那些关于胡同学的小视频。 全网都在追逐一个最终结果,然而这...

  • 那些年我们追逐的梦想

    告别写作已十年有余,十年间,从意气风发到棱角渐失,从青涩稚嫩到相夫教子,时光就这么悄无声息地溜走了,留下一道道印记...

  • 安静如花

    年过不惑,我喜欢上了安静,简单的生活。 年轻的时候,走在车水马龙的路上,目光总追逐那些或充满活力...

网友评论

      本文标题:那些年,追逐过的小视频

      本文链接:https://www.haomeiwen.com/subject/gokvbttx.html