2
0
forked from Ivasoft/DSView

fix: The status of The hot key and toolbar is not same

This commit is contained in:
dreamsourcelabTAI
2023-03-13 14:46:47 +08:00
parent e9a111379c
commit b1438495d4
6 changed files with 96 additions and 162 deletions

View File

@@ -123,19 +123,19 @@ void _saveApp(AppOptions &o, QSettings &st){
void _loadDockOptions(DockOptions &o, QSettings &st, const char *group){
st.beginGroup(group);
getFiled("decodeDoc", st, o.decodeDoc, false);
getFiled("triggerDoc", st, o.triggerDoc, false);
getFiled("measureDoc", st, o.measureDoc, false);
getFiled("searchDoc", st, o.searchDoc, false);
getFiled("decodeDoc", st, o.decodeDock, false);
getFiled("triggerDoc", st, o.triggerDock, false);
getFiled("measureDoc", st, o.measureDock, false);
getFiled("searchDoc", st, o.searchDock, false);
st.endGroup();
}
void _saveDockOptions(DockOptions &o, QSettings &st, const char *group){
st.beginGroup(group);
setFiled("decodeDoc", st, o.decodeDoc);
setFiled("triggerDoc", st, o.triggerDoc);
setFiled("measureDoc", st, o.measureDoc);
setFiled("searchDoc", st, o.searchDoc);
setFiled("decodeDoc", st, o.decodeDock);
setFiled("triggerDoc", st, o.triggerDock);
setFiled("measureDoc", st, o.measureDock);
setFiled("searchDoc", st, o.searchDock);
st.endGroup();
}

View File

@@ -63,11 +63,13 @@ struct AppOptions
std::vector<StringPair> m_protocolFormats;
};
struct DockOptions{
bool decodeDoc;
bool triggerDoc;
bool measureDoc;
bool searchDoc;
// The dock pannel open status.
struct DockOptions
{
bool decodeDock;
bool triggerDock;
bool measureDock;
bool searchDock;
};
struct FrameOptions

View File

@@ -366,7 +366,8 @@ void DsoTriggerDock::init()
_margin_slider->setDisabled(true);
_channel_comboBox->setDisabled(true);
return;
} else {
}
else {
for(QAbstractButton * btn : _source_group->buttons())
btn->setDisabled(false);

View File

@@ -476,7 +476,6 @@ namespace pv
_trigger_dock->setVisible(false);
_dso_trigger_dock->setVisible(visible);
}
_trig_bar->update_trig_btn(visible);
}
void MainWindow::on_measure(bool visible)
@@ -1078,23 +1077,9 @@ namespace pv
}
}
if (_device_agent->get_work_mode() != DSO)
{
_dso_trigger_dock->setVisible(false);
_trig_bar->update_trig_btn(_trigger_dock->isVisible());
if (_device_agent->have_instance()){
_trig_bar->reload();
}
else
{
_trigger_dock->setVisible(false);
_trig_bar->update_trig_btn(_dso_trigger_dock->isVisible());
}
if (_device_agent->get_work_mode() != LOGIC)
{
on_protocol(false);
}
_trig_bar->update_protocol_btn(_protocol_dock->isVisible());
_trig_bar->update_measure_btn(_measure_dock->isVisible());
_trig_bar->update_search_btn(_search_dock->isVisible());
}
bool MainWindow::eventFilter(QObject *object, QEvent *event)
@@ -1127,31 +1112,31 @@ namespace pv
case Qt::Key_S:
_sampling_bar->run_or_stop();
break;
case Qt::Key_I:
_sampling_bar->run_or_stop_instant();
break;
case Qt::Key_T:
if (_device_agent->get_work_mode() == DSO)
on_trigger(!_dso_trigger_dock->isVisible());
else if (_device_agent->get_work_mode() == LOGIC)
on_trigger(!_trigger_dock->isVisible());
_trig_bar->trigger_clicked();
break;
case Qt::Key_D:
if (_device_agent->get_work_mode() == LOGIC)
on_protocol(!_protocol_dock->isVisible());
_trig_bar->protocol_clicked();
break;
case Qt::Key_M:
on_measure(!_measure_dock->isVisible());
_trig_bar->measure_clicked();
break;
case Qt::Key_R:
if (_device_agent->get_work_mode() == LOGIC)
on_search(!_search_dock->isVisible());
_trig_bar->search_clicked();
break;
case Qt::Key_O:
_sampling_bar->config_device();
break;
case Qt::Key_PageUp:
_view->set_scale_offset(_view->scale(),
_view->offset() - _view->get_view_width());
@@ -1161,12 +1146,15 @@ namespace pv
_view->offset() + _view->get_view_width());
break;
case Qt::Key_Left:
_view->zoom(1);
break;
case Qt::Key_Right:
_view->zoom(-1);
break;
case Qt::Key_0:
for (auto s : sigs)
{
@@ -1182,6 +1170,7 @@ namespace pv
_view->setFocus();
update();
break;
case Qt::Key_1:
for (auto s : sigs)
{
@@ -1197,6 +1186,7 @@ namespace pv
_view->setFocus();
update();
break;
case Qt::Key_Up:
for (auto s : sigs)
{
@@ -1211,6 +1201,7 @@ namespace pv
}
}
break;
case Qt::Key_Down:
for (auto s : sigs)
{
@@ -1225,6 +1216,7 @@ namespace pv
}
}
break;
default:
QWidget::keyPressEvent((QKeyEvent *)event);
}
@@ -1453,8 +1445,7 @@ namespace pv
_view->set_device();
_trigger_widget->init();
_trigger_widget->device_updated();
_trig_bar->reload();
_trig_bar->restore_status();
_trig_bar->reload();
_dso_trigger_widget->init();
_measure_widget->reload();
}

View File

@@ -31,8 +31,8 @@
#include "../dialogs/mathoptions.h"
#include "../view/trace.h"
#include "../dialogs/applicationpardlg.h"
#include "../config/appconfig.h"
#include "../ui/langresource.h"
#include "../config/appconfig.h"
namespace pv {
namespace toolbars {
@@ -53,10 +53,8 @@ TrigBar::TrigBar(SigSession *session, QWidget *parent) :
setMovable(false);
setContentsMargins(0,0,0,0);
_trig_button.setCheckable(true);
_protocol_button.setCheckable(true);
_trig_button.setCheckable(true);
_protocol_button.setCheckable(true);
_measure_button.setCheckable(true);
_search_button.setCheckable(true);
@@ -178,94 +176,63 @@ void TrigBar::reStyle()
_dark_style->setIcon(QIcon(iconPath+"/dark.svg"));
_light_style->setIcon(QIcon(iconPath+"/light.svg"));
_action_dispalyOptions->setIcon(QIcon(iconPath+"/gear.svg"));
AppConfig &app = AppConfig::Instance();
_action_dispalyOptions->setIcon(QIcon(iconPath+"/gear.svg"));
AppConfig &app = AppConfig::Instance();
QString icon_fname = iconPath +"/"+ app._frameOptions.style +".svg";
_themes->setIcon(QIcon(icon_fname));
}
void TrigBar::protocol_clicked()
{
sig_protocol(_protocol_button.isChecked());
DockOptions *opt = getDockOptions();
opt->decodeDoc = _protocol_button.isChecked();
AppConfig::Instance().SaveFrame();
if (_protocol_button.isVisible())
{
DockOptions *opt = getDockOptions();
opt->decodeDock = !opt->decodeDock;
sig_protocol(opt->decodeDock);
_protocol_button.setChecked(opt->decodeDock);
AppConfig::Instance().SaveFrame();
}
}
void TrigBar::trigger_clicked()
{
sig_trigger(_trig_button.isChecked());
DockOptions *opt = getDockOptions();
opt->triggerDoc = _trig_button.isChecked();
AppConfig::Instance().SaveFrame();
}
void TrigBar::update_trig_btn(bool checked)
{
_trig_button.setChecked(checked);
}
void TrigBar::update_protocol_btn(bool checked)
{
_protocol_button.setChecked(checked);
}
void TrigBar::update_measure_btn(bool checked)
{
_measure_button.setChecked(checked);
}
void TrigBar::update_search_btn(bool checked)
{
_search_button.setChecked(checked);
if (_trig_button.isVisible())
{
DockOptions *opt = getDockOptions();
opt->triggerDock = !opt->triggerDock;
sig_trigger(opt->triggerDock);
_trig_button.setChecked(opt->triggerDock);
AppConfig::Instance().SaveFrame();
}
}
void TrigBar::measure_clicked()
{
sig_measure(_measure_button.isChecked());
DockOptions *opt = getDockOptions();
opt->measureDoc = _measure_button.isChecked();
AppConfig::Instance().SaveFrame();
{
if (_measure_button.isVisible())
{
DockOptions *opt = getDockOptions();
opt->measureDock = !opt->measureDock;
sig_measure(opt->measureDock);
_measure_button.setChecked(opt->measureDock);
AppConfig::Instance().SaveFrame();
}
}
void TrigBar::search_clicked()
{
sig_search(_search_button.isChecked());
DockOptions *opt = getDockOptions();
opt->searchDoc = _search_button.isChecked();
AppConfig::Instance().SaveFrame();
}
void TrigBar::close_all()
{
if (_trig_button.isChecked()) {
_trig_button.setChecked(false);
sig_trigger(false);
}
if (_protocol_button.isChecked()) {
_protocol_button.setChecked(false);
sig_protocol(false);
}
if (_measure_button.isChecked()) {
_measure_button.setChecked(false);
sig_measure(false);
}
if(_search_button.isChecked()) {
_search_button.setChecked(false);
sig_search(false);
}
if (_search_button.isVisible())
{
DockOptions *opt = getDockOptions();
opt->searchDock = !opt->searchDock;
sig_search(opt->searchDock);
_search_button.setChecked(opt->searchDock);
AppConfig::Instance().SaveFrame();
}
}
void TrigBar::reload()
{
close_all();
int mode = _session->get_device()->get_work_mode();
if (mode == LOGIC) {
@@ -296,6 +263,18 @@ void TrigBar::reload()
_action_dispalyOptions->setVisible(false);
}
DockOptions *opt = getDockOptions();
sig_protocol(_protocol_action->isVisible() && opt->decodeDock);
sig_trigger(_trig_action->isVisible() && opt->triggerDock);
sig_measure(_measure_action->isVisible() && opt->measureDock);
sig_search(_search_action->isVisible() && opt->searchDock);
_protocol_action->setChecked(opt->decodeDock);
_trig_action->setChecked(opt->triggerDock);
_measure_action->setChecked(opt->measureDock);
_search_action->setChecked(opt->searchDock);
update_view_status();
update();
}
@@ -332,43 +311,16 @@ void TrigBar::on_actionLissajous_triggered()
lissajous_dlg.exec();
}
void TrigBar::on_application_param(){
// pv::dialogs::MathOptions math_dlg(_session, this); math_dlg.exec(); return;
pv::dialogs::ApplicationParamDlg dlg;
dlg.ShowDlg(this);
void TrigBar::on_application_param()
{
pv::dialogs::ApplicationParamDlg dlg;
dlg.ShowDlg(this);
}
void TrigBar::restore_status()
{
DockOptions *opt = getDockOptions();
if (opt->decodeDoc){
_protocol_button.setChecked(true);
sig_protocol(true);
}
if (opt->triggerDoc){
_trig_button.setChecked(true);
sig_trigger(true);
}
if (opt->measureDoc){
_measure_button.setChecked(true);
sig_measure(true);
}
if (opt->searchDoc){
_search_button.setChecked(true);
sig_search(true);
}
}
DockOptions* TrigBar::getDockOptions()
{
AppConfig &app = AppConfig::Instance();
int mode = _session->get_device()->get_work_mode();
AppConfig &app = AppConfig::Instance();
int mode = _session->get_device()->get_work_mode();
if (mode == LOGIC)
return &app._frameOptions._logicDock;

View File

@@ -27,7 +27,6 @@
#include <QToolButton>
#include <QAction>
#include <QMenu>
class DockOptions;
@@ -45,8 +44,6 @@ class TrigBar : public QToolBar
public:
explicit TrigBar(SigSession *session, QWidget *parent = 0);
void close_all();
void reload();
void update_view_status();
@@ -54,7 +51,7 @@ private:
void changeEvent(QEvent *event);
void retranslateUi();
void reStyle();
DockOptions* getDockOptions();
DockOptions* getDockOptions();
signals:
void sig_setTheme(QString style);
@@ -68,6 +65,9 @@ private slots:
void on_actionDark_triggered();
void on_actionLight_triggered();
void on_actionLissajous_triggered();
void on_actionFft_triggered();
void on_actionMath_triggered();
void on_application_param();
public slots:
void protocol_clicked();
@@ -75,18 +75,6 @@ public slots:
void measure_clicked();
void search_clicked();
void update_trig_btn(bool checked);
void update_protocol_btn(bool checked);
void update_measure_btn(bool checked);
void update_search_btn(bool checked);
void on_actionFft_triggered();
void on_actionMath_triggered();
void on_application_param();
public:
void restore_status();
private:
SigSession *_session;
bool _enable;