X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fdecodesignal.cpp;h=32307e9c99dcf5d739205df177d904af5bf05ff0;hp=bc37b2019819c8c54b046467da6fc1a239b24a8e;hb=b213ef0991a13af0c74ffe5c54382c5c455c5496;hpb=fe08b6e8a85c80ae738757f7d85aa38ef7c4bdc3 diff --git a/pv/view/decodesignal.cpp b/pv/view/decodesignal.cpp index bc37b201..32307e9c 100644 --- a/pv/view/decodesignal.cpp +++ b/pv/view/decodesignal.cpp @@ -22,8 +22,16 @@ extern "C" { #include } +#include + +#include + +#include +#include + #include "decodesignal.h" +#include #include #include #include @@ -34,19 +42,24 @@ using namespace std; namespace pv { namespace view { +const QColor DecodeSignal::DecodeColours[4] = { + QColor(0xEF, 0x29, 0x29), // Red + QColor(0xFC, 0xE9, 0x4F), // Yellow + QColor(0x8A, 0xE2, 0x34), // Green + QColor(0x72, 0x9F, 0xCF) // Blue +}; + DecodeSignal::DecodeSignal(pv::SigSession &session, - boost::shared_ptr decoder) : + boost::shared_ptr decoder, int index) : Trace(session, QString(decoder->get_decoder()->name)), _decoder(decoder) { assert(_decoder); - _colour = Qt::red; -} + _colour = DecodeColours[index % countof(DecodeColours)]; -void DecodeSignal::init_context_bar_actions(QWidget *parent) -{ - (void)parent; + connect(_decoder.get(), SIGNAL(new_decode_data()), + this, SLOT(on_new_decode_data())); } bool DecodeSignal::enabled() const @@ -89,14 +102,39 @@ void DecodeSignal::paint_mid(QPainter &p, int left, int right) vector< shared_ptr > annotations(_decoder->annotations()); BOOST_FOREACH(shared_ptr a, annotations) { assert(a); - a->paint(p, left, right, samples_per_pixel, pixels_offset, y); + a->paint(p, get_text_colour(), _text_size.height(), + left, right, samples_per_pixel, pixels_offset, y); } } -const list DecodeSignal::get_context_bar_actions() +QMenu* DecodeSignal::create_context_menu(QWidget *parent) +{ + QMenu *const menu = Trace::create_context_menu(parent); + + menu->addSeparator(); + + 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 DecodeSignal::on_new_decode_data() +{ + if (_view) + _view->update_viewport(); +} + +void DecodeSignal::delete_pressed() +{ + on_delete(); +} + +void DecodeSignal::on_delete() { - list actions; - return actions; + _session.remove_decode_signal(this); } } // namespace view