X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fflag.cpp;h=779ea2eec24cd8d5088b2675f9ede6978c682ba1;hp=53b0feefa07b77c4ecce071b99358490a4fe6012;hb=34ec096859764f71c210ec7c271fcac2b96374cc;hpb=8914fe790fb677c56194a3ae4da06ba671fca78a diff --git a/pv/view/flag.cpp b/pv/view/flag.cpp index 53b0feef..779ea2ee 100644 --- a/pv/view/flag.cpp +++ b/pv/view/flag.cpp @@ -24,8 +24,9 @@ #include #include #include +#include -#include +#include #include @@ -36,14 +37,15 @@ namespace view { const QColor Flag::FillColour(0x73, 0xD2, 0x16); -Flag::Flag(View &view, double time, const QString &text) : +Flag::Flag(View &view, const pv::util::Timestamp& time, const QString &text) : TimeMarker(view, FillColour, time), text_(text) { } Flag::Flag(const Flag &flag) : - TimeMarker(flag.view_, FillColour, flag.time_) + TimeMarker(flag.view_, FillColour, flag.time_), + std::enable_shared_from_this(flag) { } @@ -59,7 +61,12 @@ QString Flag::get_text() const pv::widgets::Popup* Flag::create_popup(QWidget *parent) { - pv::widgets::Popup *const popup = TimeMarker::create_popup(parent); + using pv::widgets::Popup; + + Popup *const popup = TimeMarker::create_popup(parent); + popup->set_position(parent->mapToGlobal( + point(parent->rect())), Popup::Bottom); + QFormLayout *const form = (QFormLayout*)popup->layout(); QLineEdit *const text_edit = new QLineEdit(popup); @@ -73,6 +80,28 @@ pv::widgets::Popup* Flag::create_popup(QWidget *parent) return popup; } +QMenu* Flag::create_context_menu(QWidget *parent) +{ + QMenu *const menu = new QMenu(parent); + + QAction *const del = new QAction(tr("Delete"), this); + del->setShortcuts(QKeySequence::Delete); + connect(del, SIGNAL(triggered()), this, SLOT(on_delete())); + menu->addAction(del); + + return menu; +} + +void Flag::delete_pressed() +{ + on_delete(); +} + +void Flag::on_delete() +{ + view_.remove_flag(shared_ptr(shared_from_this())); +} + void Flag::on_text_changed(const QString &text) { text_ = text;