diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2010-12-14 20:28:37 +0000 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2010-12-14 20:28:37 +0000 |
commit | f09524b9d30115e51294edc3af4399194f8478f1 (patch) | |
tree | 7c3bb83e413f790fac39b0d7c9a7e31ae279d5d2 /libs/timecode | |
parent | ee5a37a306babadc81ac4a2612b260dc612a381a (diff) |
move ticks per beat from Meter to Timecode::BBT_Time, add new constructor for BBT_Time based on a double value; reduce BeatFramesConverted to 1 liners pending likely removal
git-svn-id: svn://localhost/ardour2/branches/3.0@8277 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/timecode')
-rw-r--r-- | libs/timecode/src/bbt_time.cc | 37 | ||||
-rw-r--r-- | libs/timecode/timecode/bbt_time.h | 4 | ||||
-rw-r--r-- | libs/timecode/wscript | 2 |
3 files changed, 42 insertions, 1 deletions
diff --git a/libs/timecode/src/bbt_time.cc b/libs/timecode/src/bbt_time.cc new file mode 100644 index 0000000000..43b65c218b --- /dev/null +++ b/libs/timecode/src/bbt_time.cc @@ -0,0 +1,37 @@ +/* + Copyright (C) 2002-2010 Paul Davis + + This program is free software; you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as published by + the Free Software Foundation; either version 2 of the License, or (at your + option) any later version. + + This program is distributed in the hope that it will be useful, but WITHOUT + ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public + License for more details. + + You should have received a copy of the GNU Lesser General Public License + along with this program; if not, write to the Free Software Foundation, + Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +*/ + +#include <cmath> + +#include "timecode/bbt_time.h" + +using namespace Timecode; + +const double BBT_Time::ticks_per_beat = 1920.0; + +BBT_Time::BBT_Time (double beats) +{ + /* NOTE: this does not construct a BBT time in a canonical form, + in that beats may be a very large number, and bars will + always be zero. + */ + + bars = 0; + beats = rint (floor (beats)); + ticks = rint (floor (BBT_Time::ticks_per_beat * fmod (beats, 1.0))); +} diff --git a/libs/timecode/timecode/bbt_time.h b/libs/timecode/timecode/bbt_time.h index a388a2a073..226a2fc894 100644 --- a/libs/timecode/timecode/bbt_time.h +++ b/libs/timecode/timecode/bbt_time.h @@ -27,6 +27,8 @@ namespace Timecode { /** Bar, Beat, Tick Time (i.e. Tempo-Based Time) */ struct BBT_Time { + static const double ticks_per_beat; + uint32_t bars; uint32_t beats; uint32_t ticks; @@ -36,6 +38,8 @@ struct BBT_Time { BBT_Time (uint32_t ba, uint32_t be, uint32_t t) : bars (ba), beats (be), ticks (t) {} + + BBT_Time (double beats); bool operator< (const BBT_Time& other) const { return bars < other.bars || diff --git a/libs/timecode/wscript b/libs/timecode/wscript index efdc814053..4eb3c66c8f 100644 --- a/libs/timecode/wscript +++ b/libs/timecode/wscript @@ -33,7 +33,7 @@ def configure(conf): def build(bld): # Library obj = bld.new_task_gen('cxx', 'shlib') - obj.source = 'src/time.cc' + obj.source = [ 'src/time.cc', 'src/bbt_time.cc' ] obj.export_incdirs = ['.'] obj.includes = ['.', './src'] obj.name = 'libtimecode' |