X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Faudio_plot.h;h=9edabf8ec70b5cc605bfd932c07fb2b1e9083db0;hb=31de5b1272d928557a7272977584f5dcc9876c75;hp=2f4b224e853854cc295321982da7e4606a776422;hpb=0c54ae8d45449b20afda7a3bc006a90ed0c6952a;p=dcpomatic.git diff --git a/src/wx/audio_plot.h b/src/wx/audio_plot.h index 2f4b224e8..9edabf8ec 100644 --- a/src/wx/audio_plot.h +++ b/src/wx/audio_plot.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2015 Carl Hetherington + Copyright (C) 2012-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -18,20 +18,24 @@ */ -#include -#include -#include #include "lib/util.h" #include "lib/audio_analysis.h" +#include "lib/warnings.h" +DCPOMATIC_DISABLE_WARNINGS +#include +DCPOMATIC_ENABLE_WARNINGS +#include +#include struct Metrics; +class FilmViewer; class AudioPlot : public wxPanel { public: - AudioPlot (wxWindow *); + explicit AudioPlot (wxWindow *, std::weak_ptr viewer); - void set_analysis (boost::shared_ptr); + void set_analysis (std::shared_ptr); void set_channel_visible (int c, bool v); void set_type_visible (int t, bool v); void set_smoothing (int); @@ -40,16 +44,41 @@ public: wxColour colour (int n) const; + boost::signals2::signal, boost::optional)> Cursor; + static const int max_smoothing; private: + + struct Point { + Point () + : db(0) + {} + + Point (wxPoint draw_, dcpomatic::DCPTime time_, float db_) + : draw(draw_) + , time(time_) + , db(db_) + {} + + wxPoint draw; + dcpomatic::DCPTime time; + float db; + }; + + typedef std::vector PointList; + void paint (); void plot_peak (wxGraphicsPath &, int, Metrics const &) const; void plot_rms (wxGraphicsPath &, int, Metrics const &) const; float y_for_linear (float, Metrics const &) const; AudioPoint get_point (int channel, int point) const; + void left_down (); + void mouse_moved (wxMouseEvent& ev); + void mouse_leave (wxMouseEvent& ev); - boost::shared_ptr _analysis; + std::weak_ptr _viewer; + std::shared_ptr _analysis; bool _channel_visible[MAX_DCP_AUDIO_CHANNELS]; bool _type_visible[AudioPoint::COUNT]; int _smoothing; @@ -57,5 +86,13 @@ private: wxString _message; float _gain_correction; + /** peak values keyed by channel */ + mutable std::map _peak; + /** RMS values keyed by channel */ + mutable std::map _rms; + + boost::optional _cursor; + static const int _minimum; + static const int _cursor_size; };