#include "timemarker.hpp"
#include "pv/widgets/timestampspinbox.hpp"
+#include "ruler.hpp"
#include "view.hpp"
#include <QApplication>
color_(color),
time_(time),
value_action_(nullptr),
- value_widget_(nullptr),
- updating_value_widget_(false)
+ value_widget_(nullptr)
{
}
-const pv::util::Timestamp& TimeMarker::time() const
+const pv::util::Timestamp TimeMarker::time() const
{
return time_;
}
time_ = time;
if (value_widget_) {
- updating_value_widget_ = true;
- value_widget_->setValue(view_.absolute_to_ruler_time(time));
- updating_value_widget_ = false;
+ QSignalBlocker blocker(value_widget_);
+ value_widget_->setValue(view_.ruler()->get_ruler_time_from_absolute_time(time));
}
view_.time_item_appearance_changed(true, true);
{
QFontMetrics m(QApplication::font());
const QSizeF text_size(
- max(m.boundingRect(get_text()).size().width(), ArrowSize),
+ max(m.boundingRect(get_display_text()).size().width(), ArrowSize),
m.height());
const QSizeF label_size(text_size + LabelPadding * 2);
const float top = rect.height() - label_size.height() -
return QRectF(x - h / 2.0f, pp.top(), h, pp.height());
}
+QString TimeMarker::get_display_text() const
+{
+ return get_text();
+}
+
+void TimeMarker::set_text(const QString &text)
+{
+ (void)text;
+}
+
void TimeMarker::paint_label(QPainter &p, const QRect &rect, bool hover)
{
if (!enabled())
p.drawPolygon(points, countof(points));
p.setPen(select_text_color(color_));
- p.drawText(r, Qt::AlignCenter | Qt::AlignVCenter, get_text());
+ p.drawText(r, Qt::AlignCenter | Qt::AlignVCenter, get_display_text());
}
void TimeMarker::paint_fore(QPainter &p, ViewItemPaintParams &pp)
popup->set_position(parent->mapToGlobal(
drag_point(parent->rect())), Popup::Bottom);
+ connect(popup, SIGNAL(closed()), this, SLOT(on_popup_closed()));
+
QFormLayout *const form = new QFormLayout(popup);
popup->setLayout(form);
value_widget_ = new pv::widgets::TimestampSpinBox(parent);
- value_widget_->setValue(view_.absolute_to_ruler_time(time_));
+ value_widget_->setValue(view_.ruler()->get_ruler_time_from_absolute_time(time_));
connect(value_widget_, SIGNAL(valueChanged(const pv::util::Timestamp&)),
this, SLOT(on_value_changed(const pv::util::Timestamp&)));
return popup;
}
+void TimeMarker::on_popup_closed()
+{
+ GlobalSettings settings;
+ if (!settings.value(GlobalSettings::Key_View_KeepRulerItemSelected).toBool())
+ select(false);
+}
+
void TimeMarker::on_value_changed(const pv::util::Timestamp& value)
{
- if (!updating_value_widget_)
- set_time(view_.ruler_to_absolute_time(value));
+ set_time(view_.ruler()->get_absolute_time_from_ruler_time(value));
}
} // namespace trace