summaryrefslogtreecommitdiff
path: root/gtk2_ardour/export_report.h
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2016-02-15 16:34:16 +0100
committerRobin Gareus <robin@gareus.org>2016-02-15 16:34:16 +0100
commit7e59435ee872ded6d969360d22f3839ad2615c5b (patch)
treef0ce875d8fc433b25cb90cd5e10552c372e3871c /gtk2_ardour/export_report.h
parente6ea35c3de0c234a99443a05a131540dd821487c (diff)
update Export Report GUI
* show normalization gain * add annotation for spectrum * log-scale / rectified waveform
Diffstat (limited to 'gtk2_ardour/export_report.h')
-rw-r--r--gtk2_ardour/export_report.h131
1 files changed, 102 insertions, 29 deletions
diff --git a/gtk2_ardour/export_report.h b/gtk2_ardour/export_report.h
index 8474688c48..a509682808 100644
--- a/gtk2_ardour/export_report.h
+++ b/gtk2_ardour/export_report.h
@@ -18,6 +18,7 @@
#include <cairo/cairo.h>
#include <gtkmm/notebook.h>
+#include <gtkmm/togglebutton.h>
#include "gtkmm2ext/cairo_widget.h"
#include "gtkmm2ext/gui_thread.h"
@@ -32,37 +33,40 @@ public:
CimgArea (Cairo::RefPtr<Cairo::ImageSurface> sf)
: CairoWidget()
, _surface(sf)
- , _playhead(-1)
- , _x0 (0)
- , _aw (0)
- , _highlight (false)
{
set_size_request (sf->get_width (), sf->get_height ());
}
+protected:
+ virtual void background (cairo_t* cr, cairo_rectangle_t* r) {
+ cairo_set_source_surface (cr, _surface->cobj(), 0, 0);
+ cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
+ cairo_paint (cr);
+ }
+
+ virtual void overlay (cairo_t* cr, cairo_rectangle_t* r) {}
+
virtual void render (cairo_t* cr, cairo_rectangle_t* r)
{
cairo_rectangle (cr, r->x, r->y, r->width, r->height);
cairo_clip (cr);
- cairo_set_source_surface (cr, _surface->cobj(), 0, 0);
- cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
- cairo_paint (cr);
+ background (cr, r);
+ overlay (cr, r);
+ }
- if (_playhead > 0 && _playhead < 1.0 && _aw > 0) {
- if (_highlight) {
- cairo_rectangle (cr, _x0, 0, _aw, _surface->get_height());
- cairo_set_source_rgba (cr, .4, .4, .6, .4);
- cairo_fill (cr);
- }
+ Cairo::RefPtr<Cairo::ImageSurface> _surface;
+};
- const float x = _playhead * _aw;
- const float h = _surface->get_height();
- cairo_set_source_rgba (cr, 1, 0, 0, 1);
- cairo_set_line_width (cr, 1.5);
- cairo_move_to (cr, _x0 + x, 0);
- cairo_line_to (cr, _x0 + x, h);
- cairo_stroke (cr);
- }
+class CimgPlayheadArea : public CimgArea
+{
+public:
+ CimgPlayheadArea (Cairo::RefPtr<Cairo::ImageSurface> sf, float x0, float w, bool h = false)
+ : CimgArea (sf)
+ , _playhead(-1)
+ , _x0 (x0)
+ , _aw (w)
+ , _highlight (h)
+ {
}
void set_playhead (float pos) {
@@ -78,15 +82,28 @@ public:
_playhead = pos;
}
- void set_audition_axis (float x0, float w, bool h = false) {
- _x0 = x0;
- _aw = w;
- _highlight = h;
- }
-
sigc::signal<void, float> seek_playhead;
protected:
+
+ virtual void overlay (cairo_t* cr, cairo_rectangle_t* r) {
+ if (_playhead > 0 && _playhead < 1.0 && _aw > 0) {
+ if (_highlight) {
+ cairo_rectangle (cr, _x0, 0, _aw, _surface->get_height());
+ cairo_set_source_rgba (cr, .4, .4, .6, .4);
+ cairo_fill (cr);
+ }
+
+ const float x = _playhead * _aw;
+ const float h = _surface->get_height();
+ cairo_set_source_rgba (cr, 1, 0, 0, 1);
+ cairo_set_line_width (cr, 1.5);
+ cairo_move_to (cr, _x0 + x, 0);
+ cairo_line_to (cr, _x0 + x, h);
+ cairo_stroke (cr);
+ }
+ }
+
bool on_button_press_event (GdkEventButton *ev) {
CairoWidget::on_button_press_event (ev);
if (ev->button == 1 && _aw > 0 && ev->x >= _x0 && ev->x <= _x0 + _aw) {
@@ -96,7 +113,6 @@ protected:
}
private:
- Cairo::RefPtr<Cairo::ImageSurface> _surface;
float _playhead;
float _x0, _aw;
bool _highlight;
@@ -113,6 +129,60 @@ private:
}
};
+class CimgWaveArea : public CimgPlayheadArea
+{
+public:
+ CimgWaveArea (
+ Cairo::RefPtr<Cairo::ImageSurface> sf,
+ Cairo::RefPtr<Cairo::ImageSurface> sf_log,
+ Cairo::RefPtr<Cairo::ImageSurface> sf_rect,
+ Cairo::RefPtr<Cairo::ImageSurface> sf_logrec,
+ float x0, float w)
+ : CimgPlayheadArea (sf, x0, w)
+ , _sf_log (sf_log)
+ , _sf_rect (sf_rect)
+ , _sf_logrec (sf_logrec)
+ , _logscale (false)
+ , _rectified (false)
+ {
+ }
+
+ void set_logscale (Gtk::ToggleButton *b) {
+ bool en = b->get_active ();
+ _logscale = en;
+ set_dirty ();
+ }
+
+ void set_rectified (Gtk::ToggleButton *b) {
+ bool en = b->get_active ();
+ _rectified = en;
+ set_dirty ();
+ }
+
+protected:
+
+ virtual void background (cairo_t* cr, cairo_rectangle_t* r) {
+ if (_logscale && _rectified) {
+ cairo_set_source_surface (cr, _sf_logrec->cobj(), 0, 0);
+ } else if (_logscale) {
+ cairo_set_source_surface (cr, _sf_log->cobj(), 0, 0);
+ } else if (_rectified) {
+ cairo_set_source_surface (cr, _sf_rect->cobj(), 0, 0);
+ } else {
+ cairo_set_source_surface (cr, _surface->cobj(), 0, 0);
+ }
+ cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
+ cairo_paint (cr);
+ }
+
+private:
+ Cairo::RefPtr<Cairo::ImageSurface> _sf_log;
+ Cairo::RefPtr<Cairo::ImageSurface> _sf_rect;
+ Cairo::RefPtr<Cairo::ImageSurface> _sf_logrec;
+ bool _logscale;
+ bool _rectified;
+};
+
class ExportReport : public ArdourDialog
{
public:
@@ -121,6 +191,9 @@ public:
int run ();
private:
+ void draw_waveform (Cairo::RefPtr<Cairo::ImageSurface>& wave,
+ ARDOUR::ExportAnalysisPtr, uint32_t, int, size_t, int, int, bool, bool);
+
void open_folder (std::string);
void audition (std::string, unsigned int, int);
void stop_audition ();
@@ -144,7 +217,7 @@ private:
unsigned int channels;
};
- std::map<int, std::list<CimgArea*> > timeline;
+ std::map<int, std::list<CimgPlayheadArea*> > timeline;
std::map<int, AuditionInfo> files;
int _audition_num;