青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Cpper
C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
class VideoRenderer : public QObject, public QQuickFramebufferObject::Renderer, public QOpenGLFunctions
{
    Q_OBJECT
public:
    
explicit VideoRenderer(QQuickFramebufferObject* object);
    
~VideoRenderer();

    QOpenGLFramebufferObject
* createFramebufferObject(const QSize& size);
    
void render();
public slots:
    
void updateVideoFrame(AVFrame* frame);
    
void paint();
private:
    std::mutex mux;
    QGLShaderProgram program;
    GLuint yuv[
3= { 0 };
    GLuint textures[
3= { 0 };
    unsigned 
char* datas[3= { 0 };
    QSize videoSize;
    QQuickFramebufferObject
* fbo;
};

VideoRenderer::VideoRenderer(QQuickFramebufferObject
* object):
QObject(
object)
{
    fbo 
= object;
    initializeOpenGLFunctions();

    qDebug() 
<< program.addShaderFromSourceCode(QGLShader::Fragment, tString);
    qDebug() 
<< program.addShaderFromSourceCode(QGLShader::Vertex, vString);

    program.bindAttributeLocation(
"vertexIn", A_VER);
    program.bindAttributeLocation(
"textureIn", T_VER);
    
    qDebug() 
<< "program.link() = " << program.link();
    qDebug() 
<< "program.bind() = " << program.bind();

    
static const GLfloat ver[] = {
        
-1.0f,-1.0f,
        
1.0f,-1.0f,
        
-1.0f1.0f,
        
1.0f,1.0f
    };

    
static const GLfloat tex[] = {
        
0.0f1.0f,
        
1.0f1.0f,
        
0.0f0.0f,
        
1.0f0.0f
    };

    glVertexAttribPointer(A_VER, 
2, GL_FLOAT, 00, ver);
    glEnableVertexAttribArray(A_VER);

    glVertexAttribPointer(T_VER, 
2, GL_FLOAT, 00, tex);
    glEnableVertexAttribArray(T_VER);

    yuv[
0= program.uniformLocation("tex_y");
    yuv[
1= program.uniformLocation("tex_u");
    yuv[
2= program.uniformLocation("tex_v");

    mux.unlock();

    glGenTextures(
3, textures);
}

VideoRenderer::
~VideoRenderer()
{
    
if(datas[0])
    {
        
for(int i = 0; i < 3; i++)
            delete datas[i];
    }
}

void SaveAvFrame(const QString& file,AVFrame* avFrame)
{
    FILE 
*fDump = fopen(file.toLocal8Bit().data(), "ab");

    uint32_t pitchY 
= avFrame->linesize[0];
    uint32_t pitchU 
= avFrame->linesize[1];
    uint32_t pitchV 
= avFrame->linesize[2];

    uint8_t 
*avY = avFrame->data[0];
    uint8_t 
*avU = avFrame->data[1];
    uint8_t 
*avV = avFrame->data[2];

    
for (uint32_t i = 0; i < avFrame->height; i++) {
        fwrite(avY, avFrame
->width, 1, fDump);
        avY 
+= pitchY;
    }

    
for (uint32_t i = 0; i < avFrame->height / 2; i++) {
        fwrite(avU, avFrame
->width / 21, fDump);
        avU 
+= pitchU;
    }

    
for (uint32_t i = 0; i < avFrame->height / 2; i++) {
        fwrite(avV, avFrame
->width / 21, fDump);
        avV 
+= pitchV;
    }

    fclose(fDump);
}

void VideoRenderer::updateVideoFrame(AVFrame* frame)
{
    
if(!frame)
        
return;

    mux.
lock();

    
if (frame->width != videoSize.width() || frame->height != videoSize.height())
    {
        videoSize.setWidth(frame
->width);
        videoSize.setHeight(frame
->height);
        
if (datas[0])
        {
            
for (int i = 0; i < 3; i++)
            {
                delete datas[i];
                datas[i] 
= 0;
            }
        }

        datas[
0= new unsigned char[frame->width*frame->height];        //Y
        datas[1= new unsigned char[frame->width*frame->height / 4];    //U
        datas[2= new unsigned char[frame->width*frame->height / 4];    //V
    }

    
if (!datas[0])
    {
        datas[
0= new unsigned char[frame->width*frame->height];        //Y
        datas[1= new unsigned char[frame->width*frame->height / 4];    //U
        datas[2= new unsigned char[frame->width*frame->height / 4];    //V
    }

    
if (videoSize.width() == frame->linesize[0])
    {
        memcpy(datas[
0], frame->data[0], videoSize.width()*videoSize.height());
        memcpy(datas[
1], frame->data[1], videoSize.width()*videoSize.height() / 4);
        memcpy(datas[
2], frame->data[2], videoSize.width()*videoSize.height() / 4);
    }
    
else
    {
        
for (int i = 0; i < videoSize.height(); i++//
            memcpy(datas[0+ videoSize.width()*i, frame->data[0+ frame->linesize[0* i, videoSize.width());
        
for (int i = 0; i < videoSize.height() / 2; i++//U
            memcpy(datas[1+ videoSize.width() / 2 * i, frame->data[1+ frame->linesize[1* i, videoSize.width());
        
for (int i = 0; i < videoSize.height() / 2; i++//V
            memcpy(datas[2+ videoSize.width() / 2 * i, frame->data[2+ frame->linesize[2* i, videoSize.width());
    }


    mux.unlock();
    av_frame_free(
&frame);

    update();
}

void VideoRenderer::render()
{
    paint();
}

void VideoRenderer::paint()
{
    
if (videoSize.isEmpty())
        
return;

    mux.
lock();

    
//Y
    glBindTexture(GL_TEXTURE_2D, textures[0]);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
    glTexImage2D(GL_TEXTURE_2D, 
0, GL_RED, videoSize.width(), videoSize.height(), 0, GL_RED, GL_UNSIGNED_BYTE, 0);

    
//U
    glBindTexture(GL_TEXTURE_2D, textures[1]);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
    glTexImage2D(GL_TEXTURE_2D, 
0, GL_RED, videoSize.width() / 2, videoSize.height() / 20, GL_RED, GL_UNSIGNED_BYTE, 0);

    
//V
    glBindTexture(GL_TEXTURE_2D, textures[2]);

    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);

    glTexImage2D(GL_TEXTURE_2D, 
0, GL_RED, videoSize.width() / 2, videoSize.height() / 20, GL_RED, GL_UNSIGNED_BYTE, 0);
 

    glActiveTexture(GL_TEXTURE0);
    glBindTexture(GL_TEXTURE_2D, textures[
0]); // to y

    glTexSubImage2D(GL_TEXTURE_2D, 
000, videoSize.width(), videoSize.height(), GL_RED, GL_UNSIGNED_BYTE, datas[0]);
    glUniform1i(yuv[
0], 0);

    glActiveTexture(GL_TEXTURE0 
+ 1);
    glBindTexture(GL_TEXTURE_2D, textures[
1]); // 1 to u
    glTexSubImage2D(GL_TEXTURE_2D, 000, videoSize.width() / 2, videoSize.height() / 2, GL_RED, GL_UNSIGNED_BYTE, datas[1]);
    glUniform1i(yuv[
1], 1);


    glActiveTexture(GL_TEXTURE0 
+ 2);
    glBindTexture(GL_TEXTURE_2D, textures[
2]); // 2 to v
    glTexSubImage2D(GL_TEXTURE_2D, 000, videoSize.width() / 2, videoSize.height() / 2, GL_RED, GL_UNSIGNED_BYTE, datas[2]);

    glUniform1i(yuv[
2], 2);

    glDrawArrays(GL_TRIANGLE_STRIP, 
04);
    mux.unlock();

}
 
QOpenGLFramebufferObject
* VideoRenderer::createFramebufferObject(const QSize &size)
{
    QOpenGLFramebufferObjectFormat format;   
//當大小發(fā)生變化時,會調用此函數生成對應大小的FBO
    format.setAttachment(QOpenGLFramebufferObject::CombinedDepthStencil);
    format.setSamples(
4);
    
return new QOpenGLFramebufferObject(size,format);
}
posted on 2019-08-12 09:25 ccsdu2009 閱讀(479) 評論(0)  編輯 收藏 引用 所屬分類: QT編程
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费在线观看成人av| 99精品福利视频| 国产日韩欧美视频| 亚洲国产精品久久91精品| 欧美一级网站| 亚洲国产精品高清久久久| 日韩视频在线免费观看| 麻豆精品视频在线观看| 国产精品日韩| 亚洲精品乱码久久久久久| 麻豆成人在线播放| 亚洲欧美日韩精品久久亚洲区| 亚洲精品一区二区三区福利| 午夜欧美不卡精品aaaaa| 欧美激情bt| 女仆av观看一区| 亚洲高清视频中文字幕| 久久国产精品网站| 久久riav二区三区| 国产精品视频免费观看| 午夜宅男欧美| 亚洲素人一区二区| 伊大人香蕉综合8在线视| 亚洲国产欧美久久| 欧美亚洲综合久久| 欧美午夜精品电影| 亚洲一级黄色片| 亚洲三级视频在线观看| 久久婷婷国产综合精品青草| 在线看无码的免费网站| 久久久亚洲一区| 亚洲韩国日本中文字幕| 国产精品久久久久aaaa九色| 91久久精品一区二区别| 亚洲电影免费在线 | 欧美日韩中文在线| 亚洲每日在线| 欧美激情精品久久久久久变态| 欧美在线影院| 亚洲精品视频二区| 亚洲精品视频免费观看| 欧美人与禽猛交乱配视频| 亚洲专区欧美专区| 亚洲影院污污.| 欧美另类在线观看| 欧美在线日韩在线| 久久久久久一区二区三区| 亚洲精品国产系列| 99一区二区| 国产精品午夜视频| 亚洲高清视频在线观看| 欧美欧美天天天天操| 1024国产精品| 亚洲婷婷综合久久一本伊一区| 国产精品无人区| 欧美激情第1页| 欧美日韩综合视频网址| 亚洲欧美在线另类| 免费欧美日韩| 亚洲一区二区三区四区在线观看| 亚洲国产精品热久久| 91久久精品国产91性色tv| 欧美色图天堂网| 久久亚洲欧洲| 欧美日韩精品在线视频| 欧美一区二区三区男人的天堂| 久久亚洲高清| 久久中文久久字幕| 亚洲福利视频三区| 欧美激情影音先锋| 蜜臀久久99精品久久久画质超高清| 国产精品资源在线观看| 美日韩精品视频免费看| 国产精品久久久久久久9999| 亚洲欧美亚洲| 久久国产精彩视频| 亚洲电影自拍| 欧美黄色影院| 亚洲高清视频在线| 中文国产成人精品久久一| 亚洲精品在线视频观看| 亚洲视频中文| 最新热久久免费视频| 亚洲乱码国产乱码精品精天堂| 亚洲视频www| 国产精品扒开腿爽爽爽视频 | 国产深夜精品福利| 亚洲福利久久| 欧美在线亚洲| 欧美在线观看网址综合| 欧美日韩高清区| 国产精品国产亚洲精品看不卡15| 欧美一区二区啪啪| 99国内精品| 欧美jjzz| 激情小说另类小说亚洲欧美| 亚洲欧美一区二区原创| 久久婷婷国产麻豆91天堂| 国产精品久久久久一区二区三区| 亚洲精品女av网站| 亚洲欧美视频在线观看视频| 国产精品久久久久久福利一牛影视| 欧美先锋影音| 欧美高清一区二区| 久久在线91| 国产精品一区二区久激情瑜伽| 欧美成人精品一区二区| 久久成人免费日本黄色| 麻豆成人精品| 久久激情视频| 久久精品国产96久久久香蕉| 亚洲精品欧美日韩| 亚洲国产精品久久久久秋霞影院 | 一区二区三区日韩| 欧美国产精品一区| 久久综合狠狠| 国产欧美日韩一区| 亚洲精品中文字幕在线| 欧美日韩高清免费| 亚洲在线视频网站| 亚洲一区二区三区在线播放| 国产精品男女猛烈高潮激情| 国产午夜精品一区二区三区欧美 | 美国十次成人| 在线观看欧美激情| 亚洲国产精品高清久久久| 欧美成人精品| 精品二区久久| 99xxxx成人网| 免费亚洲一区二区| 亚洲精品影院| 国产精品日韩在线播放| 尤妮丝一区二区裸体视频| 欧美高清hd18日本| 国产精品超碰97尤物18| 欧美在线网站| 欧美国产乱视频| 亚洲一本视频| 一区二区三区免费看| 美女视频一区免费观看| 国产精品久久久久久久午夜| 亚洲一区二区三区三| 欧美国产欧美亚洲国产日韩mv天天看完整| 一本一本久久| 国产精品日韩欧美一区二区三区| 一本色道久久精品| 亚洲在线观看视频网站| 国产欧美精品一区aⅴ影院| 午夜精品久久久久久久蜜桃app| 羞羞色国产精品| 国产一区二区三区久久悠悠色av | 亚洲欧美在线磁力| 欧美亚洲视频在线观看| 国产视频在线观看一区二区三区| 性亚洲最疯狂xxxx高清| 欧美一区视频在线| 好男人免费精品视频| 久久久久久久精| 91久久久精品| 亚洲欧美日韩精品久久久| 国产欧美一区二区三区沐欲| 久久久久久国产精品mv| 亚洲精品1区| 亚洲女优在线| 黑人一区二区三区四区五区| 夜夜嗨av一区二区三区网页| 一区二区动漫| 在线一区亚洲| 国产无遮挡一区二区三区毛片日本| 亚洲一区二区精品在线观看| 欧美在线观看一区二区三区| 国产欧美日韩在线视频| 久久精品国产一区二区三| 亚洲国产高清在线| 欧美亚洲一区在线| 亚洲成色www久久网站| 欧美日韩国产va另类| 亚洲综合日韩在线| 亚洲国产精品一区二区三区| 欧美一区二区精品| 亚洲精品一区二区在线| 国产精品美女主播| 欧美大片在线观看一区二区| 欧美亚洲在线播放| 亚洲最新视频在线| 欧美激情视频给我| 欧美精品成人91久久久久久久| 亚洲少妇自拍| 亚洲国产综合在线看不卡| 欧美一区二区三区在线看| 亚洲精品影视| 亚洲国产精品t66y| 国产一级久久| 国产精品一区二区久久精品| 欧美精品在线播放| 麻豆成人综合网| 欧美在线影院在线视频| 亚洲美女黄色片| 亚洲国产精品精华液网站| 毛片一区二区|