iOS視頻渲染(大小屏切換,小屏拖拽,后臺喚醒)

前言

上一篇 視頻采集
demo地址

正文

ios中視頻流渲染有三種方法:

AVCaptureVideoPreviewLayer:視頻采集時回顯使用的圖層揣钦, 調用簡單移层,功能較少。

AVSampleBufferDisplayLayer:CPU渲染yuv數據也可直接渲染壓縮的視頻數據憔鬼,小巧方便龟劲,功能比較豐富,可操作性強轴或。

openGl:GPU渲染昌跌,功能強大,性能卓越照雁,使用復雜蚕愤。

本文主要介紹AVSampleBufferDisplayLayer,demo分為兩個類,大屏和小屏,小屏繼承自大屏類.

openGl推薦參考:落影l(fā)oyinglin

創(chuàng)建渲染圖層

- (void)createLayer
{
    if (!self.buffer_layer)
    {
        self.buffer_layer = [[AVSampleBufferDisplayLayer alloc]init];
        self.buffer_layer.frame = self.bounds;
        self.buffer_layer.position = CGPointMake(CGRectGetMidX(self.bounds), CGRectGetMidY(self.bounds));
        /*!
         @constant      AVLayerVideoGravityResizeAspect  根據圖像像素比例 繪制圖像 圖像會填充不滿圖層size
         @abstract      Preserve aspect ratio; fit within layer bounds.
         
         @constant      AVLayerVideoGravityResizeAspectFill  根據像素比例 填充圖層 畫面會超出圖層size
         @abstract      Preserve aspect ratio; fill layer bounds.
         
         @constant      AVLayerVideoGravityResize   拉伸 用這個自適應不同size圖層最好
         @abstract      Stretch to fill layer bounds.
         */
        self.buffer_layer.videoGravity = AVLayerVideoGravityResizeAspect;
        //不透明
        self.buffer_layer.opaque = YES;
        [self.layer addSublayer:self.buffer_layer];
    }
    else
    {
        [CATransaction begin];
        [CATransaction setDisableActions:YES];
        self.buffer_layer.bounds = self.qlframe;
        self.buffer_layer.position = CGPointMake(CGRectGetMidX(self.bounds), CGRectGetMidY(self.bounds));
        [CATransaction commit];
    }
}

播放

#pragma mark - play
// 每來一幀數據進行緩存, 從后臺模式返回后, 重啟layer
- (void)play:(CMSampleBufferRef)buffer
{
    if (buffer)
    {
        [_buffer_layer enqueueSampleBuffer:buffer];
        if (_buffer_layer.status == AVQueuedSampleBufferRenderingStatusFailed)
        {
            //后臺喚醒重啟渲染層
            if (-11847 == _buffer_layer.error.code)
            {
                NSLog(@"11111");
                [self rebuildSampleBufferDisplayLayer];
            }
            else
            {
                [self rebuildSampleBufferDisplayLayer];
                NSLog(@"%s 第%d行 %@",__func__,__LINE__,_buffer_layer.error.description);
            }
        }
    }
}

#pragma mark - 重啟渲染layer
- (void)rebuildSampleBufferDisplayLayer
{
    [self remove_layer];
    [self createLayer];
}

- (void)remove_layer
{
    if (self.buffer_layer)
    {
        [self.buffer_layer stopRequestingMediaData];
        [self.buffer_layer removeFromSuperlayer];
        self.buffer_layer = nil;
    }
}

小屏

小屏的切換和拖拽功能只是添加了兩個手勢

- (instancetype)initWithFrame:(CGRect)frame and_touchBlock:(touchBlock)touch_block and_panBlcok:(panblock)pan_block
{
    if (self = [super initWithFrame:frame and_touchBlock:touch_block and_panBlcok:pan_block])
    {
        UITapGestureRecognizer * tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap:)];
        [self addGestureRecognizer:tap];
        UIPanGestureRecognizer * pan = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(pan:)];
        [self addGestureRecognizer:pan];
    }
    return self;
}

- (void)tap:(UITapGestureRecognizer*)tap
{
     // 切換大小屏時,在此block內 調用flushAndRemoveImage 清除緩存
    self.touch_block();
}

- (void)pan:(UIPanGestureRecognizer*)pan
{
    self.pan_block(pan);
}

最后

demo地址
下一篇:音頻采集播放與編解碼
歡迎交流指正

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市囊榜,隨后出現的幾起案子审胸,更是在濱河造成了極大的恐慌,老刑警劉巖卸勺,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異烫扼,居然都是意外死亡曙求,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門映企,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悟狱,“玉大人,你說我怎么就攤上這事堰氓〖方ィ” “怎么了?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵双絮,是天一觀的道長浴麻。 經常有香客問我得问,道長,這世上最難降的妖魔是什么软免? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任宫纬,我火速辦了婚禮,結果婚禮上膏萧,老公的妹妹穿的比我還像新娘漓骚。我一直安慰自己,他們只是感情好榛泛,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布蝌蹂。 她就那樣靜靜地躺著,像睡著了一般曹锨。 火紅的嫁衣襯著肌膚如雪孤个。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天艘希,我揣著相機與錄音硼身,去河邊找鬼。 笑死覆享,一個胖子當著我的面吹牛佳遂,可吹牛的內容都是我干的。 我是一名探鬼主播撒顿,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼丑罪,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了凤壁?” 一聲冷哼從身側響起吩屹,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拧抖,沒想到半個月后煤搜,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡唧席,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年擦盾,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片淌哟。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡迹卢,死狀恐怖,靈堂內的尸體忽然破棺而出徒仓,到底是詐尸還是另有隱情腐碱,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布掉弛,位于F島的核電站症见,受9級特大地震影響喂走,放射性物質發(fā)生泄漏。R本人自食惡果不足惜筒饰,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一缴啡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瓷们,春花似錦业栅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至攒钳,卻和暖如春帮孔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背不撑。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工文兢, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人焕檬。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓姆坚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親实愚。 傳聞我的和親對象是個殘疾皇子兼呵,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評論 25 707
  • 我們在項目中有時會碰到視頻相關的需求,一般的可以分為幾種情況: 1. 簡單的視頻開發(fā)腊敲,對界面無要求击喂,可直接使用系統(tǒng)...
    純情_小火雞閱讀 20,879評論 2 103
  • 發(fā)現 關注 消息 iOS 第三方庫、插件碰辅、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,024評論 4 62
  • 落日西墜没宾,從金黃的云彩里射出數道霞光忍法,染紅了半邊天。一汪湖水如一面巨大的鏡子榕吼,倒映著山水與晚霞,將天地裝飾得如夢似...
    萬空空閱讀 275評論 2 2