#include "flag.hpp"
#include "rowitemowner.hpp"
+namespace sigrok {
+class ChannelGroup;
+}
+
namespace pv {
class Session;
class CursorHeader;
class Header;
class Ruler;
+class Trace;
class Viewport;
class View : public QAbstractScrollArea, public RowItemOwner {
static const double MinScale;
static const int MaxScrollValue;
+ static const int MaxViewAutoUpdateRate;
static const int ScaleUnits[3];
std::pair<double, double> get_time_extents() const;
+ /**
+ * Enables or disables sticky scrolling, i.e. the view always shows
+ * the most recent samples when capturing data.
+ */
+ void enable_sticky_scrolling(bool state);
+
/**
* Returns true if cursors are displayed. false otherwise.
*/
void scale_offset_changed();
+ void sticky_scrolling_changed(bool state);
+
private:
void get_scroll_layout(double &length, double &offset) const;
*/
QRectF label_rect(const QRectF &rect);
- static bool add_channels_to_owner(
+ RowItemOwner* find_prevalent_trace_group(
+ const std::shared_ptr<sigrok::ChannelGroup> &group,
+ const std::unordered_map<std::shared_ptr<sigrok::Channel>,
+ std::shared_ptr<Signal> > &signal_map);
+
+ static std::vector< std::shared_ptr<Trace> >
+ extract_new_traces_for_channels(
const std::vector< std::shared_ptr<sigrok::Channel> > &channels,
- RowItemOwner *owner, int &offset,
- std::unordered_map<std::shared_ptr<sigrok::Channel>,
+ const std::unordered_map<std::shared_ptr<sigrok::Channel>,
std::shared_ptr<Signal> > &signal_map,
- std::function<bool (std::shared_ptr<RowItem>)> filter_func =
- std::function<bool (std::shared_ptr<RowItem>)>());
-
- static void apply_offset(
- std::shared_ptr<RowItem> row_item, int &offset);
+ std::set< std::shared_ptr<Trace> > &add_list);
private:
bool eventFilter(QObject *object, QEvent *event);
void signals_changed();
void data_updated();
+ void perform_delayed_view_update();
+
void process_sticky_events();
void on_hover_point_changed();
double offset_;
bool updating_scroll_;
+ bool sticky_scrolling_;
+ QTimer delayed_view_updater_;
double tick_period_;
unsigned int tick_prefix_;