簡體   English   中英

Qt App在GLWidget.show()上導致分段錯誤

[英]Qt App causes Segmentation Fault upon GLWidget.show();

當我逐步調試器時,會出現以下彈出消息:

The inferior stopped because it received a signal from the Operating System.

Signal name : 
SIGSEGV
Signal meaning : 
Segmentation fault

(我認為)這取決於這些代碼行:

#ifndef Q_WS_WINCE
    inline void show() { setVisible(true); }
#else
    void show();
#endif
    inline void hide() { setVisible(false); }
    inline QT_MOC_COMPAT void setShown(bool shown) { setVisible(shown); }

據我所知,雖然我無法通過Google找到其背后的定義,但尚未定義Q_WS_WINCE 盡管缺少CE定義, 但這是我能找到的最接近的。

根據我的調試器的說法,這就是所謂的,如箭頭#ifndef Q_WS_WINCE所示,是#ifndef Q_WS_WINCE inline void show() { setVisible(true); }的調用中inline void show() { setVisible(true); } inline void show() { setVisible(true); }函數。

我不知道這怎么可能發生。 這是怎么回事 我正在使用Ubuntu 11.10,並將Qt Creator用作我的IDE。 我還應該指出,這僅僅是在幾分鍾前開始的。 在沒有任何問題之前,我能夠逐步完成大部分代碼。

GLWidget頭文件

#pragma once

#include <QGLWidget>
#include <QInputEvent>
#include "Cube.h"

class GLWidget : public QGLWidget
{
    Q_OBJECT

public:
    explicit GLWidget( QWidget *parent = 0 );

    ~GLWidget( void );

    QSize minimumSizeHint( void ) const;

    QSize sizeHint( void ) const;

public slots:
    void SetXRotation( int angle );

    void SetYRotation( int angle );

    void SetZRotation( int angle );

signals:
    void xRotationChanged( int angle );

    void yRotationChanged( int angle );

    void zRotationChanged( int angle );

protected:
    void initializeGL( void );

    void paintGL( void );

    void resizeGL( int width, int height );

    void mousePressEvent( QMouseEvent *event );

    void mouseMoveEvent( QMouseEvent *event );

private:
    Cube *mCube;

    int mXRot;

    int mYRot;

    int mZRot;

    QPoint mLastPos;

    QColor mQtGreen;

    QColor mQtPurple;

};

GLWidget源文件

#include <GL/freeglut.h>

#include <QtGui>
#include <QtOpenGL>

#include <qmath.h>
#include <QMatrix4x4>

#include "GLWidget.h"

#ifndef GL_MULTISAMPLE
#define GL_MULTISAMPLE 0x809D
#endif

static void qNormalizeAngle( int &angle )
{
    const int ANGLE_MULTIPLIER = 360 * 16;

    while( angle < 0 )
        angle += ANGLE_MULTIPLIER;
    while ( angle > ANGLE_MULTIPLIER )
        angle -= ANGLE_MULTIPLIER;
}

GLWidget::GLWidget( QWidget *parent ) :
    QGLWidget( parent ),
    mXRot( 0 ),
    mYRot( 0 ),
    mZRot( 0 )
{    
}

GLWidget::~GLWidget( void )
{
    delete mCube;
}

void GLWidget::initializeGL( void )
{
    mQtGreen = QColor::fromCmyk( 0.40, 0.0, 1.0, 0.0 );
    mQtPurple = QColor::fromCmyk( 0.39, 0.39, 0.0, 0.0 );

    //glutInitDisplayMode( GLUT_RGBA | GLUT_DEPTH );

    qglClearColor( mQtPurple );

    mCube = new Cube( this );
    mCube->Init();
    mCube->SetColor( mQtGreen.dark() );

    glEnable( GL_DEPTH_TEST );
    glEnable( GL_CULL_FACE );
    glShadeModel( GL_SMOOTH );
    glEnable( GL_LIGHTING );
    glEnable( GL_LIGHT0 );
    glEnable( GL_MULTISAMPLE );
    static GLfloat lightPosition[4] = { 0.5, 5.0, 7.0, 1.0 };
    glLightfv( GL_LIGHT0, GL_POSITION, lightPosition );
}

QSize GLWidget::minimumSizeHint( void ) const
{
    return QSize( 50, 50 );
}

void GLWidget::mouseMoveEvent( QMouseEvent *event )
{
    mLastPos = event->pos();
}

void GLWidget::mousePressEvent( QMouseEvent *event )
{
    static const int ANGLE_ADDIFIER = 8;

    int dx = event->x() - mLastPos.x();
    int dy = event->y() - mLastPos.y();

    if ( event->buttons() & Qt::LeftButton )
    {
        SetXRotation( ( mXRot + ANGLE_ADDIFIER ) * dy );
        SetYRotation( ( mYRot + ANGLE_ADDIFIER ) * dx );

        qDebug() << "You pressed the left mouse button!" << '\n';
    }
    else if ( event->buttons() & Qt::RightButton )
    {
        SetXRotation( ( mXRot + ANGLE_ADDIFIER ) * dy );
        SetZRotation( ( mZRot + ANGLE_ADDIFIER ) * dx );

        qDebug() << "You pressed the right mouse button!" << '\n';
    }

    mLastPos = event->pos();
}

void GLWidget::paintGL( void )
{
    static const GLfloat ANGLE_DIVISOR = 16.0;

    glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );
    glLoadIdentity();
    glTranslatef( 0.0, 0.0, -10.0 );

    glRotatef( mXRot / ANGLE_DIVISOR, 1.0, 0.0, 0.0 );
    glRotatef( mYRot / ANGLE_DIVISOR, 0.0, 1.0, 0.0 );
    glRotatef( mZRot / ANGLE_DIVISOR, 0.0, 0.0, 1.0 );

    mCube->Draw();
}

void GLWidget::resizeGL( int width, int height )
{
    int side = qMin( width, height );

    //glutInitWindowPosition( 0, 0 );
    //glutInitWindowSize( width, height );

    glViewport( ( width - side ) / VIEWPORT_DIVISOR, ( height - side ) / VIEWPORT_DIVISOR, side, side );
    glMatrixMode( GL_PROJECTION );
    glLoadIdentity();

#ifdef QT_OPENGL_ES_1
    glOrthof( -0.5, +0.5, -0.5, +0.5, 4.0, 15.0 );
#else
    glOrtho( -0.5, +0.5, -0.5, +0.5, 4.0, 15.0 );
#endif*/

    glMatrixMode( GL_MODELVIEW );
}

void GLWidget::SetXRotation( int angle )
{
    qNormalizeAngle( angle );

    if ( angle != mYRot )
    {
        mYRot = angle;
        emit yRotationChanged( angle );
        updateGL();
    }
}

void GLWidget::SetYRotation( int angle )
{
    qNormalizeAngle( angle );

    if ( angle != mXRot )
    {
        mXRot = angle;
        emit xRotationChanged( angle );
        updateGL();
    }
}

void GLWidget::SetZRotation( int angle )
{
    qNormalizeAngle( angle );

    if ( angle != mZRot )
    {
        mZRot = angle;
        emit zRotationChanged( angle );
        updateGL();
    }
}

QSize GLWidget::sizeHint() const
{
    return QSize( 400, 400 );
}

找到了罪魁禍首:我有一個mCube->Init(); 函數調用被放置在代碼中的某個地方。 現在應該認為這已解決。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM