void Session::signal_new_segment()
{
- int new_segment_id = 1;
+ int new_segment_id = 0;
if ((cur_logic_segment_ != nullptr) || !cur_analog_segments_.empty()) {
// Determine new frame/segment number, assuming that all
// signals have the same number of frames/segments
if (cur_logic_segment_) {
- new_segment_id = logic_data_->get_segment_count();
+ new_segment_id = logic_data_->get_segment_count() - 1;
} else {
shared_ptr<sigrok::Channel> any_channel =
(*cur_analog_segments_.begin()).first;
shared_ptr<data::Analog> data(base->analog_data());
assert(data);
- new_segment_id = data->get_segment_count();
+ new_segment_id = data->get_segment_count() - 1;
}
}
try {
segment = segments.at(current_segment_);
} catch (out_of_range) {
- qDebug() << "Current analog segment out of range for signal" << base_->name();
+ qDebug() << "Current analog segment out of range for signal" << base_->name() << ":" << current_segment_;
}
}
}
try {
segment = segments.at(current_segment_);
} catch (out_of_range) {
- qDebug() << "Current logic segment out of range for signal" << base_->name();
+ qDebug() << "Current logic segment out of range for signal" << base_->name() << ":" << current_segment_;
}
}
}
segment_selector_->hide();
connect(&session_, SIGNAL(new_segment(int)),
this, SLOT(on_new_segment(int)));
+
connect(segment_selector_, SIGNAL(valueChanged(int)),
- view_, SLOT(on_segment_changed(int)));
+ this, SLOT(on_segment_selected(int)));
connect(view_, SIGNAL(segment_changed(int)),
this, SLOT(on_segment_changed(int)));
+
+ connect(this, SIGNAL(segment_selected(int)),
+ view_, SLOT(on_segment_changed(int)));
+
connect(view_, SIGNAL(segment_display_mode_changed(bool)),
this, SLOT(on_segment_display_mode_changed(bool)));
{
if (new_segment_id > 1) {
show_multi_segment_ui(true);
- segment_selector_->setMaximum(new_segment_id);
+ segment_selector_->setMaximum(new_segment_id + 1);
} else
show_multi_segment_ui(false);
}
{
// This is called when the current segment was changed
// by other parts of the UI, e.g. the view itself
- segment_selector_->setValue(segment_id);
+
+ // We need to adjust the value by 1 because internally, segments
+ // start at 0 while they start with 1 for the spinbox
+ segment_selector_->setValue(segment_id + 1);
+
+ segment_selected(segment_id);
+}
+
+void StandardBar::on_segment_selected(int ui_segment_id)
+{
+ // This is called when the user selected a segment using the spin box
+
+ // We need to adjust the value by 1 because internally, segments
+ // start at 0 while they start with 1 for the spinbox
+ segment_selected(ui_segment_id - 1);
}
void StandardBar::on_segment_display_mode_changed(bool segment_selectable)