fix: Unable to display all measure item on measure dock pannel

This commit is contained in:
dreamsourcelabTAI 2023-06-19 15:48:46 +08:00
parent 7794abe092
commit 4c295efafb
2 changed files with 414 additions and 284 deletions

View File

@ -54,7 +54,10 @@ MeasureDock::MeasureDock(QWidget *parent, View &view, SigSession *session) :
_session(session), _session(session),
_view(view) _view(view)
{ {
_widget = new QWidget(this); _widget = new QWidget(this);
_dist_pannel = NULL;
_edge_pannel = NULL;
_mouse_groupBox = new QGroupBox(_widget); _mouse_groupBox = new QGroupBox(_widget);
_fen_checkBox = new QCheckBox(_widget); _fen_checkBox = new QCheckBox(_widget);
@ -115,7 +118,6 @@ MeasureDock::MeasureDock(QWidget *parent, View &view, SigSession *session) :
_edge_layout->addWidget(_channel_label, 0, 5); _edge_layout->addWidget(_channel_label, 0, 5);
_edge_layout->addWidget(_edge_label, 0, 6); _edge_layout->addWidget(_edge_label, 0, 6);
_edge_layout->setColumnStretch(1, 50); _edge_layout->setColumnStretch(1, 50);
_edge_groupBox->setLayout(_edge_layout); _edge_groupBox->setLayout(_edge_layout);
/* cursors group */ /* cursors group */
@ -191,17 +193,17 @@ void MeasureDock::reStyle()
_dist_add_btn->setIcon(QIcon(iconPath+"/add.svg")); _dist_add_btn->setIcon(QIcon(iconPath+"/add.svg"));
_edge_add_btn->setIcon(QIcon(iconPath+"/add.svg")); _edge_add_btn->setIcon(QIcon(iconPath+"/add.svg"));
for (auto it = _cursor_disdance_list.begin(); it != _cursor_disdance_list.end(); it++) for (auto it = _dist_row_list.begin(); it != _dist_row_list.end(); it++)
{ {
(*it).del_bt->setIcon(QIcon(iconPath+"/del.svg")); (*it).del_bt->setIcon(QIcon(iconPath+"/del.svg"));
} }
for (auto it = _cursor_edge_list.begin(); it != _cursor_edge_list.end(); it++) for (auto it = _edge_row_list.begin(); it != _edge_row_list.end(); it++)
{ {
(*it).del_bt->setIcon(QIcon(iconPath+"/del.svg")); (*it).del_bt->setIcon(QIcon(iconPath+"/del.svg"));
} }
for (auto it = _cursor_opt_list.begin(); it != _cursor_opt_list.end(); it++) for (auto it = _opt_row_list.begin(); it != _opt_row_list.end(); it++)
{ {
(*it).del_bt->setIcon(QIcon(iconPath+"/del.svg")); (*it).del_bt->setIcon(QIcon(iconPath+"/del.svg"));
} }
@ -219,61 +221,13 @@ void MeasureDock::reload()
else else
_edge_groupBox->setVisible(false); _edge_groupBox->setVisible(false);
for (auto &o : _cursor_edge_list){ for (auto &o : _edge_row_list){
update_probe_selector(o.box); update_probe_selector(o.box);
} }
reCalc(); reCalc();
} }
void MeasureDock::cursor_update()
{
using namespace pv::data;
for(auto it = _cursor_opt_list.begin(); it != _cursor_opt_list.end(); it++)
{
(*it).del_bt->deleteLater();
(*it).goto_bt->deleteLater();
(*it).info_lable->deleteLater();
}
_cursor_opt_list.clear();
update_dist();
update_edge();
QFont font = this->font();
font.setPointSizeF(AppConfig::Instance().appOptions.fontSize);
int index = 1;
QString iconPath = GetIconPath();
auto &cursor_list = _view.get_cursorList();
for(auto it = cursor_list.begin(); it != cursor_list.end(); it++) {
QString curCursor = QString::number(index);
QToolButton *del_btn = new QToolButton(_widget);
del_btn->setIcon(QIcon(iconPath+"/del.svg"));
del_btn->setCheckable(true);
QPushButton *cursor_pushButton = new QPushButton(curCursor, _widget);
set_cursor_btn_color(cursor_pushButton);
QString _cur_text = _view.get_cm_time(index - 1) + "/" + QString::number(_view.get_cursor_samples(index - 1));
QLabel *curpos_label = new QLabel(_cur_text, _widget);
_cursor_layout->addWidget(del_btn, 1+index, 0);
_cursor_layout->addWidget(cursor_pushButton, 1 + index, 1);
_cursor_layout->addWidget(curpos_label, 1 + index, 2);
curpos_label->setFont(font);
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_cursor()));
connect(cursor_pushButton, SIGNAL(clicked()), this, SLOT(goto_cursor()));
cursor_opt_info inf = {del_btn, cursor_pushButton, curpos_label, (*it)};
_cursor_opt_list.push_back(inf);
index++;
}
}
void MeasureDock::measure_updated() void MeasureDock::measure_updated()
{ {
_width_label->setText(_view.get_measure("width")); _width_label->setText(_view.get_measure("width"));
@ -282,93 +236,112 @@ void MeasureDock::measure_updated()
_duty_label->setText(_view.get_measure("duty")); _duty_label->setText(_view.get_measure("duty"));
} }
void MeasureDock::cursor_moving() void MeasureDock::build_dist_pannel()
{ {
if (_view.cursors_shown()) { if (_dist_pannel != NULL){
int index = 0; _dist_pannel->deleteLater();
auto &cursor_list = _view.get_cursorList(); _dist_pannel = NULL;
for(auto i = cursor_list.begin(); i != cursor_list.end(); i++) {
QString _cur_text = _view.get_cm_time(index) + "/" + QString::number(_view.get_cursor_samples(index));
_cursor_opt_list[index].info_lable->setText(_cur_text);
index++;
}
} }
update_dist();
}
void MeasureDock::reCalc()
{
cursor_update();
update_dist();
update_edge();
}
void MeasureDock::goto_cursor()
{
int index = 0;
QPushButton *src = qobject_cast<QPushButton *>(sender());
assert(src);
for (auto it = _cursor_opt_list.begin(); it != _cursor_opt_list.end(); it++)
{
if ( (*it).goto_bt == src){
_view.set_cursor_middle(index);
break;
}
index++;
}
}
void MeasureDock::add_dist_measure()
{
// dsv_info("add_dist_measure:%d", _cursor_disdance_list.size());
if (_cursor_disdance_list.size() > Max_Measure_Limits)
return;
QFont font = this->font(); QFont font = this->font();
font.setPointSizeF(AppConfig::Instance().appOptions.fontSize); font.setPointSizeF(AppConfig::Instance().appOptions.fontSize);
QWidget *row_widget = new QWidget(_widget); QGridLayout *lay = new QGridLayout();
row_widget->setContentsMargins(0,0,0,0); _dist_pannel = new QWidget();
QHBoxLayout *row_layout = new QHBoxLayout(row_widget); _dist_pannel->setLayout(lay);
row_layout->setContentsMargins(0,0,0,0); lay->setColumnStretch(1, 50);
row_layout->setSpacing(0); lay->setColumnStretch(6, 100);
row_widget->setLayout(row_layout); lay->setVerticalSpacing(5);
lay->setContentsMargins(0,0,0,0);
int dex = 0;
QLabel cal_lb;
cal_lb.setFont(font);
int bt_w = cal_lb.fontMetrics().width("22") + 8;
QString iconPath = GetIconPath(); for (auto &o : _dist_row_list)
QToolButton *del_btn = new QToolButton(row_widget); {
del_btn->setIcon(QIcon(iconPath+"/del.svg")); QWidget *row_widget = new QWidget(_widget);
del_btn->setCheckable(true); row_widget->setContentsMargins(0,0,0,0);
//tr QHBoxLayout *row_layout = new QHBoxLayout(row_widget);
QPushButton *s_btn = new QPushButton(" ", row_widget); row_layout->setContentsMargins(0,0,0,0);
s_btn->setObjectName("dist"); row_layout->setSpacing(0);
//tr row_widget->setLayout(row_layout);
QPushButton *e_btn = new QPushButton(" ", row_widget);
e_btn->setObjectName("dist");
QLabel *r_label = new QLabel(row_widget);
//tr
QLabel *g_label = new QLabel("-", row_widget);
g_label->setContentsMargins(0,0,0,0);
row_layout->addWidget(del_btn); QString iconPath = GetIconPath();
row_layout->addSpacing(5); QToolButton *del_btn = new QToolButton(row_widget);
row_layout->addWidget(s_btn); del_btn->setIcon(QIcon(iconPath+"/del.svg"));
row_layout->addWidget(g_label); del_btn->setCheckable(true);
row_layout->addWidget(e_btn); //tr
row_layout->addSpacing(5); QPushButton *s_btn = new QPushButton("", row_widget);
row_layout->addWidget(r_label, 100); //tr
r_label->setFont(font); QPushButton *e_btn = new QPushButton("", row_widget);
QLabel *r_label = new QLabel(row_widget);
//tr
QLabel *g_label = new QLabel("-", row_widget);
g_label->setContentsMargins(0,0,0,0);
cursor_distance_info inf = {row_widget, del_btn, s_btn, e_btn, r_label}; row_layout->addWidget(del_btn);
_cursor_disdance_list.push_back(inf); row_layout->addSpacing(5);
row_layout->addWidget(s_btn);
row_layout->addWidget(g_label);
row_layout->addWidget(e_btn);
row_layout->addSpacing(5);
row_layout->addWidget(r_label, 100);
_dist_layout->addWidget(row_widget, _cursor_disdance_list.size(), 0, 1, 7); r_label->setFont(font);
s_btn->setFont(font);
e_btn->setFont(font);
g_label->setFont(font);
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_dist_measure())); s_btn->setFixedWidth(bt_w);
connect(s_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor())); e_btn->setFixedWidth(bt_w);
connect(e_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
lay->addWidget(row_widget, dex++, 0, 1, 7);
if (o.r_label != NULL){
r_label->setText(o.r_label->text());
}
o.del_bt = del_btn;
o.start_bt = s_btn;
o.end_bt = e_btn;
o.r_label = r_label;
if (o.cursor1 != -1){
o.start_bt->setText(QString::number(o.cursor1));
set_cursor_btn_color(o.start_bt);
}
if (o.cursor2 != -1){
o.end_bt->setText(QString::number(o.cursor2));
set_cursor_btn_color(o.end_bt);
}
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_dist_measure()));
connect(s_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
connect(e_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
}
_dist_layout->addWidget(_dist_pannel, 1, 0, 1, 7);
}
void MeasureDock::add_dist_measure()
{
if (_dist_row_list.size() < Max_Measure_Limits)
{
cursor_row_info inf;
inf.cursor1 = -1;
inf.cursor2 = -1;
inf.box = NULL;
inf.del_bt = NULL;
inf.start_bt = NULL;
inf.end_bt = NULL;
inf.r_label = NULL;
_dist_row_list.push_back(inf);
build_dist_pannel();
}
} }
void MeasureDock::del_dist_measure() void MeasureDock::del_dist_measure()
@ -376,77 +349,130 @@ void MeasureDock::del_dist_measure()
QToolButton* src = dynamic_cast<QToolButton *>(sender()); QToolButton* src = dynamic_cast<QToolButton *>(sender());
assert(src); assert(src);
for (auto it =_cursor_disdance_list.begin(); it != _cursor_disdance_list.end(); it++) for (auto it =_dist_row_list.begin(); it != _dist_row_list.end(); it++)
{ {
if ((*it).del_bt == src){ if ((*it).del_bt == src){
_dist_layout->removeWidget((*it).row_pannel); _dist_row_list.erase(it);
(*it).row_pannel->deleteLater(); build_dist_pannel();
_cursor_disdance_list.erase(it);
break; break;
} }
} }
}
// dsv_info("del_dist_measure:%d", _cursor_disdance_list.size()); void MeasureDock::build_edge_pannel()
{
if (_edge_pannel != NULL)
{
_edge_pannel->deleteLater();
_edge_pannel = NULL;
}
QFont font = this->font();
font.setPointSizeF(AppConfig::Instance().appOptions.fontSize);
QGridLayout *lay = new QGridLayout();
_edge_pannel = new QWidget();
_edge_pannel->setLayout(lay);
lay->setColumnStretch(1, 50);
lay->setColumnStretch(6, 100);
lay->setVerticalSpacing(5);
lay->setContentsMargins(0,0,0,0);
int dex = 0;
QLabel cal_lb;
cal_lb.setFont(font);
int bt_w = cal_lb.fontMetrics().width("22") + 8;
for (auto &o : _edge_row_list)
{
QWidget *row_widget = new QWidget(_widget);
row_widget->setContentsMargins(0,0,0,0);
QHBoxLayout *row_layout = new QHBoxLayout(row_widget);
row_layout->setContentsMargins(0,0,0,0);
row_layout->setSpacing(0);
row_widget->setLayout(row_layout);
QString iconPath = GetIconPath();
QToolButton *del_btn = new QToolButton(row_widget);
del_btn->setIcon(QIcon(iconPath+"/del.svg"));
del_btn->setCheckable(true);
//tr
QPushButton *s_btn = new QPushButton(" ", row_widget);
//tr
QPushButton *e_btn = new QPushButton(" ", row_widget);
QLabel *r_label = new QLabel(row_widget);
//tr
QLabel *g_label = new QLabel("-", row_widget);
g_label->setContentsMargins(0,0,0,0);
//tr
QLabel *a_label = new QLabel("@", row_widget);
a_label->setContentsMargins(0,0,0,0);
QComboBox *ch_cmb = create_probe_selector(row_widget);
row_layout->addWidget(del_btn);
row_layout->addSpacing(5);
row_layout->addWidget(s_btn);
row_layout->addWidget(g_label);
row_layout->addWidget(e_btn);
row_layout->addWidget(a_label);
row_layout->addWidget(ch_cmb);
row_layout->addSpacing(5);
row_layout->addWidget(r_label, 100);
g_label->setFont(font);
a_label->setFont(font);
s_btn->setFont(font);
e_btn->setFont(font);
a_label->setFont(font);
s_btn->setFixedWidth(bt_w);
e_btn->setFixedWidth(bt_w);
lay->addWidget(row_widget, dex++, 0, 1, 7);
if (o.r_label != NULL){
r_label->setText(o.r_label->text());
}
o.del_bt = del_btn;
o.start_bt = s_btn;
o.end_bt = e_btn;
o.r_label = r_label;
o.box = ch_cmb;
if (o.cursor1 != -1){
o.start_bt->setText(QString::number(o.cursor1));
set_cursor_btn_color(o.start_bt);
}
if (o.cursor2 != -1){
o.end_bt->setText(QString::number(o.cursor2));
set_cursor_btn_color(o.end_bt);
}
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_edge_measure()));
connect(s_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
connect(e_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
connect(ch_cmb, SIGNAL(currentIndexChanged(int)), this, SLOT(update_edge()));
}
_edge_layout->addWidget(_edge_pannel, 1, 0, 1, 7);
} }
void MeasureDock::add_edge_measure() void MeasureDock::add_edge_measure()
{ {
if (_cursor_edge_list.size() > Max_Measure_Limits) if (_edge_row_list.size() < Max_Measure_Limits)
return; {
cursor_row_info inf;
inf.cursor1 = -1;
inf.cursor2 = -1;
inf.box = NULL;
inf.del_bt = NULL;
inf.start_bt = NULL;
inf.end_bt = NULL;
inf.r_label = NULL;
QFont font = this->font(); _edge_row_list.push_back(inf);
font.setPointSizeF(AppConfig::Instance().appOptions.fontSize); build_edge_pannel();
}
QWidget *row_widget = new QWidget(_widget);
row_widget->setContentsMargins(0,0,0,0);
QHBoxLayout *row_layout = new QHBoxLayout(row_widget);
row_layout->setContentsMargins(0,0,0,0);
row_layout->setSpacing(0);
row_widget->setLayout(row_layout);
QString iconPath = GetIconPath();
QToolButton *del_btn = new QToolButton(row_widget);
del_btn->setIcon(QIcon(iconPath+"/del.svg"));
del_btn->setCheckable(true);
//tr
QPushButton *s_btn = new QPushButton(" ", row_widget);
s_btn->setObjectName("edge");
//tr
QPushButton *e_btn = new QPushButton(" ", row_widget);
e_btn->setObjectName("edge");
QLabel *r_label = new QLabel(row_widget);
//tr
QLabel *g_label = new QLabel("-", row_widget);
g_label->setContentsMargins(0,0,0,0);
//tr
QLabel *a_label = new QLabel("@", row_widget);
a_label->setContentsMargins(0,0,0,0);
QComboBox *ch_cmb = create_probe_selector(row_widget);
row_layout->addWidget(del_btn);
row_layout->addSpacing(5);
row_layout->addWidget(s_btn);
row_layout->addWidget(g_label);
row_layout->addWidget(e_btn);
row_layout->addWidget(a_label);
row_layout->addWidget(ch_cmb);
row_layout->addSpacing(5);
row_layout->addWidget(r_label, 100);
g_label->setFont(font);
a_label->setFont(font);
s_btn->setFont(font);
e_btn->setFont(font);
cursor_edge_info inf = {row_widget, del_btn, s_btn, e_btn, r_label, ch_cmb};
_cursor_edge_list.push_back(inf);
_edge_layout->addWidget(row_widget, _cursor_edge_list.size(), 0, 1, 7);
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_edge_measure()));
connect(s_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
connect(e_btn, SIGNAL(clicked()), this, SLOT(show_all_coursor()));
connect(ch_cmb, SIGNAL(currentIndexChanged(int)), this, SLOT(update_edge()));
} }
void MeasureDock::del_edge_measure() void MeasureDock::del_edge_measure()
@ -454,12 +480,11 @@ void MeasureDock::del_edge_measure()
QToolButton* src = dynamic_cast<QToolButton *>(sender()); QToolButton* src = dynamic_cast<QToolButton *>(sender());
assert(src); assert(src);
for (auto it =_cursor_edge_list.begin(); it != _cursor_edge_list.end(); it++) for (auto it =_edge_row_list.begin(); it != _edge_row_list.end(); it++)
{ {
if ((*it).del_bt == src){ if ((*it).del_bt == src){
_dist_layout->removeWidget((*it).row_pannel); _edge_row_list.erase(it);
(*it).row_pannel->deleteLater(); build_edge_pannel();
_cursor_edge_list.erase(it);
break; break;
} }
} }
@ -496,7 +521,7 @@ void MeasureDock::show_all_coursor()
glayout->addWidget(cursor_btn, index/4, index%4, 1, 1); glayout->addWidget(cursor_btn, index/4, index%4, 1, 1);
connect(cursor_btn, SIGNAL(clicked()), &cursor_dlg, SLOT(accept())); connect(cursor_btn, SIGNAL(clicked()), &cursor_dlg, SLOT(accept()));
connect(cursor_btn, SIGNAL(clicked()), this, SLOT(set_se_cursor())); connect(cursor_btn, SIGNAL(clicked()), this, SLOT(set_sel_cursor()));
index++; index++;
} }
@ -507,75 +532,87 @@ void MeasureDock::show_all_coursor()
cursor_dlg.exec(); cursor_dlg.exec();
} }
void MeasureDock::set_se_cursor() void MeasureDock::set_sel_cursor()
{ {
QPushButton *sel_cursor_index_bt = qobject_cast<QPushButton *>(sender()); assert(_sel_btn);
if (_sel_btn) QPushButton *sel_cursor_bt = qobject_cast<QPushButton *>(sender());
_sel_btn->setText(sel_cursor_index_bt->text()); int type = 0;
cursor_row_info *inf = NULL;
set_cursor_btn_color(_sel_btn); if (type == 0)
{
if (_sel_btn->objectName() == "dist") for (auto &o : _dist_row_list){
update_dist(); if (o.start_bt == _sel_btn || o.end_bt == _sel_btn){
else if (_sel_btn->objectName() == "edge") inf = &o;
update_edge(); type = 1;
} break;
}
const view::Cursor* MeasureDock::find_cousor(int index)
{
int cur_index = 1;
auto &cursor_list = _view.get_cursorList();
for(auto i = cursor_list.begin(); i != cursor_list.end(); i++) {
if (cur_index == index) {
return (*i);
} }
} }
return NULL; if (type == 0)
{
for (auto &o : _edge_row_list){
if (o.start_bt == _sel_btn || o.end_bt == _sel_btn){
inf = &o;
type = 2;
break;
}
}
}
assert(inf);
_sel_btn->setText(sel_cursor_bt->text());
set_cursor_btn_color(_sel_btn);
if (inf->start_bt == _sel_btn){
inf->cursor1 = sel_cursor_bt->text().toInt();
}
else if (inf->end_bt == _sel_btn){
inf->cursor2 = sel_cursor_bt->text().toInt();
}
if (type == 1)
update_dist();
else
update_edge();
} }
void MeasureDock::update_dist() void MeasureDock::update_dist()
{ {
int dist_index = 0;
auto &cursor_list = _view.get_cursorList(); auto &cursor_list = _view.get_cursorList();
for (auto it = _cursor_disdance_list.begin(); it != _cursor_disdance_list.end(); it++) { for (auto &inf : _dist_row_list)
cursor_distance_info inf = (*it); {
bool start_ret, end_ret; if (inf.cursor1 != -1) {
const unsigned int start = inf.start_bt->text().toInt(&start_ret) - 1; if (inf.cursor1 > cursor_list.size()) {
const unsigned int end = inf.end_bt->text().toInt(&end_ret) - 1; inf.start_bt->setText("");
if (start_ret) {
if (start + 1 > cursor_list.size()) {
inf.start_bt->setText(" ");
set_cursor_btn_color(inf.start_bt); set_cursor_btn_color(inf.start_bt);
start_ret = false; inf.cursor1 = -1;
}
}
if (end_ret) {
if (end + 1 > cursor_list.size()) {
inf.end_bt->setText(" ");
set_cursor_btn_color(inf.end_bt);
end_ret = false;
} }
} }
if (start_ret && end_ret) { if (inf.cursor2 != -1) {
int64_t delta = _view.get_cursor_samples(start) - if (inf.cursor2 > cursor_list.size()) {
_view.get_cursor_samples(end); inf.end_bt->setText("");
QString delta_text = _view.get_cm_delta(start, end) + set_cursor_btn_color(inf.end_bt);
inf.cursor2 = -1;
}
}
if (inf.cursor1 != -1 && inf.cursor2 != -1) {
int64_t delta = _view.get_cursor_samples(inf.cursor1-1) -
_view.get_cursor_samples(inf.cursor2-1);
QString delta_text = _view.get_cm_delta(inf.cursor1-1, inf.cursor2-1) +
"/" + QString::number(delta); "/" + QString::number(delta);
if (delta < 0) if (delta < 0)
delta_text.replace('+', '-'); delta_text.replace('+', '-');
inf.r_lable->setText(delta_text); inf.r_label->setText(delta_text);
} }
else { else {
inf.r_lable->setText(" "); inf.r_label->setText(" ");
} }
dist_index++;
} }
} }
@ -583,29 +620,25 @@ void MeasureDock::update_edge()
{ {
auto &cursor_list = _view.get_cursorList(); auto &cursor_list = _view.get_cursorList();
for (auto it = _cursor_edge_list.begin(); it != _cursor_edge_list.end(); it++) { for (auto &inf : _edge_row_list)
cursor_edge_info inf = (*it); {
bool start_ret, end_ret; if (inf.cursor1 != -1) {
const int start = inf.start_bt->text().toInt(&start_ret) - 1; if (inf.cursor1 > cursor_list.size()) {
const int end = inf.end_bt->text().toInt(&end_ret) - 1; inf.start_bt->setText("");
if (start_ret) {
if (start + 1 > cursor_list.size()) {
inf.start_bt->setText(" ");
set_cursor_btn_color(inf.start_bt); set_cursor_btn_color(inf.start_bt);
start_ret = false; inf.cursor1 = -1;
} }
} }
if (end_ret) { if (inf.cursor2 != -1) {
if (end + 1 > cursor_list.size()) { if (inf.cursor2 > cursor_list.size()) {
inf.end_bt->setText(" "); inf.end_bt->setText("");
set_cursor_btn_color(inf.end_bt); set_cursor_btn_color(inf.end_bt);
end_ret = false; inf.cursor2 = -1;
} }
} }
bool mValid = false; bool mValid = false;
if (start_ret && end_ret) { if (inf.cursor1 != -1 && inf.cursor2 != -1) {
uint64_t rising_edges; uint64_t rising_edges;
uint64_t falling_edges; uint64_t falling_edges;
@ -618,13 +651,13 @@ void MeasureDock::update_edge()
{ {
view::LogicSignal *logicSig = (view::LogicSignal*)s; view::LogicSignal *logicSig = (view::LogicSignal*)s;
if (logicSig->edges(_view.get_cursor_samples(end), _view.get_cursor_samples(start), if (logicSig->edges(_view.get_cursor_samples(inf.cursor2-1),
rising_edges, falling_edges)) _view.get_cursor_samples(inf.cursor1-1), rising_edges, falling_edges))
{ {
QString delta_text = QString::number(rising_edges) + "/" + QString delta_text = QString::number(rising_edges) + "/" +
QString::number(falling_edges) + "/" + QString::number(falling_edges) + "/" +
QString::number(rising_edges + falling_edges); QString::number(rising_edges + falling_edges);
inf.rising_edges_label->setText(delta_text); inf.r_label->setText(delta_text);
mValid = true; mValid = true;
break; break;
} }
@ -633,7 +666,7 @@ void MeasureDock::update_edge()
} }
if (!mValid) if (!mValid)
inf.rising_edges_label->setText("-/-/-"); inf.r_label->setText("-/-/-");
} }
} }
@ -670,6 +703,108 @@ void MeasureDock::update_probe_selector(QComboBox *selector)
} }
} }
void MeasureDock::cursor_moving()
{
if (_view.cursors_shown()) {
auto &cursor_list = _view.get_cursorList();
if (cursor_list.size() != _opt_row_list.size()){
assert(false);
}
int index = 0;
for(auto i = cursor_list.begin(); i != cursor_list.end(); i++) {
QString _cur_text = _view.get_cm_time(index) + "/"
+ QString::number(_view.get_cursor_samples(index));
_opt_row_list[index].info_label->setText(_cur_text);
index++;
}
}
update_dist();
}
void MeasureDock::reCalc()
{
cursor_update();
update_dist();
update_edge();
}
void MeasureDock::goto_cursor()
{
QPushButton *src = qobject_cast<QPushButton *>(sender());
assert(src);
int index = 0;
for (auto it = _opt_row_list.begin(); it != _opt_row_list.end(); it++)
{
if ( (*it).goto_bt == src){
_view.set_cursor_middle(index);
break;
}
index++;
}
}
void MeasureDock::cursor_update()
{
using namespace pv::data;
for(auto it = _opt_row_list.begin(); it != _opt_row_list.end(); it++)
{
(*it).del_bt->deleteLater();
(*it).goto_bt->deleteLater();
(*it).info_label->deleteLater();
}
_opt_row_list.clear();
update_dist();
update_edge();
QFont font = this->font();
font.setPointSizeF(AppConfig::Instance().appOptions.fontSize);
QLabel cal_lb;
cal_lb.setFont(font);
int bt_w = cal_lb.fontMetrics().width("22") + 8;
int index = 1;
int cursor_dex = 0;
QString iconPath = GetIconPath();
auto &cursor_list = _view.get_cursorList();
for(auto it = cursor_list.begin(); it != cursor_list.end(); it++) {
QToolButton *del_btn = new QToolButton(_widget);
del_btn->setIcon(QIcon(iconPath+"/del.svg"));
del_btn->setCheckable(true);
QPushButton *cursor_pushButton = new QPushButton(QString::number(index), _widget);
set_cursor_btn_color(cursor_pushButton);
QString cur_pos = _view.get_cm_time(cursor_dex) + "/"
+ QString::number(_view.get_cursor_samples(cursor_dex));
QLabel *curpos_label = new QLabel(cur_pos, _widget);
_cursor_layout->addWidget(del_btn, 1+index, 0);
_cursor_layout->addWidget(cursor_pushButton, 1 + index, 1);
_cursor_layout->addWidget(curpos_label, 1 + index, 2);
curpos_label->setFont(font);
cursor_pushButton->setFont(font);
cursor_pushButton->setFixedWidth(bt_w);
connect(del_btn, SIGNAL(clicked()), this, SLOT(del_cursor()));
connect(cursor_pushButton, SIGNAL(clicked()), this, SLOT(goto_cursor()));
cursor_opt_info inf = {del_btn, cursor_pushButton, curpos_label, (*it)};
_opt_row_list.push_back(inf);
index++;
cursor_dex++;
}
}
void MeasureDock::del_cursor() void MeasureDock::del_cursor()
{ {
QToolButton *src = qobject_cast<QToolButton *>(sender()); QToolButton *src = qobject_cast<QToolButton *>(sender());
@ -678,10 +813,9 @@ void MeasureDock::del_cursor()
Cursor* cursor = NULL; Cursor* cursor = NULL;
auto &cursor_list = _view.get_cursorList(); auto &cursor_list = _view.get_cursorList();
for (auto it = _cursor_opt_list.begin(); it != _cursor_opt_list.end(); it++) for (auto it = _opt_row_list.begin(); it != _opt_row_list.end(); it++)
{ {
if ((*it).del_bt == src) if ((*it).del_bt == src){
{
cursor = (*it).cursor; cursor = (*it).cursor;
break; break;
} }

View File

@ -53,30 +53,22 @@ namespace view {
namespace dock { namespace dock {
struct cursor_distance_info struct cursor_row_info
{ {
QWidget *row_pannel;
QToolButton *del_bt; QToolButton *del_bt;
QPushButton *start_bt; QPushButton *start_bt;
QPushButton *end_bt; QPushButton *end_bt;
QLabel *r_lable; QLabel *r_label;
};
struct cursor_edge_info
{
QWidget *row_pannel;
QToolButton *del_bt;
QPushButton *start_bt;
QPushButton *end_bt;
QLabel *rising_edges_label;
QComboBox *box; QComboBox *box;
int cursor1;
int cursor2;
}; };
struct cursor_opt_info struct cursor_opt_info
{ {
QToolButton *del_bt; QToolButton *del_bt;
QPushButton *goto_bt; QPushButton *goto_bt;
QLabel *info_lable; QLabel *info_label;
view::Cursor *cursor; view::Cursor *cursor;
}; };
@ -85,7 +77,7 @@ class MeasureDock : public QScrollArea, public IFontForm
Q_OBJECT Q_OBJECT
private: private:
static const int Max_Measure_Limits = 16; static const int Max_Measure_Limits = 15;
public: public:
MeasureDock(QWidget *parent, pv::view::View &view, SigSession *session); MeasureDock(QWidget *parent, pv::view::View &view, SigSession *session);
@ -101,6 +93,9 @@ private:
//IFontForm //IFontForm
void update_font(); void update_font();
void build_dist_pannel();
void build_edge_pannel();
private: private:
QComboBox* create_probe_selector(QWidget *parent); QComboBox* create_probe_selector(QWidget *parent);
void update_probe_selector(QComboBox *selector); void update_probe_selector(QComboBox *selector);
@ -111,8 +106,7 @@ private slots:
void add_edge_measure(); void add_edge_measure();
void del_edge_measure(); void del_edge_measure();
void show_all_coursor(); void show_all_coursor();
void set_se_cursor(); void set_sel_cursor();
const view::Cursor* find_cousor(int index);
void update_dist(); void update_dist();
void update_edge(); void update_edge();
void set_cursor_btn_color(QPushButton *btn); void set_cursor_btn_color(QPushButton *btn);
@ -146,12 +140,14 @@ private:
QGroupBox *_edge_groupBox; QGroupBox *_edge_groupBox;
QToolButton *_edge_add_btn; QToolButton *_edge_add_btn;
QPushButton *_sel_btn; QPushButton *_sel_btn;
QWidget *_dist_pannel;
QWidget *_edge_pannel;
QGridLayout *_cursor_layout; QGridLayout *_cursor_layout;
QGroupBox *_cursor_groupBox; QGroupBox *_cursor_groupBox;
std::vector<cursor_distance_info> _cursor_disdance_list; std::vector<cursor_row_info> _dist_row_list;
std::vector<cursor_edge_info> _cursor_edge_list; std::vector<cursor_row_info> _edge_row_list;
std::vector<cursor_opt_info> _cursor_opt_list; std::vector<cursor_opt_info> _opt_row_list;
QLabel *_channel_label; QLabel *_channel_label;
QLabel *_edge_label; QLabel *_edge_label;