OpenGL错误只在未经调试的情况下运行时出现,怎么可能呢



我在编写一个小型OpenGL应用程序时遇到了一个奇怪的错误。当我在Visual Studio中使用F5(带调试)运行应用程序时,它运行得很好。如果我用Ctrl+F5(不带调试)运行它,它将以0 FPS的速度运行。在这两种情况下,我都使用VisualStudio中的"Release"版本。

这怎么可能两种运行程序的方式有什么不同吗?应该用什么来修改程序的运行这是一个疯狂的错误,不知怎么连接到AntTweakBar并绘制了大量对象+nVidia OpenGL驱动程序。

以下是该程序的源代码(非常小):

#include "cinder/app/AppBasic.h"
#include "cinder/gl/gl.h"
#include "cinder/params/Params.h"
#include "cinder/Rand.h"
#include "cinder/Camera.h"
using namespace ci;
using namespace ci::app;
using namespace std;
class params_slowApp : public AppBasic
{
    public:
        void setup();
        void update();
        void draw();
        void prepareSettings( Settings *settings );
        CameraPersp mCam;
        params::InterfaceGl mParams;
};
void params_slowApp::prepareSettings( Settings *settings )
{
    settings->setWindowSize( 1280, 720 );
    settings->setFrameRate( 300 );
}
void params_slowApp::setup()
{
    gl::enableVerticalSync( false );
    gl::enableAlphaBlending();
    mCam.setPerspective( 45.0f, getWindowAspectRatio(), 5.0f, 300000.0f );
    mCam.lookAt( Vec3f::zero(), -Vec3f::zAxis(), Vec3f::yAxis() );
    mParams = params::InterfaceGl( "controls", Vec2i( 200, 300 ) );
    mParams.addText( "text" );
}
void params_slowApp::update()
{
}
void params_slowApp::draw()
{
    gl::clear( Color( 0, 0, 0 ), true );
    gl::pushMatrices();
    gl::setMatrices( mCam );
    gl::enableDepthRead();
    gl::enableDepthWrite();
    for( int i = 0; i < 10000; i++ )
    {
        glColor4f( randFloat(), 0.2, 0.3, 0.4 );
        {
            gl::pushModelView();
            gl::translate( randFloat(-100,100), randFloat(-100,100), randFloat(-10,-100) );
            gl::drawCube( Vec3f::zero(), Vec3f::one() );
            gl::popModelView();
        }
    }
    gl::disableDepthWrite();
    gl::disableDepthRead();
    gl::popMatrices();
    params::InterfaceGl::draw();
}
CINDER_APP_BASIC( params_slowApp, RendererGl )

我使用的是Cinder框架,如果我执行以下任何操作,程序将全速运行(100 FPS),而不是0 FPS:

  • 从AntTweakBar mParams.addText( "text" );中删除.addText
  • 删除AntTweakBar绘制例程params::InterfaceGl::draw();
  • 删除颜色更改glColor4f( randFloat(), 0.2, 0.3, 0.4 );
  • 去除内部推挽矩阵和平移
  • 在Intel GPU而不是nVidia GPU上运行

我正试图解决这个问题,但这个错误对我来说很奇怪。你能给我推荐一种诊断方法吗?我无法控制AntTweakBar,它非常复杂,所以我不知道是什么原因导致它触发了这个bug。只有当我在AntTweakBar面板上绘制了一些东西时,才会发生这种情况。我已经在Cinder的论坛上报道过了,但我相信它与Cinder无关。有没有任何工具可以诊断OpenGL驱动程序为什么决定采用0 FPS?

确保在执行任何OpenGL操作之前调用ShowWindow

相关内容

最新更新