connect(&_view, SIGNAL(signals_moved()),
this, SLOT(on_signals_moved()));
+
+ // Trigger the initial event manually. The default device has signals
+ // which were created before this object came into being
+ on_signals_changed();
}
QSize Header::sizeHint() const
const vector< shared_ptr<Trace> > traces(_view.get_traces());
BOOST_FOREACH(shared_ptr<Trace> t, traces) {
assert(t);
- max_width = max(max_width, (int)t->get_label_rect(0).width());
+
+ if (t->enabled()) {
+ max_width = max(max_width, (int)t->get_label_rect(0).width());
+ }
}
return QSize(max_width + Padding, 0);
const int delta = event->pos().y() - _mouse_down_point.y();
- for (std::list<std::pair<boost::weak_ptr<Trace>,
- int> >::iterator i = _drag_traces.begin();
- i != _drag_traces.end(); i++) {
+ for (auto i = _drag_traces.begin(); i != _drag_traces.end(); i++) {
const boost::shared_ptr<Trace> trace((*i).first);
if (trace) {
const int y = (*i).second + delta;
BOOST_FOREACH(shared_ptr<Trace> t, traces) {
assert(t);
connect(t.get(), SIGNAL(visibility_changed()),
- this, SLOT(update()));
+ this, SLOT(on_trace_changed()));
connect(t.get(), SIGNAL(text_changed()),
- this, SLOT(on_trace_text_changed()));
+ this, SLOT(on_trace_changed()));
connect(t.get(), SIGNAL(colour_changed()),
this, SLOT(update()));
}
update();
}
-void Header::on_trace_text_changed()
+void Header::on_trace_changed()
{
update();
geometry_updated();