X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_analysis.cc;h=73422a9be9ad8a2f3a6039d7487c284ddfe4f8bf;hb=a193afb89de3e335612e07a3fbec3e4095f14f98;hp=b29ed1707d0e01d8d8aaa08c7ab0a27019b0c446;hpb=6e0f2a39c9deeb51f05c0c8c9bd46632c2c6483a;p=dcpomatic.git diff --git a/src/lib/audio_analysis.cc b/src/lib/audio_analysis.cc index b29ed1707..73422a9be 100644 --- a/src/lib/audio_analysis.cc +++ b/src/lib/audio_analysis.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2015 Carl Hetherington 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,20 +17,27 @@ */ +#include "audio_analysis.h" +#include "cross.h" +#include "util.h" +#include "raw_convert.h" +#include +#include +#include #include #include -#include -#include -#include -#include "audio_analysis.h" +#include +#include +#include using std::ostream; using std::istream; using std::string; -using std::ofstream; -using std::ifstream; using std::vector; using std::cout; +using std::max; +using std::list; +using boost::shared_ptr; AudioPoint::AudioPoint () { @@ -39,55 +46,75 @@ AudioPoint::AudioPoint () } } -AudioPoint::AudioPoint (istream& s) +AudioPoint::AudioPoint (cxml::ConstNodePtr node) +{ + _data[PEAK] = node->number_child ("Peak"); + _data[RMS] = node->number_child ("RMS"); +} + +AudioPoint::AudioPoint (AudioPoint const & other) { for (int i = 0; i < COUNT; ++i) { - s >> _data[i]; + _data[i] = other._data[i]; } } -void -AudioPoint::write (ostream& s) const +AudioPoint & +AudioPoint::operator= (AudioPoint const & other) { + if (this == &other) { + return *this; + } + for (int i = 0; i < COUNT; ++i) { - s << _data[i] << "\n"; + _data[i] = other._data[i]; } + + return *this; } - +void +AudioPoint::as_xml (xmlpp::Element* parent) const +{ + parent->add_child ("Peak")->add_child_text (raw_convert (_data[PEAK])); + parent->add_child ("RMS")->add_child_text (raw_convert (_data[RMS])); +} + AudioAnalysis::AudioAnalysis (int channels) { _data.resize (channels); } -AudioAnalysis::AudioAnalysis (string filename) +AudioAnalysis::AudioAnalysis (boost::filesystem::path filename) { - ifstream f (filename.c_str ()); + cxml::Document f ("AudioAnalysis"); + f.read_file (filename); - int channels; - f >> channels; - _data.resize (channels); + BOOST_FOREACH (cxml::NodePtr i, f.node_children ("Channel")) { + vector channel; - for (int i = 0; i < channels; ++i) { - int points; - f >> points; - for (int j = 0; j < points; ++j) { - _data[i].push_back (AudioPoint (f)); + BOOST_FOREACH (cxml::NodePtr j, i->node_children ("Point")) { + channel.push_back (AudioPoint (j)); } + + _data.push_back (channel); } + + _peak = f.number_child ("Peak"); + _peak_time = DCPTime (f.number_child ("PeakTime")); } void AudioAnalysis::add_point (int c, AudioPoint const & p) { - assert (c < channels ()); + DCPOMATIC_ASSERT (c < channels ()); _data[c].push_back (p); } AudioPoint AudioAnalysis::get_point (int c, int p) const { - assert (p < points (c)); + DCPOMATIC_ASSERT (p < points (c)); return _data[c][p]; } @@ -100,24 +127,27 @@ AudioAnalysis::channels () const int AudioAnalysis::points (int c) const { - assert (c < channels ()); + DCPOMATIC_ASSERT (c < channels ()); return _data[c].size (); } void -AudioAnalysis::write (string filename) +AudioAnalysis::write (boost::filesystem::path filename) { - string tmp = filename + ".tmp"; - - ofstream f (tmp.c_str ()); - f << _data.size() << "\n"; - for (vector >::iterator i = _data.begin(); i != _data.end(); ++i) { - f << i->size () << "\n"; - for (vector::iterator j = i->begin(); j != i->end(); ++j) { - j->write (f); + shared_ptr doc (new xmlpp::Document); + xmlpp::Element* root = doc->create_root_node ("AudioAnalysis"); + + BOOST_FOREACH (vector& i, _data) { + xmlpp::Element* channel = root->add_child ("Channel"); + BOOST_FOREACH (AudioPoint& j, i) { + j.as_xml (channel->add_child ("Point")); } } - f.close (); - boost::filesystem::rename (tmp, filename); + if (_peak) { + root->add_child("Peak")->add_child_text (raw_convert (_peak.get ())); + root->add_child("PeakTime")->add_child_text (raw_convert (_peak_time.get().get ())); + } + + doc->write_to_file_formatted (filename.string ()); }