use of com.xenoage.zong.musicxml.types.attributes.MxlPosition in project Zong by Xenoage.
the class MxlStem method read.
@NonNull
public static MxlStem read(XmlReader reader) {
MxlPosition yPosition = MxlPosition.read(reader);
MxlColor color = MxlColor.read(reader);
MxlStemValue stem = MxlStemValue.read(reader);
return new MxlStem(stem, yPosition, color);
}
use of com.xenoage.zong.musicxml.types.attributes.MxlPosition in project Zong by Xenoage.
the class StemReader method read.
/**
* Reads and returns the stem of the given chord.
* If not available, {@link Stem#defaultStem} is returned.
* @param context the global context
* @param chord the chord, whose notes are already collected
* @param staff the staff index of the current chord
*/
public Stem read(Context context, Chord chord, int staff) {
if (mxlStem == null)
return Companion.getDefaultStem();
// direction
StemDirection direction = readStemDirection();
// length
Float length = null;
MxlPosition yPos = mxlStem.getPosition();
if (yPos.getDefaultY() != null) {
// convert position in tenths relative to topmost staff line into
// a length in interline spaces measured from the outermost chord note on stem side
float stemEndLinePosition = convertDefaultYToLP(context, yPos.getDefaultY(), staff);
VSide side = (direction == StemDirection.Up ? VSide.Top : VSide.Bottom);
length = Math.abs(stemEndLinePosition - getOuterNoteLp(context, chord, side, staff)) / 2;
}
// create stem
return new Stem(direction, length);
}
use of com.xenoage.zong.musicxml.types.attributes.MxlPosition in project Zong by Xenoage.
the class MxlSlurOrTied method read.
@MaybeNull
public static MxlSlurOrTied read(XmlReader reader) {
// element type
MxlElementType elementType = null;
String eName = reader.getElementName();
if (elemNameSlur.equals(eName))
elementType = MxlElementType.Slur;
else if (elemNameTied.equals(eName))
elementType = MxlElementType.Tied;
else
throw reader.dataException("slur or tied expected");
// type
MxlStartStopContinue type = MxlStartStopContinue.read(reader.getAttribute("type"));
if (type == MxlStartStopContinue.Continue && elementType == MxlElementType.Tied)
throw reader.dataException("tied can not be continued");
// other members
Integer number = reader.getAttributeInt("number");
if (elementType == MxlElementType.Slur)
number = notNull(number, defaultNumberForSlur);
MxlPosition position = MxlPosition.read(reader);
MxlPlacement placement = MxlPlacement.read(reader);
MxlBezier bezier = MxlBezier.read(reader);
return new MxlSlurOrTied(elementType, type, number, position, placement, bezier);
}
use of com.xenoage.zong.musicxml.types.attributes.MxlPosition in project Zong by Xenoage.
the class CreditsReader method addTextFrame.
/**
* Adds the given credit element as a {@link TextFrame} to the given {@link Layout}.
*/
private static void addTextFrame(MxlCredit credit, Layout layout, ScoreFormat scoreFormat) {
if (credit.getContent().getCreditContentType() == MxlCreditContentType.CreditWords) {
MxlCreditWords mxlCreditWords = (MxlCreditWords) credit.getContent();
// create formatted text
FormattedText text = createFormattedText(mxlCreditWords, scoreFormat.getLyricFont());
// compute position (read only the position of the first credit-words element)
Page firstPage = layout.getPages().get(0);
float tenths = scoreFormat.getInterlineSpace() / 10;
MxlFormattedText mxlFirstCreditWords = mxlCreditWords.getItems().get(0);
MxlPosition mxlPosition = mxlFirstCreditWords.getPrintStyle().getPosition();
Point2f offsetFromBottomInTenths = mxlPosition.getDefault().or(new Point2f(10f, 10f));
Point2f position = new Point2f(offsetFromBottomInTenths.x * tenths, firstPage.getFormat().getSize().height - offsetFromBottomInTenths.y * tenths);
// compute size
// this is the width of the widest paragraph and the height of the sum of all paragraphs
// at least 1 mm
float maxParagraphWidth = 1;
// at least 1 mm
float sumParagraphsHeight = 1;
for (FormattedTextParagraph paragraph : text.getParagraphs()) {
maxParagraphWidth = Math.max(maxParagraphWidth, paragraph.getMetrics().getWidth());
sumParagraphsHeight += paragraph.getHeightMm();
}
Size2f size = new Size2f(maxParagraphWidth, sumParagraphsHeight);
// horizontal alignment:
// try with halign first, and if not set, use justify
Alignment alignment = readAlignment(mxlFirstCreditWords.getHAlign());
if (alignment == null) {
alignment = readAlignment(mxlFirstCreditWords.getJustify());
}
if (alignment == null || alignment == Alignment.Left) {
position = position.add(size.width / 2, 0);
} else if (alignment == Alignment.Center) {
// already centered
} else if (alignment == Alignment.Right) {
position = position.add(-size.width / 2, 0);
}
// vertical alignment
MxlVAlign mxlVAlign = mxlFirstCreditWords.getVAlign();
if (mxlVAlign == MxlVAlign.Top || mxlVAlign == MxlVAlign.Unknown) {
position = position.add(0, size.height / 2);
} else if (mxlVAlign == MxlVAlign.Middle) {
// already centered
} else if (mxlVAlign == MxlVAlign.Bottom || mxlVAlign == MxlVAlign.Baseline) {
position = position.add(0, -size.height / 2);
}
// create and add TextFrame
TextFrame textFrame = new TextFrame();
textFrame.setPosition(position);
textFrame.setSize(size);
textFrame.setText(text);
layout.getPages().get(0).addFrame(textFrame);
}
}
use of com.xenoage.zong.musicxml.types.attributes.MxlPosition in project Zong by Xenoage.
the class MxlGroupSymbol method read.
@NonNull
public static MxlGroupSymbol read(XmlReader reader) {
MxlPosition position = MxlPosition.read(reader);
MxlColor color = MxlColor.read(reader);
MxlGroupSymbolValue value = MxlGroupSymbolValue.read(reader);
return new MxlGroupSymbol(value, position, color);
}
Aggregations