[FFMPEG]h264的YUV420数据的存储


前面文章有人问我解码出来的264如何播放,一般用OPENGLES去渲染

  • 这里只给关键部分代码, 从最近做的项目里面摘出来的。
    这部分内容推荐看一本书《音视频进阶开发指南Android和iOS》
    c++

这里我定义了一个snode结构体来存储YUV数据,这个自己也可以写;

还有一个经常被忽略的问题:记住处理内存泄露的问题,如果常年不写c++的话可能会忽视掉这个问题。 用PS检测内存泄露情况,跑上个十来八个小时的看下内存变换情况; 但是如果你常年写java,php,python操作系统课本不扎实的话就得回头好好补补了,代码风骚的背后需要理论功底去突破瓶颈,不需要背名词,但要记原理

        if (open_ret1 >= 0 ) {
                avcodec_decode_video2(rtspVideoCodecContext, v_frame, &got_picture, read_packet);
                printf("1\n");
                if (got_picture) {
                    // Init And Define YUV INFO
                    /* 
                    snode->luma = new unsigned char[width*height];
                    snode->chromaB = new unsigned char[width*height/4];
                    snode->chromaR = new unsigned char[width*height/4];
                    */

                    printf("alloc ok\n");
                    unsigned int height = rtspVideoCodecContext->height;
                    unsigned int width = rtspVideoCodecContext->width;
                    printf("decode video ok:%d,%d\n",width,height);

                    if (snode->luma != NULL) delete []snode->luma;
                    if (snode->chromaB != NULL) delete []snode->chromaB;
                    if (snode->chromaR != NULL) delete []snode->chromaR;
                    snode->luma = NULL;
                    snode->chromaB = NULL; 
                    snode->chromaR = NULL; 

                    snode->luma = new char[width*height];
                    snode->chromaB = new char[width*height/4];
                    snode->chromaR = new char[width*height/4];

                    int i;
                    for (i = 0; i<height; i++) {
                        memcpy(snode->luma + width*i, v_frame->data[0] + i * v_frame->linesize[0], width);
                        //memcpy(snode->luma + a, v_frame->data[0] + i * v_frame->linesize[0], width);
                    }
                    for (i = 0; i<height / 2; i++) {
                        memcpy(snode->chromaB + width/2*i, v_frame->data[1] + i * v_frame->linesize[1], width / 2);
                        //memcpy(snode->chromaB + a, v_frame->data[1] + i * v_frame->linesize[1], width / 2);
                    }
                    for (i = 0; i<height / 2; i++) {
                        memcpy(snode->chromaR + width/2*i, v_frame->data[2] + i * v_frame->linesize[2], width / 2);
                        //memcpy(snode->chromaR + a, v_frame->data[2] + i * v_frame->linesize[2], width / 2);
                    }

                    snode->luma_length = width*height;
                    snode->chromaB_length = (width*height)/4;
                    snode->chromaR_length = (width*height)/4;

                    snode->pts = read_packet->pts;
                    snode->width = width;
                    snode->height = height;

                    printf("decode video ok:%d,%d\n%d,%d,%d\n",width,height,snode->luma_length,snode->chromaB_length,snode->chromaR_length);

                    printf("set data ok\n");
                    printf("===>%d\n",snode->pts);
                    //exit(0);
                } // if got_pic
            }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 喜欢独自行走在夜色中陌生的城市,感受无声的等待,沐浴着幻想,聆听远方丝丝温柔的音乐,青灰色夜的精灵或许正飞舞跳动在...
    沁阳老刀阅读 234评论 0 2
  • 现在正是求职面试大热之时,今天我们就来谈一谈工作面试时的套路。 在正式开始面试之前最重要的是简历。简历之所以称之为...
    职场青年阅读 231评论 1 0
  • 大概是两年前,发现了微信还有公众号功能。 一个公众号就是一本杂志,人人都可以申请公众号,相当于人人都能办杂志。 学...
    dexter2017阅读 357评论 0 2
  • 读书的境界与《射雕英雄传》 金庸先生的作品,皆是武林上乘之作,虽然我读过的的不多,但是拜服其《射雕英雄传》、《神雕...
    天行践阅读 321评论 0 0