簡體   English   中英

如何更改 QT 中信號和槽的時序?

[英]How can I change the timing for signals and slot in QT?

我正在創建一個管理學生信息的程序。 目前我有一個 tableview 和一個添加按鈕,當我點擊添加按鈕時,會彈出一個新對話框,提示用戶添加一個新學生。 我的意圖是我創建一個信號和槽連接到我的對話框,這樣每當按下 ok 按鈕時,我的 tableview 就會刷新(我正在使用 SQLITE)。 但是,現在的問題是,在我看來,在我調用刷新窗口 function 后數據庫正在更新,所以當我調用刷新窗口 function 時,數據庫尚未更新。 我不確定這是否是問題所在,但這就是我的想法。

下面是一些代碼: 當我點擊添加按鈕時

void viewStudents::on_addStudent_clicked()
{
    studentWindow = new studentManagement(username,this);
    QObject::connect(studentWindow,SIGNAL(accepted()),this, SLOT(refreshwindow()));
    studentWindow->show();
}

我的刷新窗口 function

void viewStudents::refreshwindow()
{
    QSqlQueryModel *modal = new QSqlQueryModel();
    QSqlDatabase tempdb = QSqlDatabase::addDatabase("QSQLITE");
    tempdb.setDatabaseName("accounts.db");
    if(tempdb.open()){
        QSqlQuery tempquery;
        tempquery.exec("SELECT firstname, lastname, DOB, Day_of_lessons, Start_date, Price_per_lesson, Length_of_lessons from studentList WHERE teacher = '"+username+"';");
        modal->setQuery(tempquery);
        ui->tableView->setModel(modal);
        ui->tableView->resizeColumnsToContents();
        ui->tableView->resizeRowsToContents();
        tempdb.close();
    }
    else{
        QMessageBox::warning(this,"Error","Something unexpected has happened.");
    }
}

我的添加學生對話框

studentManagement::studentManagement(QString username, QWidget *parent) :
    QDialog(parent),
    ui(new Ui::studentManagement)
{
    this->username = username;
    ui->setupUi(this);
    QFont information_font = ui->informationLabel->font();
    information_font.setPointSize(14);
    information_font.setBold(true);
    ui->informationLabel->setFont(information_font);
    ui->startdate->setMinimumDate(QDate::currentDate());
    ui->dayOfLessonsBox->addItem("Monday");
    ui->dayOfLessonsBox->addItem("Tuesday");
    ui->dayOfLessonsBox->addItem("Wednesday");
    ui->dayOfLessonsBox->addItem("Thursday");
    ui->dayOfLessonsBox->addItem("Friday");
    ui->dayOfLessonsBox->addItem("Saturday");
    ui->dayOfLessonsBox->addItem("Sunday");
}

studentManagement::~studentManagement()
{
    delete ui;
}

void studentManagement::on_buttonBox_accepted()
{
    QString firstname = ui->firstname->text();
    QString lastname = ui->lastname->text();
    QString DOB = ui->dateofbirth->text();
    QString dayOfLessons = ui->dayOfLessonsBox->currentText();
    QString startdate = ui->startdate->text();
    QString pricing = ui->pricing->text();
    QString lengthoflessons = ui->lengthoflessons->text();
    QSqlDatabase mydb = QSqlDatabase::addDatabase("QSQLITE");
    mydb.setDatabaseName("accounts.db");
    if(!mydb.open())QMessageBox::warning(this,"File Not Found Error", "The database file cannot be find.");
    else{
        QSqlQuery query;
        if(query.exec("INSERT INTO studentList VALUES('"+firstname+"', '"+lastname+"', '"+DOB+"', '"+dayOfLessons+"', '"+startdate+"', '"+pricing+"', '"+lengthoflessons+"', '"+username+"');")){
            mydb.close();
        }
    }
}

如果有人能幫我一點忙,或者給我一些關於去哪里看的建議,我將不勝感激!

首先,您應該在構造函數中使用您的connect語句,或者每次on_addStudent_clicked()時都會執行一個新的連接,這不會形成錯誤,但完全沒有必要。

其次,當我們向列表中添加一條記錄時,我們希望確保立即刷新列表,因此它需要緊跟在insert語句之后。

第三,Qt 非常智能,可以找到您要創建的隱式連接,如果您使用一般形式的on_something_someevent()創建 function,那么它將自動查找名為something的對象/類( QObject類型)並連接它的信號是thissomeevent on_something_someevent()作為插槽的事件。 結果,像thisobject::on_something_someevent(){}這樣寫 function 將自動呈現為:

 QObject::connect(something, SIGNAL(someevent()), this, SLOT(on_something_someevent()));

這非常方便,但它可能會嘗試創建不需要的connect或至少引發警告或錯誤。

最后,不要忘記在您的 header 文件中使用public slot:定義您的插槽。 公共部分是必要的,否則您會收到訪問沖突錯誤,因為 Qt 框架無法調用您的插槽 function(來自另一個對象)。

這是您的代碼的更正形式,我認為它可以完成這項工作(我沒有您的 .ui 或 .h 文件,既沒有您的兩個類的完整源代碼,也沒有您的main() function,所以請將其視為我希望傳達要點的部分來源)

void viewStudents::refreshwindow()
{
    QSqlQueryModel modal = QSqlQueryModel::QSqlQueryModel();
    QSqlDatabase tempdb = QSqlDatabase::addDatabase("QSQLITE");
    tempdb.setDatabaseName("accounts.db");
    if (tempdb.open()) {
        QSqlQuery tempquery;
        tempquery.exec("SELECT firstname, lastname, DOB, Day_of_lessons, Start_date, Price_per_lesson, Length_of_lessons from studentList WHERE teacher = '" + username + "';");
        modal->setQuery(tempquery);
        ui->tableView->setModel(modal);
        ui->tableView->resizeColumnsToContents();
        ui->tableView->resizeRowsToContents();
        tempdb.close();
    }
    else {
        QMessageBox::warning(this, "Error", "Something unexpected has happened.");
    }
}

studentManagement::studentManagement(QString username, QWidget *parent) :
    QDialog(parent),
    ui(new Ui::studentManagement)
{
    this->username = username;
    ui->setupUi(this);
    QFont information_font = ui->informationLabel->font();
    information_font.setPointSize(14);
    information_font.setBold(true);
    ui->informationLabel->setFont(information_font);
    ui->startdate->setMinimumDate(QDate::currentDate());
    ui->dayOfLessonsBox->addItem("Monday");
    ui->dayOfLessonsBox->addItem("Tuesday");
    ui->dayOfLessonsBox->addItem("Wednesday");
    ui->dayOfLessonsBox->addItem("Thursday");
    ui->dayOfLessonsBox->addItem("Friday");
    ui->dayOfLessonsBox->addItem("Saturday");
    ui->dayOfLessonsBox->addItem("Sunday");

    // This connect statment could be quit unnecessary as Qt will create it automatically
    // Since you have created the function name as it is expected by Qt (on_class_event)    
    QObject::connect(addStudent, SIGNAL(clicked()), this, SLOT(on_addStudent_clicked()));
}

studentManagement::~studentManagement()
{
    delete ui;
}

void studentManagement::on_addStudent_clicked()
{
    QString firstname = ui->firstname->text();
    QString lastname = ui->lastname->text();
    QString DOB = ui->dateofbirth->text();
    QString dayOfLessons = ui->dayOfLessonsBox->currentText();
    QString startdate = ui->startdate->text();
    QString pricing = ui->pricing->text();
    QString lengthoflessons = ui->lengthoflessons->text();
    QSqlDatabase mydb = QSqlDatabase::addDatabase("QSQLITE");
    mydb.setDatabaseName("accounts.db");
    if (!mydb.open()) 
    {
        QMessageBox::warning(this, "File Not Found Error", "The database file cannot be find.");
    }
    else 
    {
        QSqlQuery query;
        if (query.exec("INSERT INTO studentList VALUES('" + firstname + "', '" + lastname + "', '" + DOB + "', '" + dayOfLessons + "', '" + startdate + "', '" + pricing + "', '" + lengthoflessons + "', '" + username + "');"))
            mydb.close();       
    }
    studentWindow = new studentManagement(username, this);
    studentWindow->show();

    viewStudents::refreshwindow();
    // OR
    // define refreshwindow as a public slot and emit a signal from here
    emit(viewStudents::refreshwindow());
}

暫無
暫無

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

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