X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Fruler.hpp;h=89b9ff4c801d22b009d30087fd4346d4db039689;hb=f052f9cde47e2c4ab8fd189eb2dc4e85adaf491d;hp=073c86c9e600533f66ae3389f99a7e29660ee8ec;hpb=361c560ed9ef67278916e086ed0b0649ae01b583;p=pulseview.git diff --git a/pv/view/ruler.hpp b/pv/view/ruler.hpp index 073c86c..89b9ff4 100644 --- a/pv/view/ruler.hpp +++ b/pv/view/ruler.hpp @@ -28,30 +28,65 @@ namespace pv { namespace view { +class TimeItem; + class Ruler : public MarginWidget { Q_OBJECT private: - static const int RulerHeight; + + /// Height of the ruler in multipes of the text height + static const float RulerHeight; + static const int MinorTickSubdivision; - static const int HoverArrowSize; + /// Height of the hover arrow in multiples of the text height + static const float HoverArrowSize; public: Ruler(View &parent); +public: + void clear_selection(); + public: QSize sizeHint() const; + /** + * The extended area that the header widget would like to be sized to. + * @remarks This area is the area specified by sizeHint, extended by + * the area to overlap the viewport. + */ + QSize extended_size_hint() const; + +private: + std::shared_ptr get_mouse_over_item( + const QPoint &pt); + private: void paintEvent(QPaintEvent *event); + void mouseMoveEvent(QMouseEvent *e); + void mousePressEvent(QMouseEvent *e); + void mouseReleaseEvent(QMouseEvent *); + void leaveEvent(QEvent*); + + void mouseDoubleClickEvent(QMouseEvent *e); + + void contextMenuEvent(QContextMenuEvent *event); + + void keyPressEvent(QKeyEvent *e); + private: /** * Draw a hover arrow under the cursor position. + * @param p The painter to draw into. + * @param text_height The height of a single text ascent. */ - void draw_hover_mark(QPainter &p); + void draw_hover_mark(QPainter &p, int text_height); + + int calculate_text_height() const; private Q_SLOTS: void hover_point_changed();