mirror of
https://github.com/microtherion/VocalEasel.git
synced 2025-01-08 19:24:00 +00:00
Handle pickup notes
This commit is contained in:
parent
cbf758784c
commit
ca9592111c
|
@ -159,7 +159,7 @@ void VLNote::Name(std::string & name, bool useSharps) const
|
||||||
name = PitchName(fPitch, useSharps);
|
name = PitchName(fPitch, useSharps);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VLNote::LilypondName(std::string & name, VLFraction at, VLFraction prevDur, VLFraction nextDur, bool & triplet, const VLProperties & prop) const
|
void VLNote::LilypondName(std::string & name, VLFraction at, VLFraction prevDur, VLFraction nextDur, bool & triplet, bool & pickup, const VLProperties & prop) const
|
||||||
{
|
{
|
||||||
std::string n = LilypondPitchName(fPitch, prop.fKey >= 0);
|
std::string n = LilypondPitchName(fPitch, prop.fKey >= 0);
|
||||||
if (fPitch != kNoPitch) {
|
if (fPitch != kNoPitch) {
|
||||||
|
@ -167,6 +167,9 @@ void VLNote::LilypondName(std::string & name, VLFraction at, VLFraction prevDur,
|
||||||
n += '\'';
|
n += '\'';
|
||||||
for (int commas = (kMiddleC-kOctave-fPitch)/kOctave; commas>0; --commas)
|
for (int commas = (kMiddleC-kOctave-fPitch)/kOctave; commas>0; --commas)
|
||||||
n += ',';
|
n += ',';
|
||||||
|
pickup = false;
|
||||||
|
} else if (pickup) {
|
||||||
|
n = "s";
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> durations;
|
std::vector<std::string> durations;
|
||||||
|
@ -1285,6 +1288,7 @@ void VLSong::LilypondNotes(std::string & notes) const
|
||||||
size_t seenEnding = 0;
|
size_t seenEnding = 0;
|
||||||
int numEndings = 0;
|
int numEndings = 0;
|
||||||
size_t endMeasure = fMeasures.size()-EmptyEnding();
|
size_t endMeasure = fMeasures.size()-EmptyEnding();
|
||||||
|
bool pickup = fMeasures[0].NoChords();
|
||||||
for (size_t measure=0; measure<fMeasures.size(); ++measure) {
|
for (size_t measure=0; measure<fMeasures.size(); ++measure) {
|
||||||
VLNoteList::const_iterator i = fMeasures[measure].fMelody.begin();
|
VLNoteList::const_iterator i = fMeasures[measure].fMelody.begin();
|
||||||
VLNoteList::const_iterator e = fMeasures[measure].fMelody.end();
|
VLNoteList::const_iterator e = fMeasures[measure].fMelody.end();
|
||||||
|
@ -1336,7 +1340,7 @@ void VLSong::LilypondNotes(std::string & notes) const
|
||||||
VLFraction nextDur(0);
|
VLFraction nextDur(0);
|
||||||
if (++n != e)
|
if (++n != e)
|
||||||
nextDur = n->fDuration;
|
nextDur = n->fDuration;
|
||||||
i->LilypondName(note, at, prevDur, nextDur, triplet, fProperties[fMeasures[measure].fPropIdx]);
|
i->LilypondName(note, at, prevDur, nextDur, triplet, pickup, fProperties[fMeasures[measure].fPropIdx]);
|
||||||
prevDur = i->fDuration;
|
prevDur = i->fDuration;
|
||||||
at += i->fDuration;
|
at += i->fDuration;
|
||||||
notes += note+" ";
|
notes += note+" ";
|
||||||
|
|
|
@ -140,7 +140,7 @@ struct VLNote {
|
||||||
VLNote(std::string name);
|
VLNote(std::string name);
|
||||||
|
|
||||||
void Name(std::string & name, bool useSharps = false) const;
|
void Name(std::string & name, bool useSharps = false) const;
|
||||||
void LilypondName(std::string & name, VLFraction at, VLFraction prevDur, VLFraction nextDur, bool & triplet, const VLProperties & prop) const;
|
void LilypondName(std::string & name, VLFraction at, VLFraction prevDur, VLFraction nextDur, bool & triplet, bool & pickup, const VLProperties & prop) const;
|
||||||
void MMAName(std::string & name, VLFraction at, VLFraction dur, VLFraction prevDur, VLFraction nextDur, const VLProperties & prop) const;
|
void MMAName(std::string & name, VLFraction at, VLFraction dur, VLFraction prevDur, VLFraction nextDur, const VLProperties & prop) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user