X-Git-Url: http://git.code-monkey.de/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fruler.hpp;h=d01b151243aeb2ea3c9a32ab8a3077cf20a76677;hp=50bbf2cdc0038075d8fbdea98cc0ba2b3af938fa;hb=4b0af0b67fe57e0880bcb8aa13b4fa807f3aaac0;hpb=17b1aa177651aae05bd94d3310ef7e8e25ec9899 diff --git a/pv/view/ruler.hpp b/pv/view/ruler.hpp index 50bbf2c..d01b151 100644 --- a/pv/view/ruler.hpp +++ b/pv/view/ruler.hpp @@ -21,9 +21,13 @@ #ifndef PULSEVIEW_PV_VIEW_RULER_HPP #define PULSEVIEW_PV_VIEW_RULER_HPP +#include #include +#include + #include "marginwidget.hpp" +#include namespace pv { namespace view { @@ -78,7 +82,6 @@ private: void mouseDoubleClickEvent(QMouseEvent *e); -private: /** * Draw a hover arrow under the cursor position. * @param p The painter to draw into. @@ -88,8 +91,45 @@ private: int calculate_text_height() const; + 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