简体   繁体   English

Qt:QGLShaderProgram关闭日志消息

[英]Qt: QGLShaderProgram turn off log messages

Is there a way to turn of log messages when calling QGLShaderProgram::link()? 调用QGLShaderProgram :: link()时,是否可以打开日志消息? http://qt-project.org/doc/qt-4.8/qglshaderprogram.html#link http://qt-project.org/doc/qt-4.8/qglshaderprogram.html#link

Messages look like: 消息看起来像:

QGLShader::link: "Vertex shader(s) linked, fragment shader(s) linked.
"

Qt code looks like this: src/opengl/qglshaderprogram.cpp:893 Qt代码如下所示:src / opengl / qglshaderprogram.cpp:893

    glLinkProgram(program);
    value = 0;
    glGetProgramiv(program, GL_LINK_STATUS, &value);
    d->linked = (value != 0);
    value = 0;
    glGetProgramiv(program, GL_INFO_LOG_LENGTH, &value);
    d->log = QString();
    if (value > 1) {
        char *logbuf = new char [value];
        GLint len;
        glGetProgramInfoLog(program, value, &len, logbuf);
        d->log = QString::fromLatin1(logbuf);
        QString name = objectName();
        if (name.isEmpty())
            qWarning() << "QGLShader::link:" << d->log;
        else
            qWarning() << "QGLShader::link[" << name << "]:" << d->log;
        delete [] logbuf;
    }
    return d->linked;
}

So it seems the only possible solution is to redirect qWarning() as done in: How to redirect qDebug, qWarning, qCritical etc output? 因此,似乎唯一可行的解​​决方案是按照以下方法进行重定向qWarning(): 如何重定向qDebug,qWarning,qCritical等输出?

 qInstallMsgHandler([](QtMsgType , const char* ) { });  // empty message handler
 bool result = program.link();
 qInstallMsgHandler(0);  // restore default message handling

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM