add:添加可以不用重启切换配置文件重新加载。
This commit is contained in:
@@ -20,7 +20,7 @@ MainWidget::MainWidget(QWidget* parent) : QWidget(parent), ui(new Ui::MainWidget
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
setWindowTitle(u8"OneLevelXmlOpr v1.3.8");
|
||||
setWindowTitle(u8"OneLevelXmlOpr v1.3.9");
|
||||
setWindowIcon(QIcon("://resource/xml.ico"));
|
||||
|
||||
QScreen* primaryScreen = QGuiApplication::primaryScreen();
|
||||
@@ -96,8 +96,9 @@ MainWidget::MainWidget(QWidget* parent) : QWidget(parent), ui(new Ui::MainWidget
|
||||
});
|
||||
|
||||
connect(ui->btnSet, &QPushButton::clicked, this, [&]() {
|
||||
QString cur = ui->cbConfig->currentText();
|
||||
group_set_->exec();
|
||||
base_init();
|
||||
base_init(cur);
|
||||
});
|
||||
connect(ui->btnHis, &QPushButton::clicked, this, [&]() {
|
||||
CUIHistory his(this, his_);
|
||||
@@ -139,7 +140,7 @@ MainWidget::MainWidget(QWidget* parent) : QWidget(parent), ui(new Ui::MainWidget
|
||||
restoreGeometry(settings.value("geometry").toByteArray());
|
||||
settings.endGroup();
|
||||
|
||||
// QFile qss_file("://qss/lightblue.css");
|
||||
//QFile qss_file("://qss/lightblue.css");
|
||||
// QFile qss_file("://qss/flatgray.css");
|
||||
// if (qss_file.open(QFile::ReadOnly)) {
|
||||
// qApp->setStyleSheet(qss_file.readAll());
|
||||
@@ -147,7 +148,7 @@ MainWidget::MainWidget(QWidget* parent) : QWidget(parent), ui(new Ui::MainWidget
|
||||
|
||||
init_menu();
|
||||
// 基本处理
|
||||
base_init();
|
||||
base_init("");
|
||||
}
|
||||
|
||||
void MainWidget::copy_key()
|
||||
@@ -212,7 +213,10 @@ void MainWidget::show_custom_menu()
|
||||
|
||||
void MainWidget::generate_table_widget()
|
||||
{
|
||||
tab_widget_ = new QTableWidget();
|
||||
clear_tab_widget();
|
||||
if (tab_widget_ == nullptr) {
|
||||
tab_widget_ = new QTableWidget();
|
||||
}
|
||||
metrics_ = std::make_shared<QFontMetrics>(tab_widget_->font());
|
||||
tab_widget_->setContextMenuPolicy(Qt::CustomContextMenu);
|
||||
|
||||
@@ -244,9 +248,11 @@ void MainWidget::generate_table_widget()
|
||||
tab_widget_->setColumnWidth(i, col_with_[i]);
|
||||
}
|
||||
|
||||
QHBoxLayout* lay = new QHBoxLayout();
|
||||
lay->addWidget(tab_widget_);
|
||||
ui->widget->setLayout(lay);
|
||||
if (lay_ == nullptr) {
|
||||
lay_ = new QHBoxLayout();
|
||||
}
|
||||
lay_->addWidget(tab_widget_);
|
||||
ui->widget->setLayout(lay_);
|
||||
}
|
||||
|
||||
void MainWidget::push_content(const std::vector<tinyxml2::XMLElement*>& eles, std::size_t page, bool auto_jump_pre)
|
||||
@@ -316,22 +322,44 @@ void MainWidget::judge_btn_page()
|
||||
}
|
||||
}
|
||||
|
||||
void MainWidget::clear_data()
|
||||
{
|
||||
}
|
||||
|
||||
bool MainWidget::read(const QString& file_path)
|
||||
{
|
||||
unit_change_auto_ = true;
|
||||
ui->cbUnit->clear();
|
||||
unit_change_auto_ = false;
|
||||
if (alreay_open_) {
|
||||
if (!CUtil::affirm(this, u8"确认", u8"当前已有打开文件在使用,请确认已保存相关内容再继续。")) {
|
||||
return false;
|
||||
} else {
|
||||
xml_.clear_data();
|
||||
current_.clear();
|
||||
vec_.clear();
|
||||
}
|
||||
}
|
||||
// 获取配置
|
||||
cur_config_.name = ui->cbConfig->currentText().toStdString();
|
||||
if (!ini_oper_->get_item(cur_config_)) {
|
||||
CUtil::msg(this, u8"获取配置失败。");
|
||||
clear_tab_widget();
|
||||
alreay_open_ = false;
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!xml_.open(file_path.toStdString())) {
|
||||
CUtil::msg(this, u8"打开xml失败。");
|
||||
clear_tab_widget();
|
||||
alreay_open_ = false;
|
||||
return false;
|
||||
}
|
||||
xml_.set_baseinfo(cur_config_);
|
||||
if (!xml_.parse_xml(vec_)) {
|
||||
CUtil::msg(this, u8"解析xml失败。");
|
||||
clear_tab_widget();
|
||||
alreay_open_ = false;
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -354,6 +382,7 @@ bool MainWidget::read(const QString& file_path)
|
||||
}
|
||||
u_ = false;
|
||||
ui->btnResort->setEnabled(false);
|
||||
ui->cbUnit->setEnabled(true);
|
||||
} else {
|
||||
ui->cbUnit->setEnabled(false);
|
||||
}
|
||||
@@ -369,21 +398,20 @@ bool MainWidget::read(const QString& file_path)
|
||||
current_ = vec_;
|
||||
|
||||
ui->edStatus->setText(file_path);
|
||||
ui->btnRead->setEnabled(false);
|
||||
// ui->btnRead->setEnabled(false);
|
||||
ui->btnSave->setEnabled(true);
|
||||
ui->btnSelectFile->setEnabled(false);
|
||||
// ui->btnSelectFile->setEnabled(false);
|
||||
ui->btnImport->setEnabled(true);
|
||||
ui->btnExport->setEnabled(true);
|
||||
ui->btnBackup->setEnabled(true);
|
||||
ui->btnBackup->setEnabled(true);
|
||||
ui->btnResort->setEnabled(true);
|
||||
|
||||
ui->cbConfig->setEnabled(false);
|
||||
ui->btnSet->setEnabled(false);
|
||||
ui->btnHis->setEnabled(false);
|
||||
// ui->cbConfig->setEnabled(false);
|
||||
// ui->btnSet->setEnabled(false);
|
||||
// ui->btnHis->setEnabled(false);
|
||||
|
||||
his_->push(ui->edStatus->text().toStdString());
|
||||
|
||||
alreay_open_ = true;
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -896,14 +924,18 @@ void MainWidget::backup_file()
|
||||
}
|
||||
}
|
||||
|
||||
void MainWidget::base_init()
|
||||
void MainWidget::base_init(const QString& cur_config)
|
||||
{
|
||||
StrVec_t vec;
|
||||
ini_oper_->get_all_node(vec);
|
||||
|
||||
QStringList list;
|
||||
bool have = false;
|
||||
for (const auto& data : vec) {
|
||||
list.append(QString::fromStdString(data));
|
||||
if (QString::fromStdString(data) == cur_config) {
|
||||
have = true;
|
||||
}
|
||||
}
|
||||
ui->cbConfig->clear();
|
||||
|
||||
@@ -912,7 +944,11 @@ void MainWidget::base_init()
|
||||
}
|
||||
|
||||
ui->cbConfig->addItems(list);
|
||||
ui->cbConfig->setCurrentIndex(0);
|
||||
if (have) {
|
||||
ui->cbConfig->setCurrentIndex(list.indexOf(cur_config));
|
||||
} else {
|
||||
ui->cbConfig->setCurrentIndex(0);
|
||||
}
|
||||
}
|
||||
|
||||
void MainWidget::unit_change()
|
||||
@@ -920,6 +956,9 @@ void MainWidget::unit_change()
|
||||
if (u_) {
|
||||
return;
|
||||
}
|
||||
if (unit_change_auto_) {
|
||||
return;
|
||||
}
|
||||
std::string unit = ui->cbUnit->currentText().toStdString();
|
||||
if (!xml_.get_all_elements(vec_, unit)) {
|
||||
CUtil::msg(this, u8"获取单元信息失败:" + QString::fromStdString(unit));
|
||||
@@ -955,6 +994,18 @@ bool MainWidget::format_xml()
|
||||
return true;
|
||||
}
|
||||
|
||||
void MainWidget::clear_tab_widget()
|
||||
{
|
||||
if (tab_widget_) {
|
||||
tab_widget_->setRowCount(0);
|
||||
if (lay_) {
|
||||
lay_->removeWidget(tab_widget_);
|
||||
}
|
||||
delete tab_widget_;
|
||||
tab_widget_ = new QTableWidget();
|
||||
}
|
||||
}
|
||||
|
||||
std::string MainWidget::extract_prefix(const std::string& name)
|
||||
{
|
||||
auto pos = name.find('.');
|
||||
|
||||
Reference in New Issue
Block a user