X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fview.cpp;h=f8b0fc4537ef71b83d0be751fbd6ddee564bd198;hp=42a2f79f0b22e96b45340c67aef0eabaa0c8957d;hb=9a2bc5fcb8ad1e9c7885429609656316f9ad006b;hpb=4e5a4405482a296ebb6014e627298ad156c78d55 diff --git a/pv/view/view.cpp b/pv/view/view.cpp index 42a2f79f..f8b0fc45 100644 --- a/pv/view/view.cpp +++ b/pv/view/view.cpp @@ -24,13 +24,15 @@ #include #include +#include + #include #include #include #include -#include "decodesignal.h" +#include "decodetrace.h" #include "header.h" #include "ruler.h" #include "signal.h" @@ -153,6 +155,43 @@ void View::zoom(double steps, int offset) set_scale_offset(new_scale, new_offset); } +void View::zoom_fit() +{ + using pv::data::SignalData; + + const vector< shared_ptr > sigs( + session().get_signals()); + + // Make a set of all the visible data objects + set< shared_ptr > visible_data; + BOOST_FOREACH(const shared_ptr sig, sigs) + if (sig->enabled()) + visible_data.insert(sig->data()); + + if (visible_data.empty()) + return; + + double left_time = DBL_MAX, right_time = DBL_MIN; + BOOST_FOREACH(const shared_ptr d, visible_data) + { + const double start_time = d->get_start_time(); + left_time = min(left_time, start_time); + right_time = max(right_time, start_time + + d->get_max_sample_count() / d->samplerate()); + } + + assert(left_time < right_time); + if (right_time - left_time < 1e-12) + return; + + assert(_viewport); + const int w = _viewport->width(); + if (w <= 0) + return; + + set_scale_offset((right_time - left_time) / w, left_time); +} + void View::set_scale_offset(double scale, double offset) { _scale = scale; @@ -168,7 +207,7 @@ vector< shared_ptr > View::get_traces() const { const vector< shared_ptr > sigs( session().get_signals()); - const vector< shared_ptr > decode_sigs( + const vector< shared_ptr > decode_sigs( session().get_decode_signals()); vector< shared_ptr > traces( sigs.size() + decode_sigs.size()); @@ -177,7 +216,7 @@ vector< shared_ptr > View::get_traces() const i = copy(sigs.begin(), sigs.end(), i); i = copy(decode_sigs.begin(), decode_sigs.end(), i); - sort(traces.begin(), traces.end(), compare_trace_v_offsets); + stable_sort(traces.begin(), traces.end(), compare_trace_v_offsets); return traces; } @@ -266,7 +305,7 @@ void View::get_scroll_layout(double &length, double &offset) const if (!sig_data) return; - length = _data_length / (sig_data->get_samplerate() * _scale); + length = _data_length / (sig_data->samplerate() * _scale); offset = _offset / _scale; }