]> sigrok.org Git - pulseview.git/blobdiff - pv/view/timemarker.cpp
Don't attempt to set the value if TimeMarker::_value_widget has not been created
[pulseview.git] / pv / view / timemarker.cpp
index 9d4c43c21d2321f0ad20526075b1ace4dbeb5be7..e40c393ba6e629e32724f9cba1c382bf4d48a5a3 100644 (file)
@@ -29,11 +29,13 @@ using namespace std;
 namespace pv {
 namespace view {
 
-TimeMarker::TimeMarker(const View &view, const QColor &colour,
-       double time) :
+TimeMarker::TimeMarker(View &view, const QColor &colour, double time) :
        _view(view),
        _colour(colour),
-       _time(time)
+       _time(time),
+       _value_action(NULL),
+       _value_widget(NULL),
+       _updating_value_widget(false)
 {
 }
 
@@ -45,6 +47,13 @@ double TimeMarker::time() const
 void TimeMarker::set_time(double time)
 {
        _time = time;
+
+       if (_value_widget) {
+               _updating_value_widget = true;
+               _value_widget->setValue(time);
+               _updating_value_widget = false;
+       }
+
        time_changed();
 }
 
@@ -55,10 +64,12 @@ void TimeMarker::paint(QPainter &p, const QRect &rect)
        p.drawLine(QPointF(x, rect.top()), QPointF(x, rect.bottom()));
 }
 
-const list<QAction*> TimeMarker::get_context_bar_actions()
+void TimeMarker::on_value_changed(double value)
 {
-       list<QAction*> actions;
-       return actions;
+       if (!_updating_value_widget) {
+               _time = value;
+               time_changed();
+       }
 }
 
 } // namespace view