-
-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathtest-alignment.tex
217 lines (173 loc) · 10 KB
/
test-alignment.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
\documentclass[DIV=12]{scrartcl}
\usepackage{lyluatex}
% NOTE: Currently this still has to be installed from
% https://github.com/uliska/musicexamples
\usepackage{musicexamples}
\setXmpCaptionLabel{Example}
%\usepackage{fontspec}
%\usepackage{Libertine}
\usepackage{libertine}
\usepackage{microtype}
\frenchspacing
\usepackage{mdwlist}
\usepackage[top=2cm,bottom=3cm]{geometry}
\usepackage{multicol}
\usepackage[colorlinks]{hyperref}
\newcommand{\betweenLilyPondSystem}[1]{
\bigskip
}
\begin{document}
\section*{Alignment of Scores in Text Documents}
\lyluatex%
\footnote{\url{https://github.com/jperon/lyluatex}}
is a package for \LuaLaTeX\ that manages the engraving and integration of musical scores in text documents. The scores are encoded in chunks of LilyPond input which can be written directly in the document or maintained in standalone files. They are compiled using LilyPond and cached intelligently. Line width and staff size can be inferred from the surrounding text (but also configured explicitly). The following Beethoven excerpt is included twice, first normally and then with a smaller staff size in a two-column section:
\begin{musicExampleNonFloat}
\includely[staffsize=18]{ly/Beethoven/opus-18-1.ly}
\caption{Score automatically generated from an included LilyPond file}
\end{musicExampleNonFloat}
\setlength{\columnsep}{1cm}
\begin{multicols}{2}
And now the same score is engraved in two columns with the staff size manually reduced (in the \LaTeX\ include). Note that the same LilyPond file is simply used again.
Two important features can be demonstrated in these two examples: automatic engraving and individual handling of systems. Depending on the current line width the same score input is rendered twice with different settings, so it is not necessary to manually make the score “fit” into the text in the notation software. And if the settings change (for example when rendering to different output media or adjusting the space between the columns) one doesn't have to go back to the notation software to update \emph{all} used scores. Instead they are recompiled automatically upon the next \LaTeX\ run.
The other aspect is that the resulting systems of the score are generated as independent image files. This makes the score float freely through the text, allowing \LaTeX\ to break pages and columns automatically.
\begin{musicExampleNonFloat}
\includely[staffsize=14]{ly/Beethoven/opus-18-1.ly}
\caption{Engraved from the same file}
\end{musicExampleNonFloat}
\end{multicols}
\bigskip
\hrule
\bigskip
But the main point of this document is to provide material for discussing the \emph{alignment} of scores to the surrounding text. The examples so far show an achievement of the \lyluatex\ package: when aligning the score to the text the \emph{staff lines} exactly match the line width of the text, while brackets and instrument names protrude into the left margin. This is actually a non-trivial task, as the width of that margin material is arbitrary and can't reasonably be predicted, at least not automatically and reliably. In order to properly handle that task \lyluatex\ reads that width from an intermediate PostScript file and applies the corresponding negative offset when including the image file for each system.
\setmainfont{Adobe Garamond Pro}
\bigskip
However, while this is a great default behaviour there are valid reasons for \emph{not} wanting such protrusion to (always) happen. For example it might be considered inappropriate to use the margin at all (maybe there are other elements to be printed in the margin) or it may look awkward or actually run off the page when the margin text is very wide:
\begin{musicExampleNonFloat}
\begin{ly}
\version "2.16"
\language "français"
\paper {
ragged-last = ##f
}
MetriqueArmure = {
\tempo 4=70
\time 3/4
\key do \major
}
italique = { \override Score . LyricText #'font-shape = #'italic }
roman = { \override Score . LyricText #'font-shape = #'roman }
MusiqueTheme = \relative do' {
\partial 4 do4
fa4 fa la
fa4 fa la
sol4 sol la8[( sol])
fa2 do4
fa4 fa la
fa4 fa la
sol4 sol
}
Paroles = \lyricmode {
L'heure é -- tait ve -- nu -- e,
où l'ai -- rain sa -- cré,
de sa voix con -- nu -- e,
an -- non -- çait
}
\score{
\new ChoirStaff \with {
instrumentName = \markup { "Voix" \italic "bien modulée" \hspace #2 }
} <<
\new Staff <<
\set Staff.autoBeaming = ##f
\new Voice = "theme" {
\override Score.PaperColumn #'keep-inside-line = ##t
\MetriqueArmure
\MusiqueTheme
}
>>
\new Lyrics \lyricsto theme {
\Paroles
}
>>
\layout{}
}
\end{ly}
\caption{Long text protruding in the left margin}
\end{musicExampleNonFloat}
\bigskip
Which of the following approaches would be correct or acceptable from the typographical point of view? Additional suggestions are welcome!
\begin{itemize*}
\item indent the score so the margin text is aligned with the margin of the text?
\item indent by \emph{some} extent, if so, what extent?
\item Do \emph{not} handle this and expect the relevant information to be given differently, for example with text markup or in a caption?
\end{itemize*}
If it is desirable to provide a way to include scores \emph{without} protrusion, i.\,e. aligning the leftmost printed element with the surrounding text, there are technical challenges because we don't know the width of the margin text beforehand.
If we would simply not apply the negative offset the score would of course protrude into the \emph{right} margin, which is inacceptable. It would on the other hand be simple to scale the image to fit exactly into the line width, but this would scale it down and make it inconsistent with other scores. Somewhat less inacceptable but still ugly and unprofessional. Obviously the native line width of the score would have to be reduced, which could be done in two ways:
\begin{itemize*}
\item Give the user an option to manually specify an indentation width. However, this will \emph{not} make the resulting image match with the text's line width (at least not without tedious trial\,\&\,error), and there would be the question of whether it should be left-aligned, right-aligned, or centered to the paragraph.
\item Determine the actual value in a two-pass process. In a first compilation LilyPond produces the score with the desired line width. From that the width of the margin elements can be read, and then LilyPond can compile the score once more, with the line width reduced accordingly. This approach will perfectly align both the leftmost printed item and the right edge of the system with the surrounding text while keeping the staff height consistent. But it will require the score to be compiled twice, which requires non-neglectable amounts of time. And it has to be noted that shortening the line width \emph{may} affect the line breaking in unexpected ways.
\end{itemize*}
Another situation to be discussed is the alignment of shorter music examples. Typically these are not justified to span full lines but centered, as is demonstrated in the following example:
\begin{musicExampleNonFloat}
\begin{ly}
\relative c'{
\slurDashed
\override Slur.color = #magenta
c \f ( d e2 )
\override DynamicText.color = #magenta
\once \override DynamicText.font-size = -3
f4 \p
\override Script.color = #magenta
\override ParenthesesItem.color = #magenta
g a2 -\parenthesize ->
}
\end{ly}
\caption{Short centered music example}
\label{xmp:short-centered-example}
\end{musicExampleNonFloat}
This example didn't include any margin items so the system is nicely centered together with the paragraph and the caption. If on the other hand there \emph{is} something printed in the margin the question arises what should be centered, the staff lines or the whole image. The following two examples show the behaviour \emph{with} protrusion (as currently \lyluatex\ can not do otherwise (which is the reason for this discussion anyway)), one of them with a ridiculously long text, just to show the effect. The question is if in such cases it would be better to center the \emph{whole} image or at least give the user the option to choose (globally and per score).
\begin{musicExampleNonFloat}
\begin{ly}
\new StaffGroup <<
\new Staff \relative c' {
\set Staff.instrumentName = "Vl. 1"
\tempo Allegro
\time 3/4
\key f \major
f4 \p ~ f8 ( g16 f ) e8-. f-. |
c4 r r |
}
\new Staff \relative f {
\set Staff.instrumentName = "Vc."
\clef bass
\key f \major
f4 \p ~ f8 ( g16 f ) e8-. f-.
c4 r r |
}
>>
\end{ly}
\caption{Short centered music example -- staff lines centered}
\end{musicExampleNonFloat}
\begin{musicExampleNonFloat}
\begin{ly}
\new Staff \with {
instrumentName = "Highlighting editorial decisions"
} \relative c'{
\slurDashed
\override Slur.color = #magenta
c \f ( d e2 )
\override DynamicText.color = #magenta
\once \override DynamicText.font-size = -3
f4 \p
\override Script.color = #magenta
\override ParenthesesItem.color = #magenta
g a2 -\parenthesize ->
}
\end{ly}
\caption{Short centered music example with loooong text in front}
\end{musicExampleNonFloat}
\hrule
\bigskip
For continuing the development some questions about the interface for \LaTeX\ users have to be discussed. It seems we are dealing with two terms: \emph{protrusion} and \emph{indentation}. The current behaviour as shown in this document is clearly “with protrusion”. But if the whole image is aligned instead of the staff lines is that “without protrusion” or “with indentation”? And would it make a difference in terminology if the user chooses to automatically align the whole image or if they create an explicit indentation (shorten the line width)?
Independently from the \emph{naming} of the features it should be decided which of the features should be configurable globally (package option), in the middle of the document (command to change behaviour/values), or on a per-score basis (optional arguments). Please give any feedback on the package's issue tracker%
\footnote{\url{https://github.com/jperon/lyluatex/issues/36}}.
\end{document}