召唤蕾姆

qt5.9.1 QOpenGLWidget绘图崩溃到nvoglv64.dll:drvpresentBuffer();



  • 程序中OpenGLWidget继承QOpenGLWidget和QOpenGLFunctions,同时打开多个OpenGLWidget播放视频(视频解码通过ffmpeg完成,解码出来的YUV数据存储在AVFrame结构体中。)
    绘图类代码如下:
    #define ATTRIB_VERTEX 3
    #define ATTRIB_TEXTURE 4

    #include "openglwidget.h"
    #include <QOpenGLShaderProgram>
    #include <QOpenGLShader>
    #include <QOpenGLTexture>

    const char *vsrc =
    "#version 410\n"
    "in vec4 vertexIn;\n"
    "in vec2 textureIn;\n"
    "out vec2 textureOut;\n"
    "void main(void)\n"
    "{\n"
    " gl_Position = vertexIn;\n"
    " textureOut = textureIn;\n"
    "}";

    const char *fsrc =
    "#version 410\n"
    "in vec2 textureOut;\n"
    "out vec4 fragColor;\n"
    "uniform sampler2D tex_y;\n"
    "uniform sampler2D tex_u;\n"
    "uniform sampler2D tex_v;\n"
    "void main(void)\n"
    "{\n"
    " vec3 yuv;\n"
    " vec3 rgb;\n"
    " yuv.x = texture(tex_y, textureOut).r;\n"
    " yuv.y = texture(tex_u, textureOut).r - 0.5;\n"
    " yuv.z = texture(tex_v, textureOut).r - 0.5;\n"
    " rgb = mat3( 1, 1, 1,\n"
    " 0, -0.21482, 2.12798,\n"
    " 1.28033, -0.38059, 0) * yuv;\n"
    " fragColor = vec4(rgb, 1);\n"
    "}";

    OpenGLWidget::OpenGLWidget(QWidget *parent)
    {
    setParent(parent);
    y_texture = false;
    u_texture = false;
    v_texture = false;
    paint = false;
    width = 0;
    height = 0;
    this->setMouseTracking(true);
    setUpdateBehavior(QOpenGLWidget::PartialUpdate);
    }

    void OpenGLWidget::clearWidget()
    {
    makeCurrent();
    glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
    }

    void OpenGLWidget::initializeGL()
    {
    initializeOpenGLFunctions();
    m_shader = prepareShaderProgram();

    textureUniformY = glGetUniformLocation(m_shader, "tex_y");
    textureUniformU = glGetUniformLocation(m_shader, "tex_u");
    textureUniformV = glGetUniformLocation(m_shader, "tex_v");
    
    
    // Create a interleaved triangle (vec3 position, vec3 color)
    float vertexPoints[] ={
        -1.0f, -1.0f,0.0f, 1.0f,
        1.0f, -1.0f,1.0f, 1.0f,
        -1.0f, 1.0f,0.0f, 0.0f,
        1.0f, 1.0f,1.0f, 0.0f,
    };
    
    glGenVertexArrays(1, &m_vertexBuffer);
    glBindVertexArray(m_vertexBuffer);
    
    glGenBuffers(1, &vertexBuffer);
    glBindBuffer(GL_ARRAY_BUFFER, vertexBuffer);
    glBufferData(GL_ARRAY_BUFFER, 4 * 4 * sizeof(float), vertexPoints, GL_STATIC_DRAW);
    vertextAttribute = glGetAttribLocation(m_shader, "vertexIn");
    textureAttribute = glGetAttribLocation(m_shader, "textureIn");
    glEnableVertexAttribArray(vertextAttribute);
    glVertexAttribPointer(vertextAttribute, 2, GL_FLOAT, GL_FALSE, sizeof(float)*4, (const GLvoid *)0);
    glEnableVertexAttribArray(textureAttribute);
    glVertexAttribPointer(textureAttribute, 2, GL_FLOAT, GL_FALSE, sizeof(float)*4, (const GLvoid *)(sizeof(float)*2));
    
    
    //Init Texture
    glGenTextures(1, &id_y);
    glBindTexture(GL_TEXTURE_2D, id_y);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
    
    glGenTextures(1, &id_u);
    glBindTexture(GL_TEXTURE_2D, id_u);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
    
    glGenTextures(1, &id_v);
    glBindTexture(GL_TEXTURE_2D, id_v);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
    

    }

    GLuint OpenGLWidget::prepareShaderProgram()
    {
    GLuint program = glCreateProgram();

    //vertex shader
    GLuint vertexShader = glCreateShader( GL_VERTEX_SHADER);
    glShaderSource( vertexShader, 1, (const GLchar**)&vsrc, NULL );
    glCompileShader( vertexShader );
    GLint  compiled;
    glGetShaderiv( vertexShader, GL_COMPILE_STATUS, &compiled );
    glAttachShader( program, vertexShader );
    
    //fragment shader
    GLuint fragmentShader = glCreateShader( GL_FRAGMENT_SHADER);
    glShaderSource( fragmentShader, 1, (const GLchar**)&fsrc, NULL );
    glCompileShader( fragmentShader );
    glGetShaderiv( fragmentShader, GL_COMPILE_STATUS, &compiled );
    glAttachShader( program, fragmentShader );
    
    /* Link output */
    glBindFragDataLocation(program, 0, "fragColor");
    /* link  and error check */
    glLinkProgram(program);
    
    GLint  linked;
    glGetProgramiv( program, GL_LINK_STATUS, &linked );
    if ( !linked ) {
        qWarning() << "Shader program failed to link";
    }
    glUseProgram(program);
    return program;
    

    }

    bool OpenGLWidget::getPaint() const
    {
    return paint;
    }

    void OpenGLWidget::setPaint(bool value)
    {
    paint = value;
    }

    void OpenGLWidget::paintGL()
    {
    glClearColor(0.0, 0.0, 0.0, 1.0);
    glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );

    if(paint)
    {
            glActiveTexture(GL_TEXTURE0);
            glBindTexture(GL_TEXTURE_2D, id_y);
            glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, this->width, this->height, 0, GL_RED, GL_UNSIGNED_BYTE, frame.data[0]);
            glUniform1i(textureUniformY, 0);
    
            glActiveTexture(GL_TEXTURE1);
            glBindTexture(GL_TEXTURE_2D, id_u);
            glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, this->width/2, this->height/2, 0, GL_RED, GL_UNSIGNED_BYTE, frame.data[1]);
            glUniform1i(textureUniformU, 1);
    
    
    
            glActiveTexture(GL_TEXTURE2);
            glBindTexture(GL_TEXTURE_2D, id_v);
            glTexImage2D(GL_TEXTURE_2D, 0, GL_RED, this->width/2, this->height/2, 0, GL_RED, GL_UNSIGNED_BYTE, frame.data[2]);
            glUniform1i(textureUniformV, 2);
    
        // Draw stuff
        glDrawArrays( GL_TRIANGLE_STRIP, 0, 4 );
    }
    

    }

    void OpenGLWidget::resizeGL(int w, int h)
    {
    show_width = w;
    show_height = qMax(h,1);
    glViewport(0,0,show_width,show_height);
    }



  • 0_1508382122722_QQ图片20171019110154.png



  • 翻x之后查资料,有2种说法,一种是让关闭nv的线程优化选项(一看就不靠谱),另一种说是显存泄露(??)。线程优化就不用说了,关了之后仍然会崩溃。特来此求教。。。



  • 想问一下,会不会是因为多个窗口同时绘图、访问显存出现了问题?



  • 而且不崩溃的时候创建多个openglwidget窗口时,新窗口的创建会导致老窗口闪烁一下(有时图像绘制出现颜色变化),不解,求大家指导。



  • 蹦到绘图里的问题找到了。是因为frame结构体的多线程读写导致的。但是现在又开始崩溃到mf.dll is required for hardware video decoding。。。无语,翻资料去了。


  • 网站研运

    @flowerlove 多线程来进行渲染?我看到成功的似乎只有Qt的Scene Graph渲染框架,而且这个也分情况,在某些平台下多线程渲染仍然是不足的。


 

最近的回复

  • 0_1524629331614_好棒的.jpg
    各位好哦,最近我又开始进行我们论坛的再次研发了。这一次呢,我们为我们的社区添加了一个重大的功能,那就是Live2D哦。借助Live2D在Web端的技术,我们成功地把看板娘蕾姆请到我们论坛了呢。
    0_1524634368387_d2c83fb3-71fc-414e-ab02-334a1d6c6007-image.png
    不要小看她,她可以陪你们说话、也可以一个人自言自语,有时候还会爆发出中二的词汇呢;
    更多的情况下,蕾姆很温柔,早上她能向你说声早上好,中午她能向你提出建议不要太累太辛苦了,晚上也能提醒你不要熬夜。自从有了蕾姆后,我们的精神也爽了,心情也好了,自己也变得萌萌哒了。

    好了,技术方面呢,还是要感谢 @维基萌 的二次作品,虽然最初Live2D是由这家公司制作的,但是有庞大的社区力量,推动了这款产品的普及,于是乎我们也可以拿Live2D来用了呢。
    此外,得益于最近兴起的聊天机器人,我们也成功地将聊天机器人的功能整合到我们的论坛里了,目前聊天机器人很棒,感觉就像真的蕾姆一样呢。

    归纳总结,我们使用到了以下的内容:

    NodeBB框架
    Live2D
    Turing123

    萌梦社区以后会给大家带来更多更好的内容!

    阅读更多
  • 亮点就是对比的地方比较清晰。我希望另外一个beyond compare软件出现。

    阅读更多
  • 在deepin上,如何使用git托管代码,这里推荐一个工具 SmartGit

    在深度商店搜索[SmartGit],安装

    0_1524572222379_深度截图_deepin-appstore_20180424191503.png

    第一次打开,需要配置,这里输入自己的git用户名和邮箱,我使用的是码云

    0_1524572276100_深度截图_选择区域_20180424191602.png

    创建本地仓库

    菜单[Respository]-[Clone]

    0_1524572487937_深度截图_选择区域_20180424202102.png

    输入git仓库地址,下一步,下一步,

    0_1524572568462_深度截图_选择区域_20180424202236.png

    选择本地地址,Finish,这样我们的代码就从git下载到本地了

    0_1524572342889_深度截图_选择区域_20180424201348.png

    上传

    我创建了一个测试文本

    0_1524572727847_深度截图_选择区域_20180424202521.png

    右键这个文件,选择Commit

    0_1524572789341_深度截图_选择区域_20180424202623.png

    点击Commit后

    0_1524572829048_深度截图_选择区域_20180424202644.png

    右键这一条,选择Push Commit,如果提示输入账户就填码云的账号

    登录网站,检查,成功了

    0_1524573043120_深度截图_选择区域_20180424203030.png

    新建一个文档,这次提交时候选择Commit & Push,可以直接提交到网站

    阅读更多
  • 告诉你一个方法,Slider位于MouseArea的上层,然后除了Slider的hover和press事件,其余的事件都走MouseArea。怎么做到?可以在事件中设置MouseArea的visible属性。
    还有一种做法就是Slider自定义背景background,里面包含了MouseArea。

    阅读更多

关注我们

微博
QQ群











与 萌梦社区 的连接断开,我们正在尝试重连,请耐心等待