X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fbeats_frames_converter.cc;h=54db8008da2c4fcabacaba0d0da64963952da040;hb=6894f468d4e5fcd6624368f7a7f820a9fcaa4455;hp=10a1d443214074eadd800211985c7918e3934a49;hpb=0906b39918ba0551044bd1f8c50e9de4d5aa1694;p=ardour.git diff --git a/libs/ardour/beats_frames_converter.cc b/libs/ardour/beats_frames_converter.cc index 10a1d44321..54db8008da 100644 --- a/libs/ardour/beats_frames_converter.cc +++ b/libs/ardour/beats_frames_converter.cc @@ -19,22 +19,56 @@ $Id: midiregion.h 733 2006-08-01 17:19:38Z drobilla $ */ +#include "pbd/stacktrace.h" + #include "ardour/beats_frames_converter.h" #include "ardour/tempo.h" namespace ARDOUR { -framecnt_t -BeatsFramesConverter::to (double beats) const +/** Takes a positive duration in beats and considers it as a distance from the origin + * supplied to the constructor. Returns the equivalent number of frames, + * taking tempo changes into account. + */ +framepos_t +BeatsFramesConverter::to (Evoral::Beats beats) const { - return _tempo_map.framepos_plus_bbt (_origin_b, Timecode::BBT_Time(beats)) - _origin_b; + if (beats < Evoral::Beats()) { + std::cerr << "negative beats passed to BFC: " << beats << std::endl; + PBD::stacktrace (std::cerr, 30); + return 0; + } + return _tempo_map.framepos_plus_beats (_origin_b, beats) - _origin_b; } -double -BeatsFramesConverter::from (framecnt_t frames) const +/** Takes a duration in frames and considers it as a distance from the origin + * supplied to the constructor. Returns the equivalent number of beats, + * taking tempo changes into account. + */ +Evoral::Beats +BeatsFramesConverter::from (framepos_t frames) const { return _tempo_map.framewalk_to_beats (_origin_b, frames); } +/** As above, but with beats in double instead (for GUI). */ +framepos_t +DoubleBeatsFramesConverter::to (double beats) const +{ + if (beats < 0.0) { + std::cerr << "negative beats passed to BFC: " << beats << std::endl; + PBD::stacktrace (std::cerr, 30); + return 0; + } + return _tempo_map.framepos_plus_beats (_origin_b, Evoral::Beats(beats)) - _origin_b; +} + +/** As above, but with beats in double instead (for GUI). */ +double +DoubleBeatsFramesConverter::from (framepos_t frames) const +{ + return _tempo_map.framewalk_to_beats (_origin_b, frames).to_double(); +} + } /* namespace ARDOUR */