X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Fruler.hpp;h=d01b151243aeb2ea3c9a32ab8a3077cf20a76677;hb=4b0af0b67fe57e0880bcb8aa13b4fa807f3aaac0;hp=e47c424ae6b53168535a37d6cfe68a835e6de0a4;hpb=819e2e95555b2b3c2190f24a3cfa82250d1f34e5;p=pulseview.git diff --git a/pv/view/ruler.hpp b/pv/view/ruler.hpp index e47c424..d01b151 100644 --- a/pv/view/ruler.hpp +++ b/pv/view/ruler.hpp @@ -18,42 +18,40 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PULSEVIEW_PV_VIEW_RULER_H -#define PULSEVIEW_PV_VIEW_RULER_H +#ifndef PULSEVIEW_PV_VIEW_RULER_HPP +#define PULSEVIEW_PV_VIEW_RULER_HPP +#include #include +#include + #include "marginwidget.hpp" +#include namespace pv { namespace view { class TimeItem; +class ViewItem; class Ruler : public MarginWidget { Q_OBJECT private: - static const int RulerHeight; - static const int MinorTickSubdivision; - static const int HoverArrowSize; + /// Height of the ruler in multipes of the text height + static const float RulerHeight; - static const int Padding; + static const int MinorTickSubdivision; - /** - * The vertical offset, relative to the bottom line of the widget, - * where the arrows of the cursor labels end. - */ - static const int BaselineOffset; + /// 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; @@ -65,34 +63,76 @@ public: QSize extended_size_hint() const; private: - void paintEvent(QPaintEvent *event); + /** + * Gets the time items. + */ + std::vector< std::shared_ptr > items(); - void mouseMoveEvent(QMouseEvent *e); - void mousePressEvent(QMouseEvent *e); - void mouseReleaseEvent(QMouseEvent *); - void leaveEvent(QEvent*); + /** + * Gets the first view item which has a label that contains @c pt . + * @param pt the point to search with. + * @return the view item that has been found, or and empty + * @c shared_ptr if no item was found. + */ + std::shared_ptr get_mouse_over_item( + const QPoint &pt); - void mouseDoubleClickEvent(QMouseEvent *e); +private: + void paintEvent(QPaintEvent *event); - void keyPressEvent(QKeyEvent *e); + void mouseDoubleClickEvent(QMouseEvent *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(); + int calculate_text_height() const; -private: - std::shared_ptr mouse_down_item_; - const int text_height_; + struct TickPositions + { + std::vector> major; + std::vector minor; + }; + + /** + * Holds the tick positions so that they don't have to be recalculated on + * every redraw. Set by 'paintEvent()' when needed. + */ + boost::optional tick_position_cache_; + + /** + * Calculates the major and minor tick positions. + * + * @param major_period The period between the major ticks. + * @param offset The time at the left border of the ruler. + * @param scale The scale in seconds per pixel. + * @param width the Width of the ruler. + * @param format_function A function used to format the major tick times. + * @return An object of type 'TickPositions' that contains the major tick + * positions together with the labels at that ticks, and the minor + * tick positions. + */ + static TickPositions calculate_tick_positions( + const double major_period, + const pv::util::Timestamp& offset, + const double scale, + const int width, + std::function format_function); + +protected: + void resizeEvent(QResizeEvent*) override; private Q_SLOTS: void hover_point_changed(); + + // Resets the 'tick_position_cache_'. + void invalidate_tick_position_cache(); }; } // namespace view } // namespace pv -#endif // PULSEVIEW_PV_VIEW_RULER_H +#endif // PULSEVIEW_PV_VIEW_RULER_HPP