2 Copyright (C) 2009 Paul Davis
3 Author: David Robillard
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 $Id: midiregion.h 733 2006-08-01 17:19:38Z drobilla $
22 #include "temporal/beats.h"
23 #include "evoral/TimeConverter.hpp"
25 #include "ardour/libardour_visibility.h"
26 #include "ardour/types.h"
28 #ifndef __ardour_beats_samples_converter_h__
29 #define __ardour_beats_samples_converter_h__
35 /** Converter between quarter-note beats and samples. Takes distances in quarter-note beats or samples
36 * from some origin (supplied to the constructor in samples), and converts
37 * them to the opposite unit, taking tempo changes into account.
39 class LIBARDOUR_API BeatsSamplesConverter
40 : public Evoral::TimeConverter<Temporal::Beats,samplepos_t> {
42 BeatsSamplesConverter (const TempoMap& tempo_map, samplepos_t origin)
43 : Evoral::TimeConverter<Temporal::Beats, samplepos_t> (origin)
44 , _tempo_map(tempo_map)
47 samplepos_t to (Temporal::Beats beats) const;
48 Temporal::Beats from (samplepos_t samples) const;
51 const TempoMap& _tempo_map;
54 /** Converter between quarter-note beats and samples. Takes distances in quarter-note beats or samples
55 * from some origin (supplied to the constructor in samples), and converts
56 * them to the opposite unit, taking tempo changes into account.
58 class LIBARDOUR_API DoubleBeatsSamplesConverter
59 : public Evoral::TimeConverter<double,samplepos_t> {
61 DoubleBeatsSamplesConverter (const TempoMap& tempo_map, samplepos_t origin)
62 : Evoral::TimeConverter<double, samplepos_t> (origin)
63 , _tempo_map(tempo_map)
66 samplepos_t to (double beats) const;
67 double from (samplepos_t samples) const;
70 const TempoMap& _tempo_map;
73 } /* namespace ARDOUR */
75 #endif /* __ardour_beats_samples_converter_h__ */