#include <vector>
-#include "evoral/Beats.hpp"
+#include "temporal/beats.h"
+#include "evoral/Range.hpp"
+
+#include "pbd/string_convert.h"
#include "ardour/ardour.h"
+#include "ardour/midi_cursor.h"
#include "ardour/region.h"
class XMLNode;
namespace ARDOUR {
namespace Properties {
- LIBARDOUR_API extern PBD::PropertyDescriptor<Evoral::Beats> start_beats;
- LIBARDOUR_API extern PBD::PropertyDescriptor<Evoral::Beats> length_beats;
+ LIBARDOUR_API extern PBD::PropertyDescriptor<double> start_beats;
+ LIBARDOUR_API extern PBD::PropertyDescriptor<double> length_beats;
}
}
~MidiRegion();
+ bool do_export (std::string path) const;
+
boost::shared_ptr<MidiRegion> clone (std::string path = std::string()) const;
boost::shared_ptr<MidiRegion> clone (boost::shared_ptr<MidiSource>) const;
boost::shared_ptr<MidiSource> midi_source (uint32_t n=0) const;
/* Stub Readable interface */
- virtual framecnt_t read (Sample*, framepos_t /*pos*/, framecnt_t /*cnt*/, int /*channel*/) const { return 0; }
- virtual framecnt_t readable_length() const { return length(); }
-
- framecnt_t read_at (Evoral::EventSink<framepos_t>& dst,
- framepos_t position,
- framecnt_t dur,
+ virtual samplecnt_t read (Sample*, samplepos_t /*pos*/, samplecnt_t /*cnt*/, int /*channel*/) const { return 0; }
+ virtual samplecnt_t readable_length() const { return length(); }
+
+ samplecnt_t read_at (Evoral::EventSink<samplepos_t>& dst,
+ samplepos_t position,
+ samplecnt_t dur,
+ Evoral::Range<samplepos_t>* loop_range,
+ MidiCursor& cursor,
uint32_t chan_n = 0,
NoteMode mode = Sustained,
MidiStateTracker* tracker = 0,
MidiChannelFilter* filter = 0) const;
- framecnt_t master_read_at (MidiRingBuffer<framepos_t>& dst,
- framepos_t position,
- framecnt_t dur,
+ samplecnt_t master_read_at (MidiRingBuffer<samplepos_t>& dst,
+ samplepos_t position,
+ samplecnt_t dur,
+ Evoral::Range<samplepos_t>* loop_range,
+ MidiCursor& cursor,
uint32_t chan_n = 0,
NoteMode mode = Sustained) const;
XMLNode& state ();
int set_state (const XMLNode&, int version);
- int separate_by_channel (ARDOUR::Session&, std::vector< boost::shared_ptr<Region> >&) const;
+ int separate_by_channel (std::vector< boost::shared_ptr<Region> >&) const;
/* automation */
boost::shared_ptr<const MidiModel> model() const;
void fix_negative_start ();
- Evoral::Beats start_beats () {return _start_beats.val(); }
+ double start_beats () const {return _start_beats; }
+ double length_beats () const {return _length_beats; }
+
+ void clobber_sources (boost::shared_ptr<MidiSource> source);
+
protected:
virtual bool can_trim_start_before_source_start () const {
private:
friend class RegionFactory;
- PBD::Property<Evoral::Beats> _start_beats;
- PBD::Property<Evoral::Beats> _length_beats;
+ PBD::Property<double> _start_beats;
+ PBD::Property<double> _length_beats;
MidiRegion (const SourceList&);
MidiRegion (boost::shared_ptr<const MidiRegion>);
- MidiRegion (boost::shared_ptr<const MidiRegion>, frameoffset_t offset);
+ MidiRegion (boost::shared_ptr<const MidiRegion>, ARDOUR::MusicSample offset);
- framecnt_t _read_at (const SourceList&, Evoral::EventSink<framepos_t>& dst,
- framepos_t position,
- framecnt_t dur,
+ samplecnt_t _read_at (const SourceList&, Evoral::EventSink<samplepos_t>& dst,
+ samplepos_t position,
+ samplecnt_t dur,
+ Evoral::Range<samplepos_t>* loop_range,
+ MidiCursor& cursor,
uint32_t chan_n = 0,
NoteMode mode = Sustained,
MidiStateTracker* tracker = 0,
void recompute_at_start ();
void recompute_at_end ();
- void set_position_internal (framepos_t pos, bool allow_bbt_recompute);
- void set_length_internal (framecnt_t len);
- void set_start_internal (framecnt_t);
- void trim_to_internal (framepos_t position, framecnt_t length);
- void update_length_beats ();
+ void set_position_internal (samplepos_t pos, bool allow_bbt_recompute, const int32_t sub_num);
+ void set_position_music_internal (double qn);
+ void set_length_internal (samplecnt_t len, const int32_t sub_num);
+ void set_start_internal (samplecnt_t, const int32_t sub_num);
+ void trim_to_internal (samplepos_t position, samplecnt_t length, const int32_t sub_num);
+ void update_length_beats (const int32_t sub_num);
void model_changed ();
+ void model_shifted (double qn_distance);
void model_automation_state_changed (Evoral::Parameter const &);
- void set_start_beats_from_start_frames ();
+ void set_start_beats_from_start_samples ();
void update_after_tempo_map_change (bool send_change = true);
std::set<Evoral::Parameter> _filtered_parameters; ///< parameters that we ask our source not to return when reading
PBD::ScopedConnection _model_connection;
+ PBD::ScopedConnection _model_shift_connection;
PBD::ScopedConnection _source_connection;
PBD::ScopedConnection _model_contents_connection;
-
- double _last_length_beats;
+ bool _ignore_shift;
};
} /* namespace ARDOUR */