#include 'lights.h' #include 'ui_lights.h' #include 'switchform.h' #include 'sqlite.h' #include #include #include #include

Lights::Lights(int userid,QWidget *parent) : QWidget(parent), ui(new Ui::Lights) { ui->setupUi(this); LightsWidget(); //连接开关组件的信号和自定义的槽函数 connect(ui->SwitchStatus,&SwitchForm::statusChanged,this,&Lights::switchButton_status);

// 连接完成按钮的clicked信号和自定义的槽函数
connect(ui->Finished, &QPushButton::clicked, this,[=]{
    if(flag)
    {
        QString brighteness = QString::number(ui->ctrlform->getValue());
        qDebug()<<brighteness;
        Sqlite::sqlite_init();
        updateSmartHomeStatus(userid,QString('灯'),QString(flag),brighteness);
    }
});

}

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

void Lights::LightsWidget() { setWindowTitle('智能灯设置'); //设置ui组件背景 setAutoFillBackground(true); QPalette palette=this->palette(); QPixmap pixmap(':/user/image/image/light.jpg'); palette.setBrush(QPalette::Window, QBrush(pixmap)); setPalette(palette); setFixedSize(600,400); }

bool Lights::switchButton_status(bool checked) { qDebug()<<checked; flag=checked; return flag; } // 更新智能家居状态表中的数据 void updateSmartHomeStatus(const int userId, const QString& deviceName, const QString& devicestate, const QString& newValue) { Sqlite::sqlite_init(); // 执行更新操作 QSqlQuery query; QString sql = QString('UPDATE Status SET %1 = :newValue WHERE username = :uid') .arg(deviceName); query.prepare(sql); query.bindValue(':divice_state', devicestate); query.bindValue(':value', newValue); query.bindValue(':uid', userId);

if (!query.exec()) {
    qDebug() << '更新数据失败:' << query.lastError().text();
} else {
    qDebug() << '数据更新成功';
}

}


原文地址: https://www.cveoy.top/t/topic/fAxA 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录