代码修改只显示修改部分:用户点击Lights界面从数据库的Status表中得到最新的智能灯device_state和value更新在Lights页面当用户未对Switchform进行操作但对ctrlform更改时向Status存入上一次Status的device_state并更新value值#ifndef LIGHTS_H#define LIGHTS_H#include QWidgetnamesp
以下是修改的代码部分:
void Lights::showEvent(QShowEvent *event)
{
// 当页面显示时,加载上次更改的状态
loadLastStatus();
event->accept();
}
void Lights::hideEvent(QHideEvent *event)
{
saveLastStatus();
event->accept();
}
void Lights::closeEvent(QCloseEvent *event)
{
// 隐藏窗口而不是关闭
hide();
event->ignore();
}
void Lights::loadLastStatus()
{
QString state = getLastState(this->userid);
QString brightness = getLastBrightness(this->userid);
if (state == "开启")
{
ui->SwitchStatus->setChecked(true);
ui->ctrlform->setValue(brightness.toInt());
}
else
{
ui->SwitchStatus->setChecked(false);
ui->ctrlform->setValue(0);
}
}
void Lights::saveLastStatus()
{
QString state = QString(flag);
QString brightness = QString::number(ui->ctrlform->getValue());
updateLastBrightness(this->userid, state, brightness);
}
QString Lights::getLastBrightness(int userid)
{
Sqlite::sqlite_init();
QString queryStr = QString("SELECT value FROM Status WHERE uid = %1 AND device_name = '智能灯' ORDER BY sid DESC LIMIT 1").arg(userid);
QSqlQuery query;
if (query.exec(queryStr) && query.next())
{
return query.value(0).toString();
}
else
{
qDebug() << "得到上一次亮度错误: " << query.lastError().text();
return "";
}
}
void Lights::updateLastBrightness(int userid, QString state, QString brightness)
{
Sqlite::sqlite_init();
QString queryStr = QString("UPDATE Status SET value = %1, device_state = %2 WHERE uid = %3 AND device_name = '智能灯'").arg(brightness).arg(state).arg(userid);
QSqlQuery query;
if (!query.exec(queryStr))
{
qDebug() << "更新亮度失败: " << query.lastError().text();
}
}
QString Lights::getLastState(int userid)
{
Sqlite::sqlite_init();
QString queryStr = QString("SELECT device_state FROM Status WHERE uid = %1 AND device_name = '智能灯' ORDER BY sid DESC LIMIT 1").arg(userid);
QSqlQuery query;
if (query.exec(queryStr) && query.next())
{
return query.value(0).toString();
}
else
{
qDebug() << "得到上一次状态错误: " << query.lastError().text();
return "";
}
}
以上是对Lights类中的部分代码进行修改,只显示了修改的部分。修改的内容包括:
- 修改了
showEvent函数,加载上次更改的状态。 - 修改了
hideEvent函数,保存当前更改的状态。 - 修改了
closeEvent函数,隐藏窗口而不是关闭。 - 修改了
loadLastStatus函数,获取上次更改的状态并更新界面。 - 修改了
saveLastStatus函数,保存当前更改的状态。 - 修改了
getLastBrightness函数,获取上次更改的亮度值。 - 修改了
updateLastBrightness函数,更新上次更改的亮度值。 - 修改了
getLastState函数,获取上次更改的状态。
这些修改的目的是根据需求更新界面和保存状态。
原文地址: http://www.cveoy.top/t/topic/izas 著作权归作者所有。请勿转载和采集!