diff options
author | Dan Eble <nine.fierce.ballads@gmail.com> | 2016-06-15 18:54:53 -0400 |
---|---|---|
committer | Dan Eble <nine.fierce.ballads@gmail.com> | 2016-08-06 17:43:48 -0400 |
commit | 980df8c5df55556b784d573f1c3d16bb9c8f3ab8 (patch) | |
tree | 758560310d9550bc3903383515b9b44ad14dd164 /lily | |
parent | 00a48501c64c8babe77c2ebabcc42dae33a7c026 (diff) |
Issue 4947: Link notes to dynamics in Dynamic_performer rather than
Staff_performer. Dynamics in different voices are now independent.
Diffstat (limited to 'lily')
-rw-r--r-- | lily/dynamic-performer.cc | 25 | ||||
-rw-r--r-- | lily/staff-performer.cc | 38 |
2 files changed, 25 insertions, 38 deletions
diff --git a/lily/dynamic-performer.cc b/lily/dynamic-performer.cc index 857b3590dc..23b7d43bfd 100644 --- a/lily/dynamic-performer.cc +++ b/lily/dynamic-performer.cc @@ -30,6 +30,7 @@ class Dynamic_performer : public Performer public: TRANSLATOR_DECLARATIONS (Dynamic_performer); protected: + virtual void acknowledge_audio_element (Audio_element_info info); virtual void finalize (); void stop_translation_timestep (); void process_music (); @@ -111,6 +112,7 @@ private: }; private: + vector<Audio_note *> notes_; Stream_event *script_event_; Drul_array<Stream_event *> span_events_; Direction next_grow_dir_; @@ -131,6 +133,16 @@ Dynamic_performer::Dynamic_performer () = span_events_[RIGHT] = 0; } +void +Dynamic_performer::acknowledge_audio_element (Audio_element_info inf) +{ + // Keep track of the notes played in this translation time step so that they + // can be pointed to the current dynamic in stop_translation_timestep. + if (Audio_note *n = dynamic_cast<Audio_note *> (inf.elem_)) { + notes_.push_back (n); + } +} + bool Dynamic_performer::drive_state_machine (Direction next_grow_dir) { @@ -429,6 +441,19 @@ Dynamic_performer::process_music () void Dynamic_performer::stop_translation_timestep () { + // link notes to the current dynamic + if (!open_span_.dynamic_) + programming_error("no current dynamic"); + else + { + for (vector<Audio_note *>::const_iterator ni = notes_.begin (); + ni != notes_.end (); ++ni) + { + (*ni)->dynamic_ = open_span_.dynamic_; + } + } + notes_.clear (); + script_event_ = 0; span_events_[LEFT] = span_events_[RIGHT] = 0; diff --git a/lily/staff-performer.cc b/lily/staff-performer.cc index d413a46835..592c6a7e01 100644 --- a/lily/staff-performer.cc +++ b/lily/staff-performer.cc @@ -55,7 +55,6 @@ private: int get_channel (const string &instrument); Audio_staff *get_audio_staff (const string &voice); Audio_staff *new_audio_staff (const string &voice); - Audio_span_dynamic *get_dynamic (const string &voice); class Midi_control_initializer : public Midi_control_change_announcer { @@ -79,10 +78,8 @@ private: Audio_text *instrument_name_; Audio_text *name_; Audio_tempo *tempo_; - map<string, deque<Audio_note *> > note_map_; map<string, Audio_staff *> staff_map_; map<string, int> channel_map_; - map<string, Audio_span_dynamic *> dynamic_map_; // Would prefer to have the following two items be // members of the containing class Performance, // so they can be reset for each new midi file output. @@ -178,15 +175,6 @@ Staff_performer::get_audio_staff (const string &voice) return new_audio_staff (voice); } -Audio_span_dynamic * -Staff_performer::get_dynamic (const string &voice) -{ - map<string, Audio_span_dynamic *>::const_iterator i = dynamic_map_.find (voice); - if (i != dynamic_map_.end ()) - return i->second; - return 0; -} - void Staff_performer::process_music () { @@ -220,21 +208,6 @@ Staff_performer::stop_translation_timestep () tempo_ = 0; instrument_name_ = 0; instrument_ = 0; - // For each voice with a note played in the current translation time step, - // check if the voice has a dynamic registered: if yes, apply the dynamic - // to every note played in the voice in the current translation time step. - for (map<string, deque<Audio_note *> >::iterator vi = note_map_.begin (); - vi != note_map_.end (); ++vi) - { - Audio_span_dynamic *d = get_dynamic (vi->first); - if (d) - { - for (deque<Audio_note *>::iterator ni = vi->second.begin (); - ni != vi->second.end (); ++ni) - (*ni)->dynamic_ = d; - } - } - note_map_.clear (); } void @@ -331,19 +304,8 @@ Staff_performer::acknowledge_audio_element (Audio_element_info inf) if (Audio_item *ai = dynamic_cast<Audio_item *> (inf.elem_)) { ai->channel_ = channel_; - if (Audio_note *n = dynamic_cast<Audio_note *> (inf.elem_)) - { - // Keep track of the notes played in the current voice in this - // translation time step (for adjusting their dynamics later in - // stop_translation_timestep). - note_map_[voice].push_back (n); - } audio_staff->add_audio_item (ai); } - else if (Audio_span_dynamic *d = dynamic_cast<Audio_span_dynamic *> (inf.elem_)) - { - dynamic_map_[voice] = d; - } } Staff_performer::Midi_control_initializer::Midi_control_initializer |