X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fheader.cpp;h=1c7903dbc372d38d55366b771c49fe3854de9bdf;hp=8fe9d485b761c5874625836b1aa469669bf135ba;hb=49f8ff3fd225c72934eca725eacffb12b6542ebf;hpb=ed6f0f4f84a26aadacfd4d3a745a8d7f1094efc5 diff --git a/pv/view/header.cpp b/pv/view/header.cpp index 8fe9d485..1c7903db 100644 --- a/pv/view/header.cpp +++ b/pv/view/header.cpp @@ -28,6 +28,8 @@ #include +#include +#include #include #include #include @@ -40,9 +42,13 @@ namespace view { Header::Header(View &parent) : QWidget(&parent), - _view(parent) + _view(parent), + _action_set_name(new QAction(tr("Set &Name..."), this)) { setMouseTracking(true); + + connect(_action_set_name, SIGNAL(triggered()), + this, SLOT(on_action_set_name_triggered())); } void Header::paintEvent(QPaintEvent *event) @@ -84,5 +90,47 @@ void Header::leaveEvent(QEvent *event) update(); } +void Header::contextMenuEvent(QContextMenuEvent *event) +{ + const int w = width(); + const vector< shared_ptr > &sigs = + _view.session().get_signals(); + + int offset = -_view.v_offset(); + BOOST_FOREACH(const shared_ptr s, sigs) + { + assert(s); + + const QRect signal_heading_rect( + 0, offset, w, View::SignalHeight); + + if(s->pt_in_label_rect(signal_heading_rect, _mouse_point)) { + QMenu menu(this); + menu.addAction(_action_set_name); + + _context_signal = s; + menu.exec(event->globalPos()); + _context_signal.reset(); + + break; + } + + offset += View::SignalHeight; + } +} + +void Header::on_action_set_name_triggered() +{ + boost::shared_ptr context_signal = _context_signal; + if(!context_signal) + return; + + const QString new_label = QInputDialog::getText(this, tr("Set Name"), + tr("Name"), QLineEdit::Normal, context_signal->get_name()); + + if(!new_label.isEmpty()) + context_signal->set_name(new_label); +} + } // namespace view } // namespace pv