X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Ftrace%2Fcursorpair.hpp;h=1dc66a32b8eef8bd622c199e75f9ddf09872dd65;hp=12a9d7ff7a7344b0154a30f8a61e2e078e6cb989;hb=ef85cfa4599d3741e7007921e39a44490e97cfaf;hpb=641574bcc118be0b6dc3a65039ab3497f9d7241a diff --git a/pv/views/trace/cursorpair.hpp b/pv/views/trace/cursorpair.hpp index 12a9d7ff..1dc66a32 100644 --- a/pv/views/trace/cursorpair.hpp +++ b/pv/views/trace/cursorpair.hpp @@ -21,10 +21,13 @@ #define PULSEVIEW_PV_VIEWS_TRACEVIEW_CURSORPAIR_HPP #include "cursor.hpp" +#include "pv/globalsettings.hpp" #include +#include #include +#include using std::pair; using std::shared_ptr; @@ -35,11 +38,14 @@ namespace pv { namespace views { namespace trace { -class CursorPair : public TimeItem +class View; + +class CursorPair : public TimeItem, public GlobalSettingsInterface { + Q_OBJECT + private: static const int DeltaPadding; - static const QColor ViewportFillColor; public: /** @@ -48,7 +54,8 @@ public: */ CursorPair(View &view); -public: + ~CursorPair(); + /** * Returns true if the item is visible and enabled. */ @@ -75,7 +82,6 @@ public: pv::widgets::Popup* create_popup(QWidget *parent) override; -public: QRectF label_rect(const QRectF &rect) const override; /** @@ -96,16 +102,23 @@ public: /** * Constructs the string to display. */ - QString format_string(); - - void compute_text_size(QPainter &p); + QString format_string(qreal max_width = 0, std::function query_size + = [](const QString& s) -> qreal { Q_UNUSED(s); return 0; }); pair get_cursor_offsets() const; + virtual void on_setting_changed(const QString &key, const QVariant &value) override; + +public Q_SLOTS: + void on_hover_point_changed(const QWidget* widget, const QPoint &hp); + private: shared_ptr first_, second_; + QColor fill_color_; QSizeF text_size_; + QRectF label_area_; + bool label_incomplete_; }; } // namespace trace