X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Faudio_plot.h;h=9edabf8ec70b5cc605bfd932c07fb2b1e9083db0;hb=01e979c79f7d0aa20fac1bb24c699e0636168294;hp=580bc2d5a532f5b4ef2021a727305aad6b1772dc;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/wx/audio_plot.h b/src/wx/audio_plot.h index 580bc2d5a..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,36 +18,67 @@ */ -#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); void set_message (wxString); void set_gain_correction (double gain); + 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; @@ -55,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; };