namespace pv {
namespace view {
-const QPen Signal::SignalAxisPen(QColor(128, 128, 128, 64));
-
const char *const ProbeNames[] = {
"CLK",
"DATA",
"SCL"
};
-Signal::Signal(pv::SigSession &session, const sr_probe *const probe) :
+Signal::Signal(pv::SigSession &session, sr_probe *const probe) :
Trace(session, probe->name),
_probe(probe),
- _name_action(NULL),
_name_widget(NULL),
_updating_name_widget(false)
{
assert(_probe);
}
-void Signal::init_context_bar_actions(QWidget *parent)
-{
- _name_widget = new QComboBox(parent);
- _name_widget->setEditable(true);
-
- _name_action = new QWidgetAction(parent);
- _name_action->setDefaultWidget(_name_widget);
-
- for(unsigned int i = 0; i < countof(ProbeNames); i++)
- _name_widget->insertItem(i, ProbeNames[i]);
- _name_widget->setEditText(_probe->name);
-
- connect(_name_widget, SIGNAL(editTextChanged(const QString&)),
- this, SLOT(on_text_changed(const QString&)));
-}
-
void Signal::set_name(QString name)
{
Trace::set_name(name);
return _probe->enabled;
}
-const sr_probe* Signal::probe() const
+void Signal::enable(bool enable)
{
- return _probe;
+ _probe->enabled = enable;
+ visibility_changed();
}
-void Signal::paint_axis(QPainter &p, int y, int left, int right)
+const sr_probe* Signal::probe() const
{
- p.setPen(SignalAxisPen);
- p.drawLine(QPointF(left, y + 0.5f), QPointF(right, y + 0.5f));
+ return _probe;
}
-void Signal::on_text_changed(const QString &text)
+void Signal::populate_popup_form(QWidget *parent, QFormLayout *form)
{
- Trace::set_name(text);
- text_changed();
+ _name_widget = new QComboBox(parent);
+ _name_widget->setEditable(true);
+
+ for(unsigned int i = 0; i < countof(ProbeNames); i++)
+ _name_widget->insertItem(i, ProbeNames[i]);
+ _name_widget->setEditText(_probe->name);
+
+ connect(_name_widget, SIGNAL(editTextChanged(const QString&)),
+ this, SLOT(on_text_changed(const QString&)));
+
+ form->addRow(tr("Name"), _name_widget);
+
+ add_colour_option(parent, form);
}
} // namespace view