use of com.xenoage.zong.musiclayout.notation.chord.NotesNotation in project Zong by Xenoage.
the class NotesNotator method compute.
/**
* Computes the displacement of the notes of the given chord, which has a stem into
* the given direction, using the given musical context.
*/
public NotesNotation compute(Chord chord, StemDirection stemDirection, ChordWidths chordWidths, MusicContext musicContext) {
ChordLps lp = new ChordLps(chord, musicContext);
ChordClass chordClass = computeChordClass(lp, stemDirection);
float noteheadWidth = chordWidths.get(chord.getDisplayedDuration());
float stemOffset = computeStemOffset(chordClass, noteheadWidth);
float notesWidth = computeNotesWidth(chordClass, noteheadWidth);
NoteDisplacement[] notes = computeNotes(lp, stemDirection, stemOffset);
int dotsCount = computeDotsCount(chord.getDuration());
float[] dotsOffsets = computeDotsOffsets(notesWidth, dotsCount, chordWidths);
int[] dotsLp = (dotsCount > 0 ? computeDotsLp(lp) : emptyIntArray);
boolean leftSuspended = isLeftSuspended(notes);
float totalWidth;
if (dotsCount > 0)
totalWidth = dotsOffsets[dotsCount - 1];
else
totalWidth = notesWidth;
return new NotesNotation(totalWidth, noteheadWidth, notes, dotsOffsets, dotsLp, stemOffset, leftSuspended);
}
use of com.xenoage.zong.musiclayout.notation.chord.NotesNotation in project Zong by Xenoage.
the class ChordNotator method compute.
public ChordNotation compute(Chord chord, Context context, @MaybeNull Notations notations) {
Score score = context.score;
float interlineSpace = score.getInterlineSpace(context.mp);
FontInfo lyricsFont = score.getFormat().getLyricFont();
MusicContext mc = score.getMusicContext(context.mp, BeforeOrAt, Before);
// grace or normal chord?
boolean grace = chord.isGrace();
ChordWidths chordWidths = (grace ? context.settings.graceChordWidths : context.settings.chordWidths);
ChordSpacings spacings = (grace ? context.settings.spacings.graceChordSpacings : context.settings.spacings.normalChordSpacings);
// use or compute stem direction
StemDirection stemDirection = chord.getStem().getDirection();
if (stemDirection == StemDirection.Default) {
// if stem direction was not computed yet, compute it now
if (notations != null)
stemDirection = notations.getChord(chord).stemDirection;
if (stemDirection == StemDirection.Default) {
Map<Chord, StemDirection> computedStems = stemDirector.compute(chord);
stemDirection = computedStems.get(chord);
// also remember the other computed stems
if (notations != null)
for (Chord computedChord : computedStems.keySet()) notations.getChord(computedChord).stemDirection = computedStems.get(computedChord);
}
}
// notes displacement
NotesNotation notes = notesNotator.compute(chord, stemDirection, chordWidths, mc);
float leftSuspendedWidth = (notes.leftSuspended ? notes.noteheadWidthIs : 0);
// accidentals
AccidentalsNotation accs = accidentalsNotator.compute(chord, notes, chordWidths, mc);
// symbol's width: width of the noteheads and dots
float symbolWidth = notes.widthIs - leftSuspendedWidth;
float frontGap = accs.widthIs + leftSuspendedWidth;
// rear gap: empty duration-dependent space behind the chord minus the symbol's width
float rearGap = spacings.getWidth(chord.getDisplayedDuration()) - symbolWidth;
// lyric width
float lyricWidth = 0;
TextMeasurer textMeasurer = platformUtils().getTextMeasurer();
for (Lyric lyric : chord.getLyrics()) {
if (lyric != null && lyric.getText() != null) {
// width of lyric in interline spaces
FormattedText lyricText = styleText(lyric.getText(), new FormattedTextStyle(lyricsFont));
float l = lyricText.getWidth() / interlineSpace;
// for start and end syllable, request "-" more space, for middle syllables "--"
// TODO: unsymmetric - start needs space on the right, end on the left, ...
SyllableType lyricType = lyric.getSyllableType();
if (lyricType == SyllableType.Begin || lyricType == SyllableType.End) {
l += textMeasurer.measure(lyricsFont, "-").getWidth() / interlineSpace;
} else if (lyricType == SyllableType.Middle) {
l += textMeasurer.measure(lyricsFont, "--").getWidth() / interlineSpace;
}
// save width of the widest lyric
lyricWidth = Math.max(lyricWidth, l);
}
}
// compute length of the stem (if any)
float scaling = grace ? context.settings.scalingGrace : 1;
StemNotation stem = stemNotator.compute(chord.getStem(), notes.getLps(), stemDirection, context.mp.getStaff(), Companion.staffLines(mc.getLinesCount()), scaling);
// compute articulations
ArticulationsNotation arts = articulationsNotator.compute(chord, stemDirection, notes, mc.getLinesCount());
return new ChordNotation(chord, chord.getMP(), new ElementWidth(frontGap, symbolWidth, rearGap, lyricWidth), context.mp.getStaff(), notes, stemDirection, stem, accs, arts);
}
use of com.xenoage.zong.musiclayout.notation.chord.NotesNotation in project Zong by Xenoage.
the class NotesNotatorTest method testSingleNoteF4.
/**
* Tests a F4, 1/2. Stem: right, up. Width: 1x half.
*/
@Test
public void testSingleNoteF4() {
Chord chord = chord(Companion.pi(3, 0, 4), Companion.fr(1, 2));
NotesNotation notes = testee.compute(chord, StemDirection.Up, cw, context);
assertEquals(n, notes.stemOffsetIs, Df);
assertEquals(n, notes.widthIs, Df);
NoteDisplacement note = notes.getNote(0);
assertEquals(1, note.lp);
assertEquals(0, note.xIs, Df);
assertEquals(NoteSuspension.None, note.suspension);
}
use of com.xenoage.zong.musiclayout.notation.chord.NotesNotation in project Zong by Xenoage.
the class NotesNotatorTest method testChordC4E4G4.
/**
* Tests a C4-E4-G4, 3/4. Stem: right, up. Width: 1x half + 1x dot.
*/
@Test
public void testChordC4E4G4() {
Chord chord = chord(new Pitch[] { Companion.pi(0, 0, 4), Companion.pi(2, 0, 4), Companion.pi(4, 0, 4) }, Companion.fr(3, 4));
NotesNotation notes = testee.compute(chord, StemDirection.Up, cw, context);
assertEquals(n, notes.stemOffsetIs, Df);
assertEquals(n + dg, notes.widthIs, Df);
assertEquals(0, notes.getNote(0).xIs, Df);
assertEquals(NoteSuspension.None, notes.getNote(0).suspension);
assertEquals(0, notes.getNote(1).xIs, Df);
assertEquals(NoteSuspension.None, notes.getNote(1).suspension);
assertEquals(0, notes.getNote(2).xIs, Df);
assertEquals(NoteSuspension.None, notes.getNote(2).suspension);
}
use of com.xenoage.zong.musiclayout.notation.chord.NotesNotation in project Zong by Xenoage.
the class NotesNotatorTest method testChordC5D5.
/**
* Tests a C5/D5, 1/4. Stem: left, down. Width: 1x quarter.
*/
@Test
public void testChordC5D5() {
Chord chord = chord(new Pitch[] { Companion.pi(0, 0, 5), Companion.pi(1, 0, 5) }, Companion.fr(1, 4));
NotesNotation notes = testee.compute(chord, StemDirection.Down, cw, context);
assertEquals(n, notes.stemOffsetIs, Df);
assertEquals(2 * n, notes.widthIs, Df);
NoteDisplacement note = notes.getNote(0);
assertEquals(5, note.lp);
assertEquals(0, note.xIs, Df);
assertEquals(NoteSuspension.Left, note.suspension);
note = notes.getNote(1);
assertEquals(6, note.lp);
assertEquals(n, note.xIs, Df);
assertEquals(NoteSuspension.None, note.suspension);
}
Aggregations