projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Logging improvements to allow prettier displays in the server GUI.
[dcpomatic.git]
/
src
/
lib
/
analyse_audio_job.h
diff --git
a/src/lib/analyse_audio_job.h
b/src/lib/analyse_audio_job.h
index 0a0be8fa055e48caad18252b4f84b54ff2107de8..d9b90ec668acc5c0ad090ad6139fe7c9efa4f6a9 100644
(file)
--- a/
src/lib/analyse_audio_job.h
+++ b/
src/lib/analyse_audio_job.h
@@
-1,5
+1,5
@@
/*
/*
- Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012
-2015
Carl Hetherington <cth@carlh.net>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@
-17,33
+17,53
@@
*/
*/
+/** @file src/lib/analyse_audio_job.h
+ * @brief AnalyseAudioJob class.
+ */
+
#include "job.h"
#include "job.h"
-#include "audio_
analysis
.h"
+#include "audio_
point
.h"
#include "types.h"
#include "types.h"
-#include "dcpomatic_time.h"
class AudioBuffers;
class AudioBuffers;
-class AudioContent;
+class AudioAnalysis;
+class Playlist;
+class AudioPoint;
+/** @class AnalyseAudioJob
+ * @brief A job to analyse the audio of a film and make a note of its
+ * broad peak and RMS levels.
+ *
+ * After computing the peak and RMS levels the job will write a file
+ * to Film::audio_analysis_path.
+ */
class AnalyseAudioJob : public Job
{
public:
class AnalyseAudioJob : public Job
{
public:
- AnalyseAudioJob (boost::shared_ptr<const Film>, boost::shared_ptr<AudioContent>);
+ AnalyseAudioJob (boost::shared_ptr<const Film>, boost::shared_ptr<const Playlist>);
+ ~AnalyseAudioJob ();
std::string name () const;
std::string json_name () const;
void run ();
std::string name () const;
std::string json_name () const;
void run ();
+ boost::shared_ptr<const Playlist> playlist () const {
+ return _playlist;
+ }
+
private:
private:
- void audio (boost::shared_ptr<const AudioBuffers>, DCPTime);
+ void analyse (boost::shared_ptr<const AudioBuffers>);
+
+ boost::shared_ptr<const Playlist> _playlist;
- boost::weak_ptr<AudioContent> _content;
int64_t _done;
int64_t _samples_per_point;
int64_t _done;
int64_t _samples_per_point;
- std::vector<AudioPoint> _current;
+ AudioPoint* _current;
+
+ float _overall_peak;
+ Frame _overall_peak_frame;
boost::shared_ptr<AudioAnalysis> _analysis;
static const int _num_points;
};
boost::shared_ptr<AudioAnalysis> _analysis;
static const int _num_points;
};
-