]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/de/learning/tweaks.itely
8ee2e06b849163880e119e2bb2d3de2d4fe70a0c
[lilypond.git] / Documentation / de / learning / tweaks.itely
1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: de -*-
2
3 @ignore
4     Translation of GIT committish: a0077273ac8bf29ae472c8712bc78a02d138f898
5
6     When revising a translation, copy the HEAD committish of the
7     version that you are working on.  For details, see the Contributors'
8     Guide, node Updating translation committishes.
9 @end ignore
10
11 @c \version "2.15.39"
12
13 @node Die Ausgabe verändern
14 @chapter Die Ausgabe verändern
15 @translationof Tweaking output
16
17 In diesem Kapitel wird erklärt, wie man die Notenausgabe verändern
18 kann. In LilyPond kann man sehr viel konfigurieren, fast jedes
19 Notenfragment kann geändert werden.
20
21
22 @menu
23 * Grundlagen für die Optimierung::
24 * Die Referenz der Programminterna::
25 * Erscheinung von Objekten::
26 * Positionierung von Objekten::
27 * Kollision von Objekten::
28 * Weitere Optimierungen::
29 @end menu
30
31
32 @node Grundlagen für die Optimierung
33 @section Grundlagen für die Optimierung
34 @translationof Tweaking basics
35
36 @menu
37 * Grundlagen zur Optimierung::
38 * Objekte und Schnittstellen::
39 * Regeln zur Benennung von Objekten und Eigenschaften::
40 * Optimierungsmethoden::
41 @end menu
42
43 @node Grundlagen zur Optimierung
44 @subsection Grundlagen zur Optimierung
45 @translationof Introduction to tweaks
46
47 @qq{Optimierung} (engl. tweaking) ist ein LilyPond-Begriff für die
48 verschiedenen Methoden, die Aktionen zu beeinflussen, die während
49 der Kompilation einer Notationsdatei vorgenommen werden sowie auf
50 das Notenbild einzuwirken. Einige dieser Optimierungen sind sehr
51 einfach, andere dagegen recht komplex. Aber insgesamt erlaubt das
52 System an Optimierungen so gut wie alle möglichen Erscheinungsformen
53 für die Notenausgabe.
54
55 In diesem Abschnitt werden die grundlegenden Konzepte vorgestellt,
56 um die Optimierung zu verstehen. Später soll eine Anzahl von fertigen
57 Befehlen bereitgestellt werden, die einfach in die Quelldatei
58 kopiert werden können um den selben Effekt wie im Beispiel
59 zu erhalten. Gleichzeitig zeigen diese Beispiele, wie die Befehle
60 konstruiert werden, so dass Sie in der Lage sein werden, eigene
61 Befehle auf dieser Grundlage zu entwickeln.
62
63 Bevor Sie mit diesem Kapitel beginnen, könnte Sie ein Blick in den
64 Abschnitt @ref{Kontexte und Engraver} interessieren, dann
65 Kontexte und Engraver sowie die Eigenschaften, die mit ihnen
66 verknüpft sind, sind die Voraussetzung, um die Funktionsweise
67 von Optimierungen verstehen zu können.
68
69
70 @node Objekte und Schnittstellen
71 @subsection Objekte und Schnittstellen
72 @translationof Objects and interfaces
73
74 @cindex Objekte
75 @cindex Grobs
76 @cindex Spanners
77 @cindex Interfaces
78 @cindex Strecker
79 @cindex Schnittstellen
80 @cindex graphische Objekte (Grob)
81 @cindex Objekteigenschaften
82 @cindex Layout-Objekt
83 @cindex Objekt, Layout-
84 @cindex Eigenschaften von Objekten
85
86 Optimierung bedeutet, die internen Operationen und Strukturen
87 des LilyPond-Programmes zu verändern, darum sollen hier
88 zunächst die wichtigsten Begriffe erklärt werden, die zur
89 Beschreibung dieser Operationen und Strukturen benutzt werden.
90
91 Der Begriff @qq{Objekt} ist ein allgemeiner Begriff, mit dem
92 die Vielzahl an internen Strukturen bezeichnet wird, die LilyPond
93 während der Bearbeitung des Quelltextes erstellt. Wenn etwa
94 ein Befehl wie @code{\new Staff} auftritt, wird ein neues Objekt
95 vom Typ @code{Staff} erstellt. Dieses Objekt @code{Staff} enthält
96 dann alle Eigenschaften, die mit diesem speziellen Notensystem
97 verknüpft sind, wie beispielsweise seine Bezeichnung, Tonart und
98 spezifische Angaben über die Engraver, die innerhalb dieses Systems
99 eingesetzt werden. Für alle anderen Kontexte gibt es genauso
100 Objekte, die deren Eigenschaften beinhalten, beispielsweise für
101 @code{Voice}-Objekte, @code{Score}-Objekte, @code{Lyrics}-Objekte,
102 aber auch für Objekte, die Notationselemente wie die Taktlinien,
103 Notenköpfe, Bögen und Dynamikbezeichnung enthalten. Jedes
104 Objekt hat eine eigene Gruppe an Eigenschaftswerten.
105
106 Bestimmte Objekttypen tragen besondere Bezeichnungen. Objekte, die
107 Notationselemente der gesetzten Ausgabe repräsentieren, also
108 Notenköpfe, Hälse, Bögen, Fingersatz, Schlüssel usw., werden
109 @qq{Layout-Objekte}, oft auch @qq{Graphische Objekte} genannt.
110 Daraus resultiert die künstliche Abkürzung @qq{Grob}.
111 Diese sind auch Objekte im allgemeinen Sinn und haben genauso
112 Eigenschaften, die mit ihnen verknüpft sind, wie etwa Größe, Position,
113 Farbe usw.
114
115 Einige Layout-Objekte sind etwas spezieller. Phrasierungsbögen,
116 Crescendo-Klammern, Oktavierungszeichen und viele andere
117 Grobs sind nicht an einer Stelle plaziert -- sie haben vielmehr
118 einen Anfangspunkt, einen Endpunkt und eventuell noch andere
119 Eigenschaften, die ihre Form bestimmen. Objekte mit solch
120 einer erweiterten Gestalt werden als @qq{Strecker} (engl. Spanners)
121 bezeichnet.
122
123 Es bleibt uns noch übrig zu erklären, was @qq{Schnittstellen}
124 (engl. interface) sind. Wenn auch viele Objekte sehr unterschiedlich
125 sind, haben sie doch oft gemeinsame Eigenschaften, die auf
126 die gleiche Weise verarbeitet werden.  Alle Grobs beispielsweise
127 haben eine Farbe, eine Größe, eine Position usw. und alle
128 diese Eigenschaften werden von LilyPond auf die gleiche Weise
129 verarbeitet, während der Quelltext in Notensatz umgesetzt wird.
130 Um die internen Operationen zu vereinfachen, sind alle diese
131 gemeinsamen Prozesse und Eigenschaften in einem Objekt
132 mit der Bezeichnung @code{grob-interface} (Schnittstelle eines
133 graphischen Objektes) zusammengefasst. Es gibt viele andere
134 Gruppen gemeinsamer Eigenschaften, die jede eine Bezeichnung
135 besitzen, welche auf @code{-interface} endet. Insgesamt
136 gibt es über 100 dieser Schnittstellen. Wir werden später sehen,
137 was es damit auf sich hat.
138
139 Dies waren die Hauptbegriffe, die in diesem Kapitel zur Anwendung
140 kommen sollen.
141
142
143 @node Regeln zur Benennung von Objekten und Eigenschaften
144 @subsection Regeln zur Benennung von Objekten und Eigenschaften
145 @translationof Naming conventions of objects and properties
146
147 @cindex Benennungskonventionen für Objekte
148 @cindex Benennungskonventionen für Eigenschaften
149 @cindex Objekte, Benennungskonventionen
150 @cindex Eigenschaften, Benennungskonventionen
151 @cindex Regeln zur Benennung von Objekten/Eigenschaften
152
153 Es wurden schon früher einige Regeln zur Benennung von
154 Objekten vorgestellt, siehe
155 @ref{Kontexte und Engraver}. Hier eine Referenzliste der
156 häufigsten Objekt- und Eigenschaftsbezeichnungen mit
157 den Regeln für ihre Bezeichnung und
158 illustrierenden echten Bezeichnungen. Es wurde @qq{A}
159 für einen beliebigen Großbuchstaben und @qq{aaa} für eine
160 beliebige Anzahl an Kleinbuchstaben eingesetzt. Andere
161 Zeichen werden explizit angegeben.
162
163 @multitable @columnfractions .33 .33 .33
164 @headitem Objekt-/Eigenschaftstyp
165   @tab Naming convention
166   @tab Beispiele
167 @item Kontexte
168   @tab Aaaa oder AaaaAaaaAaaa
169   @tab Staff, GrandStaff
170 @item Layout-Objekte
171   @tab Aaaa oder AaaaAaaaAaaa
172   @tab Slur, NoteHead
173 @item Engraver
174   @tab Aaaa_aaa_engraver
175   @tab Clef_engraver, Note_heads_engraver
176 @item Schnittstellen
177   @tab aaa-aaa-interface
178   @tab grob-interface, break-aligned-interface
179 @item Kontext-Eigenschaften
180   @tab aaa oder aaaAaaaAaaa
181   @tab alignAboveContext, skipBars
182 @item Layout-Objekt-Eigenschaften
183   @tab aaa oder aaa-aaa-aaa
184   @tab direction, beam-thickness
185 @end multitable
186
187 Es wird bald ersichtlich werden, dass die Eigenschaften von
188 unterschiedlichen Objekttypen mit unterschiedlichen Befehlen
189 geändert werden. Deshalb ist es nützlich, aus der
190 Schreibweise zu erkennen, um was
191 für ein Objekt es sich handelt, um den entsprechenden
192 Befehl einsetzen zu können.
193
194
195 @node Optimierungsmethoden
196 @subsection Optimierungsmethoden
197 @translationof Tweaking methods
198
199 @cindex override-Befehl
200 @funindex \override
201 @funindex override
202
203 @strong{Der \override-Befehl}
204
205 Wir haben uns schon mit den Befehlen @code{\set}
206 und @code{\with} bekannt gemacht, mit welchen
207 Eigenschaften von @strong{Kontexten} verändert
208 und @strong{Engraver} entfernt oder hinzugefügt
209 werden können. Siehe dazu
210 @ref{Kontexteigenschaften verändern} und @ref{Engraver hinzufügen und entfernen}. Jetzt wollen wir uns weitere
211 wichtige Befehle anschauen.
212
213 Der Befehl, um die Eigenschaften von @strong{Layout-Objekten}
214 zu ändern, ist @code{\override}. Weil dieser Befehl interne
215 Eigenschaften tief in der Programmstruktur von LilyPond
216 verändern muss, ist seine Syntax nicht so einfach wie die der
217 bisherigen Befehle. Man muss genau wissen, welche Eigenschaft
218 welches Objektes in welchem Kontext geändert werden soll,
219 und welches der neu zu setzende Wert dann ist. Schauen wir
220 uns an, wie das vor sich geht.
221
222 Die allgemeine Syntax dieses Befehles ist:
223
224 @example
225 \override @var{Kontext}.@var{LayoutObjekt} #'@var{layout-eigenschaft} =
226 #@var{Wert}
227 @end example
228
229 @noindent
230 Damit wir die Eigenschaft mit der Bezeichnung @var{layout-property}
231 das Layout-Objektes mit der Bezeichnung@var{LayoutObject},
232 welches ein Mitglied des @var{Kontext}-Kontextes ist, auf den
233 Wert @var{value}.
234
235 Der @var{Kontext} kann (und wird auch normalerweise) ausgelassen
236 werden, wenn der benötigte Kontext eindeutig impliziert ist und einer
237 der untersten Kontexte ist, also etwa @code{Voice}, @code{ChordNames}
238 oder @code{Lyrics}. Auch in diesem Text wird der Kontext oft ausgelassen
239 werden. Später soll gezeigt werden, in welchen Fällen er ausdrücklich
240 definiert werden muss.
241
242 Spätere Abschnitte behandeln umfassend Eigenschaften und ihre
243 Werte, siehe @ref{Typen von Eigenschaften}. Aber um ihre Funktion und ihr
244 Format zu demonstrieren,
245 werden wir hier nur einige einfache Eigenschaften und Werte einsetzen,
246 die einfach zu verstehen sind.
247
248 Für den Moment könne Sie die @code{#'}-Zeichen ignorieren, die vor jeder
249 Layout-Eigenschaft, und die @code{#}-Zeichen, die vor jedem Wert
250 stehen. Sie müssen immer in genau dieser Form geschrieben werden.
251 Das ist der am häufigsten gebrauchte Befehl für die Optimierung,
252 und der größte Teil dieses Abschnittes wird dazu benutzt, seine Benutzung
253 zu erläutern. Hier ein einfaches Beispiel, um die Farbe des Notenkopfes
254 zu ändern:
255
256 @cindex color-Eigenschaft, Beispiel
257 @cindex Farb-Eigenschaft, Beispiel
258 @cindex NoteHead, Beispiel für override
259 @cindex Notenkopf, Beispiel für Veränderung
260
261 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
262 c4 d
263 \override NoteHead #'color = #red
264 e4 f |
265 \override NoteHead #'color = #green
266 g4 a b c |
267 @end lilypond
268
269
270 @strong{Der \revert-Befehl}
271
272 @cindex revert-Befehl
273 @funindex \revert
274 @funindex revert
275
276 Wenn eine Eigenschaft einmal überschrieben wurde, wird ihr
277 neuer Wert so lange bewahrt, bis er noch einmal überschrieben
278 wird oder ein @code{\revert}-Befehl vorkommt. Der
279 @code{\revert}-Befehl hat die folgende Syntax und setzt den
280 Wert der Eigenschaft zurück auf den Standardwert, nicht
281 jedoch auf den vorigen Wert, wenn mehrere
282 @code{\override}-Befehle benutzt wurden.
283
284 @example
285 \revert @var{Kontext}.@var{LayoutObjekt} #'@var{layout-eigenschaft}
286 @end example
287
288 Wiederum, genauso wie der @var{Kontext} bei dem @code{\override}-Befehl,
289 wird @var{Kontext} oft nicht benötigt. Er wird in vielen der folgenden
290 Beispiele ausgelassen. Im nächsten Beispiel wird die Farbe des Notenkopfes
291 wieder auf den Standardwert für die letzten zwei Noten gesetzt.
292
293 @cindex color-Eigenschaft, Beispiel
294 @cindex Farb-Eigenschaft, Beispiel
295 @cindex NoteHead, Beispiel für override
296 @cindex Notenkopf, Beispiel für Veränderung
297
298 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
299 c4 d
300 \override NoteHead #'color = #red
301 e4 f |
302 \override NoteHead #'color = #green
303 g4 a
304 \revert NoteHead #'color
305 b4 c |
306 @end lilypond
307
308 @strong{\once-Präfix}
309
310 @funindex \once
311 @funindex once
312
313 Sowohl der @code{\override}-Befehl als auch der @code{\set}-Befehl können mit
314 dem Präfix @code{\once} (@emph{einmal}) versehen werden.  Dadurch wird
315 der folgende @code{\override}- oder @code{\set}-Befehl nur für den aktuellen
316 Musik-Moment wirksam, bevor sich wieder der vorherige Zustand herstellt
317 (dieser kann sich vom Standard unterscheiden, wenn etwa noch ein anderer
318 @code{\override}-Befehl aktiv ist).  Am gleichen
319 Beispiel demonstriert, kann damit die Farbe eines einzelnen Notenkopfes
320 geändert werden:
321
322 @cindex color-Eigenschaft, Beispiel
323 @cindex Farb-Eigenschaft, Beispiel
324 @cindex NoteHead, Beispiel für override
325 @cindex Notenkopf, Beispiel für Veränderung
326
327 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
328 c4 d
329 \override NoteHead #'color = #red
330 e4 f |
331 \once \override NoteHead #'color = #green
332 g4 a
333 \revert NoteHead #'color
334 b c |
335 @end lilypond
336
337
338 @strong{Der \overrideProperty-Befehl}
339
340 @cindex overrideProperty-Befehl
341
342 @funindex \overrideProperty
343 @funindex overrideProperty
344
345 Es gibt eine andere Form des @code{override}-Befehls,
346 @code{\overrideProperty} (überschreibe Eigenschaft),
347 welcher ab und zu benötigt wird.  Es wird hier nur der
348 Vollständigkeit halber erwähnt, sein Einsatz wird demonstriert
349 in @rextend{Schwierige Korrekturen}.
350 @c Maybe explain in a later iteration  -td
351
352
353 @strong{Der \tweak-Befehl}
354
355 @cindex tweak-Befehl
356 @funindex \tweak
357 @funindex tweak
358
359 Der letzte Optimierungsbefehl in LilyPond ist @code{\tweak}
360 (engl. optimieren).  Er wird eingesetzt um Eigenschaften
361 nur eines Objektes von mehreren Objekten zu verändern,
362 die zum selben Musik-Moment
363 auftreten, wie etwa die Noten eines Akkordes.  Ein
364 @code{\override} würde alle Noten des Akkords beeinflussen,
365 während mit @code{\tweak} nur das nächste Objekt der
366 Eingabe geändert wird.
367
368 Hier ein Beispiel. Angenommen, die Größe des mittleren
369 Notenkopfes (ein E) in einem C-Dur-Akkord soll geändert
370 werden.  Schauen wir zuerst, was wir mit
371 @code{\once \override} erhalten:
372
373 @cindex Schriftgröße, Beispiel
374 @cindex NoteHead, Beispiel für override
375 @cindex Notenkopf, Beispiel für Veränderung
376
377 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
378 <c e g>4
379 \once \override NoteHead #'font-size = #-3
380 <c e g>4
381 <c e g>4
382 @end lilypond
383
384 Wie man sehen kann, beeinflusst @code{override} @emph{alle}
385 Notenköpfe des Akkordes.  Das liegt daran, dass alle die Noten
386 eines Akkordes zum selben Musik-Moment auftreten und
387 die Funktion von @code{\once} ist es, die Optimierung auf
388 an allen Objekten auszuführen, die zum selben Musik-Moment
389 auftreten wie der @code{\override}-Befehl.
390
391 Der @code{\tweak}-Befehl funktioniert anders. Er bezieht sich
392 auf das direkt folgende Element in der Eingabe-Datei.  In seiner
393 einfachsten Form ist der Befehl nur an Objekten wirksam, die direkt
394 vom vorhergehenden Element erstellt worden sind, insbesondere
395 Notenköpfe und Artikulation.
396
397 Um also zu unserem Beispiel zurückzukommen, könnte man die
398 mittlere Note eines Akkordes auf diese Weise ändern:
399
400 @cindex font-size-Eigenschaft, Beispiel
401 @cindex Schriftgröße, Beispiel
402 @cindex @code{\tweak}-Beispiel
403
404 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
405 <c e g>4
406 <c \tweak #'font-size #-3 e g>4
407 @end lilypond
408
409 Beachten Sie, dass die Syntax des @code{\tweak}-Befehls sich
410 von der des @code{\override}-Befehls unterscheidet. Der
411 Kontext dürfen nicht angegeben werden, denn
412 das würde zu einem Fehler führen. Sowohl Kontext als auch das Layout-Objekt sind
413 durch das folgende Element im Inputstream impliziert. Hier sollte auch
414 kein Gleichheitszeichen vorhanden sein.  Die verallgemeinerte
415 Syntax des @code{\tweak}-Befehls ist also
416
417 @example
418 \tweak #'@var{layout-eigenschaft} #@var{Wert}
419 @end example
420
421 Ein @code{\tweak}-Befehl kann auch benutzt werden, um nur
422 eine von mehreren Artikulationen zu ändern, wie im nächsten
423 Beispiel zu sehen ist.
424
425 @cindex Farb-Eigenschaft, Beispiel
426 @cindex @code{\tweak}-Beispiel
427
428 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
429 a4^"Black"
430   -\tweak #'color #red ^"Red"
431   -\tweak #'color #green _"Green"
432 @end lilypond
433
434 @noindent
435 Beachten Sie, dass ein Artikulationsmodifikator vor dem @code{\tweak}-Befehl
436 geschrieben werden muss, weil auch der @code{\tweak}-Ausdruck als
437 Artikulation angefügt wird.  Im Falle von mehreren Richtungsmodifikatoren
438 (@code{^} or @code{_}) gilt der Modifikator links außen, weil er als
439 letzter angefügt wird.
440
441 @cindex @code{\tweak}, Versetzungszeichen
442 @cindex @code{\tweak}, bestimmtes Layout-Objekt
443
444 Objekte wie Hälse und Versetzungszeichen werden später erstellt und nicht
445 direkt aus dem vorhergehenden Ereignis.  Es ist dennoch möglich, @code{\tweak}
446 mit solchen indirekt erstelltn Objekten zu verwenden, indem man die
447 Layout-Objekte direkt benennt, vorausgesetzt dass LilyPond ihre Herkunft
448 bis zu dem ursprünglichen Ereignis zurück verfolgen kann:
449
450 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
451 <\tweak Accidental #'color #red   cis4
452  \tweak Accidental #'color #green es
453                                   g>
454 @end lilypond
455
456 Diese Langform des @code{\tweak}-Befehls kann wie folgend beschrieben werden:
457
458 @example
459 \tweak @var{layout-object} #'@var{layout-property} @var{value}
460 @end example
461
462 @cindex Triolen, geschachtelt
463 @cindex N-tolen, geschachtelt
464 @cindex Klammer, Triole
465 @cindex Triolenklammer
466 @cindex N-tolenklammer
467 @cindex Komplizierte Rhythmen, Schachtelung von
468 @funindex TupletBracket
469
470 Der @code{\tweak}-Befehl muss auch benutzt werden, wenn das
471 Aussehen einer vor mehreren geschachtelten Triolenklammern
472 geändert werden soll, die zum selben Zeitpunkt beginnen.
473 Im folgenden Beispiel beginnen die lange Klammer und die
474 erste Triolenklammer zum selben Zeitpunkt, sodass ein
475 @code{\override}-Befehl sich auf beide beziehen würde.
476 In dem Beispiel wird @code{\tweak} benutzt, um zwischen
477 ihnen zu unterscheiden. Der erste @code{\tweak}Befehl
478 gibt an, dass die lange Klammer über den Noten gesetzt
479 werden soll, und der zweite, dass die Zahl der rhythmischen
480 Aufteilung für die erste der kurzen Klammern in rot
481 gesetzt wird.
482
483 @cindex Farb-Eigenschaft, Beispiel
484 @cindex @code{\tweak}-Beispiel
485 @cindex Richtungs-Eigenschaft, Beispiel
486 @cindex color-Eigenschaft, Beispiel
487 @cindex direction-Eigenschaft, Beispiel
488
489 @lilypond[quote,ragged-right,verbatim,fragment,relative=2]
490 \tweak #'direction #up
491 \times 4/3 {
492   \tweak #'color #red
493   \times 2/3 { c8[ c c] }
494   \times 2/3 { c8[ c c] }
495   \times 2/3 { c8[ c c] }
496 }
497 @end lilypond
498
499 Wenn geschachtelte N-tolen nicht zum gleichen Zeitpunkt
500 beginnen, kann ihr Aussehen auf die übliche Art mit dem
501 @code{\override}-Befehl geändert werden:
502
503 @cindex text-Eigenschaft, Beispiel
504 @cindex tuplet-number-Funktion, Beispiel
505 @cindex transparent-Eigenschaft, Beispiel
506 @cindex TupletNumber, Beispiel zur Veränderung
507 @cindex Triolennummer, Beispiel zur Veränderung
508 @cindex Triolen-Nummer-Funktion, Beispiel
509
510 @c NOTE Tuplet brackets collide if notes are high on staff
511 @c See issue 509
512 @lilypond[quote,ragged-right,verbatim,fragment,relative=1]
513 \times 2/3 { c8[ c c] }
514 \once \override TupletNumber
515   #'text = #tuplet-number::calc-fraction-text
516 \times 2/3 {
517   c8[ c]
518   c8[ c]
519   \once \override TupletNumber #'transparent = ##t
520   \times 2/3 { c8[ c c] }
521   \times 2/3 { c8[ c c] }
522 }
523 @end lilypond
524
525
526 @seealso
527 Notationsreferenz:
528 @ruser{Der tweak-Befehl}.
529
530
531 @node Die Referenz der Programminterna
532 @section Die Referenz der Programminterna
533 @translationof The Internals Reference manual
534
535 @menu
536 * Eigenschaften von Layoutobjekten::
537 * Eigenschaften die Schnittstellen besitzen können::
538 * Typen von Eigenschaften::
539 @end menu
540
541 @node Eigenschaften von Layoutobjekten
542 @subsection Eigenschaften von Layoutobjekten
543 @translationof Properties of layout objects
544
545 @cindex Eigenschaften von Layout-Objekten
546 @cindex Eigenschaften von Grobs
547 @cindex Grobs, Eigenschaften von
548 @cindex Layout-Objekte, Eigenschaften von
549 @cindex Property (Layout-Objekte, Grobs)
550 @cindex Regerenz der Interna
551
552 Angenommen, in Ihrer Partitur tritt ein Legatobogen
553 auf, der Ihrer Meinung nach zu dünn ausgefallen ist.
554 Sie würden ihn gerne etwas schwerer gezeichnet
555 sehen. Wie gehen Sie vor? Von den Anmerkungen in
556 früheren Abschnitten wissen Sie schon, dass LilyPond
557 sehr flexibel ist und eine derartige Modifikation
558 möglich sein sollte, und Sie erraten vielleicht,
559 dass ein @code{\override}-Befehl angebracht ist.
560 Aber gibt es eine Eigenschaft für die Dicke eines
561 Legatobogens (engl. slur), und wenn es sie gibt,
562 auf welche Weise lässt sie sich verändern? Hier
563 kommt die Referenz der Interna zur Geltung. Dort
564 finden sich alle Informationen, um den beschriebenen
565 und alle anderen @code{\override}-Befehle zu
566 konstruieren.
567
568 Bevor Sie jetzt in die Referenz der Interna wechseln, ist
569 eine Warnung angebracht. Es handelt sich um ein
570 @strong{Referenz}dokument, was heißt, dass es sehr
571 wenig oder gar keine Erklärungen enthält: seine Aufgabe
572 ist es, Information klar und genau darzustellen. Das
573 bedeutet, dass es auf den ersten Blick entmutigend
574 wirkt. Die Einführung und Erklärung in diesem Abschnitt
575 wird Ihnen aber schnell ermöglichen, genau die Information
576 aus der Referenz zu entnehmen, die Sie benötigen.
577 @c For German users
578 Beachten Sie, dass die Referenz der Interna nur auf Englisch
579 existiert. Um die Eigenschaftsbezeichnung eines bestimmten
580 Objektes zu finden, können Sie das Glossar (siehe
581 @rglosnamed{Top,Musikglossar})
582  verwenden, in dem
583 die englischen Begriffe in viele andere Sprachen übersetzt sind.
584
585 @cindex Override-Beispiel
586 @cindex Referenz der Interna, Benutzung
587 @cindex IR (Referenz der Interna), Benutzung
588 @cindex @code{\addlyrics}-Beispiel
589
590 Das Vorgehen soll an einem konkreten Beispiel einer echten
591 Komposition demonstriert werden. Hier das Beispiel:
592
593 @c Mozart, Die Zauberflöte Nr. 7 Duett
594
595 @lilypond[quote,verbatim,relative=2]
596 {
597   \key es \major
598   \time 6/8
599   {
600     r4 bes8 bes[( g]) g |
601     g8[( es]) es d[( f]) as |
602     as8 g
603   }
604   \addlyrics {
605     The man who | feels love's sweet e -- | mo -- tion
606   }
607 }
608 @end lilypond
609
610 Angenommen also, wir wollen die Legatobögen etwas
611 dicker setzten. Ist das möglich? Die Legatobögen sind mit
612 Sicherheit ein Layout-Objekt, die Frage muss also lauten:
613 @qq{Gibt es eine Eigenschaft von Legatobögen, die die
614 Dicke bestimmt?} Um diese Frage zu beantworten, müssen
615 wir in der Referenz der Interna ( kurz IR) nachschauen.
616
617 Die IR für die LilyPond-Version, die Sie benutzen, findet sich
618 auf der LilyPond-Webseite unter der Adresse
619 @uref{http://lilypond.org}. Gehen Sie zur Dokumentationsseite
620 und klicken Sie auf den Link zur Referenz der Interna.
621 @c Addition for German users
622 Die Sprache ändert sich ab hier nach englisch. Für diese Übung
623 sollten Sie die HTML-Version benutzen, nicht die
624 @qq{auf einer großen Seite} oder die PDF-Version.
625 Damit Sie die nächsten Absätze verstehen können, müssen Sie
626 genauso vorgehen, während Sie weiterlesen.
627
628 Unter der Überschrift @strong{Top} befinden sich fünf Links.
629 Wählen Sie den Link zum @emph{Backend}, wo sich die Information
630 über Layout-Objekte befindet. Hier, unter der Überschrift
631 @strong{Backend}, wählen Sie den Link @emph{All layout objects}.
632 Die Seite, die sich öffnet, enthält ein Liste aller Layout-Objekte,
633 die in Ihrerer LilyPond-Version benutzt werden, in alphabetischer
634 Ordnung. Wählen Sie den Link @emph{Slur} und die Eigenschaften
635 der Legatobögen (engl. slur) werden aufgelistet.
636
637 Eine alternative Methode, auf diese Seite zu gelangen, ist von
638 der Notationsreferenz aus. Auf einer der Seiten zu Legatobögen
639 findet sich ein Link zur Referenz der Interna. Dieser Link führt
640 Sie direkt auf diese Seite. Wenn Sie aber eine Ahnung haben,
641 wie die Bezeichnung des Layout-Objektes lauten könnte, das sie
642 ändern wollen, ist es oft schneller, direkt zur IR zu gehen und
643 dort nachzuschlagen.
644
645 Aus der Slur-Seite in der IR könne wir entnehmen, dass
646 Legatobögen (Slur-Objekte) durch den Slur_engraver erstellt
647 werden. Dann werden die Standardeinstellungen aufgelistet.
648 Beachten Sie, dass diese @strong{nicht} in alphabetischer Reihenfolge
649 geordnet sind. Schauen Sie sich die Liste an, ob sie eine Eigenschaft
650 enthält, mit der die Dicke von Legatobögen kontrolliert werden kann.
651 Sie sollten folgendes finden:
652
653 @example
654 @code{thickness} (number)
655      @code{1.2}
656      Line thickness, generally measured in @code{line-thickness}
657 @end example
658
659 Das sieht ganz danach aus, als ob damit die Dicke geändert
660 werden kann.  Es bedeutet, dass der Wert von
661 @code{thickness} einfach eine Zahl (@emph{number}) ist,
662 dass der Standardwert 1.2 ist, und dass die Einheit
663 für die Dicke eine andere Eigenschaft mit der
664 Bezeichnung @code{line-thickness} ist.
665
666 Wie schon früher gesagt, gibt es wenig bis gar keine Erklärungen
667 in der IR, aber wir haben schon genug Informationen, um
668 zu versuchen, die Dicke eines Legatobogens zu ändern.  Die
669 Bezeichnung des Layout-Objekts ist offensichtlich @code{Slur}
670 und die Bezeichnung der Eigenschaft, die geändert werden soll
671 @code{thickness}.  Der neue Wert sollte etwas mehr als 1.2 sein,
672 denn der Bogen soll ja dicker werden.
673
674 Den benötigten @code{\override}-Befehl können wir jetzt einfach
675 konstruieren, indem wir die Werte für die Bezeichnungen in den
676 Modellbefehl einfügen und den Kontext auslassen.  Setzen wir
677 einmal einen sehr großen Wert für die Dicke um zu sehen, ob der
678 Befehl auch funktioniert.  Also:
679
680 @example
681 \override Slur #'thickness = #5.0
682 @end example
683
684 Vergessen Sie nicht das Rautenzeichen und Apostroph
685 (@code{#'}) vor der Eigenschaftsbezeichnung und das
686 Rautenzeichen vor dem neuen Wert!
687
688 Die nächste Frage ist nun: @qq{Wohin soll dieser Befehl geschrieben
689 werden?} Solange wir uns noch im Lernstadium befinden, ist
690 die beste Antwort: @qq{Innerhalb der Noten, vor den ersten
691 Legatobogen und nahe bei ihm.} Also etwa so:
692
693 @cindex Legatobogen, Beispiel für Veränderung
694 @cindex thickness-Eigenschaft, Beispiel
695 @cindex Dicke-Eigenschaft, Beispiel
696
697 @lilypond[quote,verbatim,relative=2]
698 {
699   \key es \major
700   \time 6/8
701   {
702     % Increase thickness of all following slurs from 1.2 to 5.0
703     \override Slur #'thickness = #5.0
704     r4 bes8 bes[( g]) g |
705     g8[( es]) es d[( f]) as |
706     as8 g
707   }
708   \addlyrics {
709     The man who | feels love's sweet e -- | mo -- tion
710   }
711 }
712 @end lilypond
713
714 @noindent
715 und wirklich wird der Legatobogen dicker.
716
717 Das ist also die grundlegende Herangehensweise,
718 @code{\override}-Befehl zu formulieren. Es gibt einige
719 zusätzliche Komplikationen, denen wir uns später widmen
720 werden, aber Sie haben jetzt das Handwerkszeug, um Ihre
721 eigenen Befehle zu konstruieren -- wenn Sie auch noch etwas
722 Übung benötigen. Die sollen Sie durch die folgenden Übungen
723 erhalten.
724
725
726 @subheading Den Kontext finden
727
728 @cindex Kontext, Finden und identifizieren
729
730 Manchmal muss dennoch der Kontext spezifiziert werden.
731 Welcher aber ist der richtige Kontext? Wir könnten raten,
732 dass Legatobögen sich im @code{Voice}-Kontext befinden,
733 denn sie sind immer einzelnen Melodielinien zugewiesen.
734 Aber wir können uns dessen nicht sicher sein. Um unsere
735 Annahme zu überprüfen, gehen wir wieder zu der Seite im
736 IR, die die Legatobögen beschreibt und die Überschrift
737 @emph{Slur} hat. Dort steht: @qq{Slur objects are created
738 by: Slur engraver}. Legatobögen werden also in dem Kontext
739 erstellt, in dem sich der @code{Slur_engraver} befindet.
740 Folgen Sie dem Link zu der @code{Slur_engraver}-Seite.
741 Unten auf der Seite steht, dass der @code{Slur_engraver}
742 sich in fünf Stimmen-Kontexten befindet, unter anderem
743 auch im normalen @code{Voice}-Kontext. Unsere Annahme
744 war also richtig. Und weil @code{Voice} einer der Kontexte
745 der untersten Ebene ist, welcher eindeutig schon dadurch
746 definiert ist, dass wir Noten eingeben, kann er an dieser Stelle
747 auch weggelassen werden.
748
749
750 @subheading Nur einmal mit \override verändern
751
752 @cindex Override nur einmal
753 @cindex once override
754 @funindex \once
755 @funindex once
756
757 Im Beispiel oben wurden @emph{alle} Legatobögen dicker
758 gesetzt. Vielleicht wollen Sie aber nur den ersten Bogen
759 dicker haben. Das können Sie mit dem @code{\once}-Befehl
760 erreichen. Er wird direkt vor den @code{\override}-Befehl
761 gesetzt und bewirkt, dass nur der Bogen geändert wird, der
762 @strong{unmittelbar an der nächsten Note beginnt.} Wenn
763 die nächste Note keinen Bogenbeginn hat, dann passiert
764 gar nichts -- der Befehl wird nicht gespeichert, sondern einfach
765 vergessen. Der Befehl, mit @code{\once} zusammen benutzt,
766 muss also wie folgt positioniert werden:
767
768 @cindex Legatobogen, Beispiel zur Veränderung
769 @cindex thickness-Eigenschaft, Beispiel
770
771 @lilypond[quote,verbatim,relative=2]
772 {
773   \time 6/8
774   {
775     \key es \major
776     r4 bes8
777     % Increase thickness of immediately following slur only
778     \once \override Slur #'thickness = #5.0
779     bes8[( g]) g |
780     g8[( es]) es d[( f]) as |
781     as8 g
782   }
783   \addlyrics {
784     The man who | feels love's sweet e -- | mo -- tion
785   }
786 }
787 @end lilypond
788
789 @noindent
790 Jetzt bezieht er sich nur noch auf den ersten Legatobogen.
791
792 Der @code{\once}-Befehl kann übrigens auch vor einem @code{\set}-Befehl
793 eingesetzt werden.
794
795
796 @subheading Rückgängig machen
797
798 @cindex Revert
799 @cindex Rückgängig machen
800 @cindex Wiederherstellen von Standardeinstellungen
801 @cindex Standardeinstellungen, Wiederherstellen
802 @funindex \revert
803 @funindex revert
804
805 Eine weitere Möglichkeit: nur die beiden ersten Legatobögen sollen
806 dicker gesetzt werden. Gut, wir könnten jetzt zwei Befehle benutzen,
807 jeden mit dem @code{\once}-Präfix und direkt vor die entsprechende
808 Note gestellt, an welcher der Bogen beginnt:
809
810 @cindex Legatobogen, Beispiel zur Veränderung
811 @cindex thickness-Eigenschaft, Beispiel
812
813 @lilypond[quote,verbatim,relative=2]
814 {
815   \key es \major
816   \time 6/8
817   {
818     r4 bes8
819     % Increase thickness of immediately following slur only
820     \once \override Slur #'thickness = #5.0
821     bes[( g]) g |
822     % Increase thickness of immediately following slur only
823     \once \override Slur #'thickness = #5.0
824     g8[( es]) es d[( f]) as |
825     as8 g
826   }
827   \addlyrics {
828     The man who | feels love's sweet e -- | mo -- tion
829   }
830 }
831 @end lilypond
832
833 @noindent
834 Wir könnten aber auch den @code{\once}-Befehl weglassen und anstelle
835 dessen später den @code{\revert}-Befehl einsetzen, um die
836 @code{thickness}-Eigenschaft wieder auf ihren Standardwert zurückzusetzen:
837
838 @cindex Legatobogen, Beispiel zur Veränderung
839 @cindex thickness-Eigenschaft, Beispiel
840
841 @lilypond[quote,verbatim,relative=2]
842 {
843   \key es \major
844   \time 6/8
845   {
846     r4 bes8
847     % Increase thickness of all following slurs from 1.2 to 5.0
848     \override Slur #'thickness = #5.0
849     bes[( g]) g |
850     g8[( es]) es
851     % Revert thickness of all following slurs to default of 1.2
852     \revert Slur #'thickness
853     d8[( f]) as |
854     as8 g
855   }
856   \addlyrics {
857     The man who | feels love's sweet e -- | mo -- tion
858   }
859 }
860 @end lilypond
861
862 @noindent
863 Der @code{\revert}-Befehl kann benutzt werden, um eine beliebige
864 Eigenschaft, die mit @code{\override} geändert worden ist, wieder in
865 ihre Standardeinstellungen zurückzuversetzen. In unserem Beispiel können
866 Sie die Methode benutzen, die Ihnen lieber ist, beide haben das gleiche
867 Resultat.
868
869 Damit endet die Einleitung in die Referenz der Interna (IR) und die
870 grundlegenden Optimierungsmethoden. Einige Beispiele folgen in späteren
871 Abschnitten dieses Kapitel, einerseits um Sie mit weiteren Möglichkeiten
872 der IR bekanntzumachen, andererseits um Ihnen mehr Übungsmöglichkeiten
873 zu geben, die relevante Information dort zu finden. Die Beispiele werden
874 Schritt für Schritt immer weniger Erklärungen beinhalten.
875
876
877 @node Eigenschaften die Schnittstellen besitzen können
878 @subsection Eigenschaften, die Schnittstellen besitzen können
879 @translationof Properties found in interfaces
880
881 @cindex Interface-Eigenschaften
882 @cindex Eigenschaften von Interfaces
883 @cindex Schnittstellen, Eigenschaften von
884 @cindex Eigenschaften von Schnittstellen
885
886 Der Text unseres Beispiels soll jetzt kursiv gesetzt werden. Was für
887 ein @code{\override}-Befehl wird dazu benötigt? Schauen wir
888 uns zunächst das Inhaltsverzeichnis in der IR an: @qq{All layout objects},
889 wie auch schon zuvor. Welches Objekt könnte die Darstellung des
890 Textes (engl. lyrics) beeinflussen? Es gibt den Eintrag @code{LyricText},
891 das hört sich schon sehr gut an. Ein Klick hierauf zeigt alle Eigenschaften
892 an, die verändert werden können. Dazu gehört
893 @code{font-series} und @code{font-size}, aber nichts, womit man kursiven
894 Text erreichen könnte. Das liegt daran, dass die Schnitteigenschaft allen
895 Schrift-Objekten gemeinsam ist. Sie findet sich also nicht in jedem einzelnen
896 Layout-Objekt aufgelistet, sondern ist mit anderen ähnlichen Eigenschaften
897 zusammen in einem @strong{Interface} -- einer Schnittstelle -- verortet;
898 in diesem Fall das
899 @code{font-interface}.
900
901 Jetzt müssen wir also lernen, wie wir Eigenschaften von Schnittstellen finden
902 und wie wir herausfinden, welche Objekte diese Schnittstelleneigenschaften
903 benutzen.
904
905 Schauen Sie sich noch einmal die Seite in der IR an, die @code{LyricText}
906 beschreibt. Unten auf der Seite ist eine klickbare Liste (in der HTML-Version
907 der IR) an Eigenschaften, die von @code{LyricText} unterstützt
908 werden. Diese Liste enthält sieben Einträge, darunter auch
909 @code{font-interface}. Ein Klick hierauf bringt uns zu den Eigenschaften,
910 die mit dieser Schnittstelle verbunden sind, also auch @code{LyricText}.
911
912 Jetzt sehen wir alle die Eigenschaften, die der Benutzer verändern kann,
913 um die Schriftartendarstellung zu beeinflussen. Dazu gehört nun auch
914 @code{font-shape(symbol)}, wobei @code{symbol} auf die Werte
915 @code{upright} (gerade), @code{italics} (kursiv) oder @code{caps}
916 (Kapitälchen) gesetzt werden kann.
917
918 Sie werden gemerkt haben, dass @code{font-series} und @code{font-size}
919 hier auch aufgelistet sind. Es stellt sich die Frage, warum diese
920 allgemeinen Schriftarteigenschaften @code{font-series} und
921 @code{font-size} sowohl unter der Überschrift
922 @code{LyricText} als unter dem @code{font-interface} aufgelistet
923 sind, aber @code{font-shape} befindet sich nur im
924 @code{font-interface}? Die Antwort ist: Die globalen Einstellungen
925 von @code{font-series} und @code{font-size} werden geändert, wenn
926 ein @code{LyricText}-Objekt erstellt wird, aber @code{font-shape}
927 wird davon nicht beeinflusst. Die zusätzlichen Einträge unter der
928 Überschrift @code{LyricText} beinhalten dann die Werte der
929 Standardeinstellungen dieser zwei Eigenschaften, wenn es sich
930 um ein @code{LyricText}-Objekt handelt. Andere Objekte,
931 die auch das @code{font-interface} unterstützen, setzen diese
932 Eigenschaften anders, wenn sie erstellt werden.
933
934 Versuchen wir nun einen @code{\override}-Befehl zu konstruieren,
935 der den Gesangstext kursiv setzt. Das Objekt hat die Bezeichnung
936 @code{LyricText}, die Eigenschaft ist @code{font-shape}
937 und der Wert @code{italic}. Wie vorher schon lassen wir den
938 Kontext aus.
939
940 Am Rande sei angemerkt, dass die Werte der @code{font-shape}-Eigenschaft
941 mit einem Apostroph (@code{'}) gekennzeichnet werden
942 müssen, weil es sich um Symbole handelt. Aus dem gleichen
943 Grund mussten auch für @code{thickness} weiter oben im
944 Text ein Apostroph gesetzt werden. Symbole sind besondere
945 Bezeichnungen, die LilyPond intern bekannt sind. Einige
946 sind Bezeichnungen von Eigenschaften, wie eben @code{thickness}
947 oder @code{font-shape}. Andere sind besondere Werte,
948 die an Eigenschaften übergeben werden können, wie
949 @code{italic}. Im Unterschied hierzu gibt es auch beliebige
950 Zeichenketten, die immer mit Anführungszeichen, also
951 als @code{"Zeichenkette"} auftreten. Für weitere
952 Einzelheiten zu Zeichenketten und Werten, siehe
953 @rextend{Scheme-Übung}.
954
955 Gut, der @code{\override}-Befehl, mit dem der Gesangstext
956 kursiv gesetzt wird, lautet:
957
958 @example
959 \override LyricText #'font-shape = #'italic
960 @end example
961
962 @noindent
963 und er muss direkt vor den Text gesetzt werden, auf den er sich
964 bezieht, etwa so:
965
966 @cindex font-shape-Eigenschaft, Beispiel
967 @cindex LyricText, Beispiel zur Veränderung
968 @cindex kursiv, Beispiel
969 @cindex @code{\addlyrics}, Beispiel
970
971 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
972 {
973   \key es \major
974   \time 6/8
975   {
976     r4 bes8 bes[( g]) g |
977     g8[( es]) es d[( f]) as |
978     as8 g
979   }
980   \addlyrics {
981     \override LyricText #'font-shape = #'italic
982     The man who | feels love's sweet e -- | mo -- tion
983   }
984 }
985 @end lilypond
986
987 @noindent
988 Jetzt wird der Text kursiv gesetzt.
989
990
991 @subheading Den Kontext im Liedtextmodus bestimmen
992
993
994 @cindex Kontext im Gesangstextmodus angeben
995 @cindex Gesangstextmodus, Kontext angeben
996
997 Bei Gesangstexten funktioniert der @code{\override}-Befehl
998 nicht mehr, wenn Sie den Kontext im oben dargestellten
999 Format angeben.  Eine Silbe wird im Gesangtextmodus
1000 (lyricmode) entweder von einem Leerzeichen, einer
1001 neuen Zeile oder einer Zahl beendet.  Alle anderen
1002 Zeichen werden als Teil der Silbe integriert.  Aus diesem
1003 Grund muss auch vor der schließenden Klammer
1004 @code{@}} ein Leerzeichen gesetzt oder eine neue
1005 Zeile begonnen werden.  Genauso müssen Leerzeichen
1006 vor und nach einem Punkt benutzt werden, um die
1007 Kontext-Bezeichnung von der Objekt-Bezeichnung zu
1008 trennen, denn sonst würden beide Bezeichnungen als
1009 ein Begriff interpretiert und von LilyPond nicht verstanden
1010 werden.  Der Befehl muss also lauten:
1011
1012 @example
1013 \override Lyrics . LyricText #'font-shape = #'italic
1014 @end example
1015
1016 @warning{Innerhalb von Gesangstext muss immer ein
1017 Leerzeichen zwischen der letzten Silbe und der schließenden
1018 Klammer gesetzt werden.}
1019
1020 @warning{Innerhalb von @code{\override}-Befehlen in
1021 Gesangstexten müssen Leerzeichen um Punkte zwischen
1022 Kontext- und Objektbezeichnungen gesetzt werden.}
1023
1024 @seealso
1025 Erweitern: @rextend{Scheme-Übung}.
1026
1027
1028 @node Typen von Eigenschaften
1029 @subsection Typen von Eigenschaften
1030 @translationof Types of properties
1031
1032 @cindex Eigenschaftsarten
1033
1034 Bis jetzt hatten wir es mit zwei Arten von Eigenschaften zu
1035 tun: @code{number} (Zahl) und @code{symbol}.  Damit
1036 ein Befehl funktioniert, muss der Wert einer Eigenschaft
1037 vom richtigen Typ sein und die Regeln befolgen, die
1038 für diesen Typ gelten.  Der Eigenschaftstyp ist in der
1039 IR in Klammern hinter der Eigenschaftsbezeichnung
1040 angegeben.  Hier eine Liste der Typen, die Sie vielleicht
1041 benötigen werden, mit den Regeln, die für den jeweiligen
1042 Typ gelten und einigen Beispielen. Sie müssen immer
1043 ein Rautenzeichen (@code{#}) vor den Typeintrag setzen,
1044 wenn sie in einem @code{\override}-Befehl benutzt werden.
1045
1046 @multitable @columnfractions .2 .45 .35
1047 @headitem Eigenschaftstyp
1048   @tab Regeln
1049   @tab Beispiele
1050 @item Boolesch
1051   @tab Entweder wahr oder falsch, dargestellt als #t oder #f
1052   @tab @code{#t}, @code{#f}
1053 @item Dimension (in Notenlinienabständen)
1054   @tab Eine positive Dezimalzahl (in Notenlinienabstand-Einheiten)
1055   @tab @code{2.5}, @code{0.34}
1056 @item Richtung
1057   @tab Eine gültige Richtungskonstante oder das numerische Äquivalent
1058   @tab @code{LEFT}, @code{CENTER}, @code{UP},
1059        @code{1}, @w{@code{-1}}
1060 @item Integer
1061   @tab Eine positive ganze Zahl
1062   @tab @code{3}, @code{1}
1063 @item Liste
1064   @tab Eine eingeklammerte Anzahl von Einträgen, mit Klammern getrennt
1065   und angeführt von einem Apostroph
1066   @tab @code{'(left-edge staff-bar)}, @code{'(1)},
1067        @code{'(1.0 0.25 0.5)}
1068 @item Textbeschriftung (markup)
1069   @tab Beliebige gültige Beschriftung
1070   @tab @code{\markup @{ \italic "cresc." @}}
1071 @item Moment
1072   @tab Ein Bruch einer ganzen Note, mit der make-moment-Funktion
1073   konstruiert
1074   @tab @code{(ly:make-moment 1 4)},
1075        @code{(ly:make-moment 3 8)}
1076 @item Zahl
1077   @tab Eine beliebige positive oder negative Dezimalzahl
1078   @tab @code{3.5}, @w{@code{-2.45}}
1079 @item Paar (Zahlenpaar)
1080   @tab Zwei Zahlen getrennt von @qq{Leerzeichen . Leerzeichen}, eingeklammert
1081   und angeführt von einem Apostroph
1082   @tab @code{'(2 . 3.5)}, @code{'(0.1 . -3.2)}
1083 @item Symbol
1084   @tab Eine beliebige Anzahl von Symbolen, die für die Eigenschaft
1085   gültig sind, angeführt von einem Apostroph
1086   @tab @code{'italic}, @code{'inside}
1087 @item Unbekannt
1088   @tab Eine Prozedur oder @code{#f} (um keine Aktion hervorzurufen)
1089   @tab @code{bend::print}, @code{ly:text-interface::print},
1090        @code{#f}
1091 @item Vektor
1092   @tab Eine Liste mit drei Einträgen, eingeklammert und mit
1093   Apostroph-Raute ( @code{'#}) angeführt.
1094   @tab @code{'#(#t #t #f)}
1095 @end multitable
1096
1097
1098 @seealso
1099 Erweitern: @rextend{Scheme-Übung}.
1100
1101
1102 @node Erscheinung von Objekten
1103 @section Erscheinung von Objekten
1104 @translationof Appearance of objects
1105
1106 In diesem Abschnitt wollen wir zeigen, wie die Kenntnisse der
1107 vorigen Abschnitte in der Praxis angewandt werden können,
1108 um das Aussehen des Musiksatzes zu beeinflussen.
1109
1110 @menu
1111 * Sichtbarkeit und Farbe von Objekten::
1112 * Größe von Objekten::
1113 * Länge und Dicke von Objekten::
1114 @end menu
1115
1116
1117 @node Sichtbarkeit und Farbe von Objekten
1118 @subsection Sichtbarkeit und Farbe von Objekten
1119 @translationof Visibility and color of objects
1120
1121 In Unterrichtsmaterial für den Musikunterricht wird oft
1122 eine Partitur dargestellt, in der bestimmte Notationselemente
1123 fehlen, so dass der Schüler die Aufgabe bekommt, die
1124 nachzutragen.  Ein einfaches Beispiel ist etwa, die
1125 Taktlinien zu entfernen, damit der Schüler sie selber zeichnen
1126 kann.  Aber die Tatklinien werden normalerweise automatisch
1127 eingefügt.  Wie verhindern wir, dass sie ausgegeben werden?
1128
1129 Bevor wir uns hieran machen, sei daran erinnert, dass
1130 Objekteigenschaften in sogenannten @emph{Schnittstellen}
1131 -- engl. interface -- gruppiert sind, siehe auch
1132 @ref{Eigenschaften die Schnittstellen besitzen können}.  Das dient ganz einfach
1133 dazu, die Eigenschaften zusammenzufassen, die üblicherweise
1134 zusammen benötigt werden -- wenn eine davon für ein Objekt
1135 gilt, dann auch die anderen.  Manche Objekte brauchen die
1136 Eigenschaften von der einen Schnittstelle, andere von einer
1137 anderen.  Die Schnittstellen, die die Eigenschaften von einem
1138 bestimmten Grob beinhalten, sind in der IR unten auf der
1139 Seite aufgelistet, die dieses Grob beschreibt.  Die Eigenschaften
1140 können betrachtet werden, indem die Seite der entsprechenden
1141 Schnittstelle geöffnet wird.
1142
1143 Zu Information, wie man Eigenschaften von Grobs findet, siehe
1144 @ref{Eigenschaften von Layoutobjekten}.  Wir benutzen also jetzt
1145 die selbe Methode um in der IR das Layout-Objekt zu finden,
1146 dass für die Tatklinien zuständig ist. Über die Überschriften
1147 @emph{Backend} und @emph{All layout objects} kommen
1148 wir zu einem Layout-Objekt mit der Bezeichnung
1149 @code{BarLine} (engl. TaktLinie).  Seine Eigenschaften
1150 beinhalten zwei, die über die Sichtbarkeit entscheiden:
1151 @code{break-visibility} und @code{stencil}.
1152 @code{BarLine} unterstützt auch einige Schnittstellen,
1153 unter anderem @code{grob-interface}, wo wir eine
1154 @code{transparent} und eine @code{color}-Eigenschaft
1155 finden.  Alle können die Sichtbarkeit von Taktlinien (und
1156 natürlich auch die Sichtbarkeit von vielen anderen Objekten)
1157 beeinflussen.  Schauen wir uns diese Eigenschaften eine
1158 nach der anderen an.
1159
1160 @subheading stencil (Matrize)
1161
1162 @cindex Stencil-Eigenschaft
1163 @cindex Matrizen-Eigenschaft
1164
1165 Diese Eigenschaft kontrolliert die Erscheinung der Taktlinien,
1166 indem sie das Symbol bestimmt, das ausgegeben werden soll.
1167 Wie bei vielen anderen Eigenschaften auch, kann sie so
1168 eingestellt werden, dass sie nichts ausgibt, indem ihr Wert
1169 auf @code{#f} (falsch) gesetzt wird.  Ein Versuch also,
1170 wie vorher, indem wir den impliziten Kontext (@code{Voice})
1171 auslassen:
1172
1173 @cindex Taktlinie, Beispiel zur Veränderung
1174 @cindex stencil-Eigenschaft, Beispiel
1175
1176 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1177 {
1178   \time 12/16
1179   \override BarLine #'stencil = ##f
1180   c4 b8 c d16 c d8
1181   g,8 a16 b8 c d4 e16 |
1182   e8
1183 }
1184 @end lilypond
1185
1186 Die Taktlinien werden aber immer noch angezeigt.  Was ist da
1187 falsch gelaufen?  Gehen Sie zurück zur IR und schauen Sie auf
1188 die Seite, die die Eigenschaften für @code{BarLine} angibt.
1189 Oben auf der Seite steht: @qq{Barline objects are created
1190 by: Bar_engraver}.  Schauen Sie sich die
1191 @code{Bar_engraver}-Seite an.  Unten auf der Seite steht
1192 eine Liste der Kontexte, in denen der Takt-Engraver
1193 funktioniert.  Alle Kontexte sind @code{Staff}-Typen (also
1194 Notensystem-Typen).  Der Grund, warum der
1195 @code{\override}-Befehl nicht funktioniert hat, liegt
1196 also darin, dass das Taktlinie-Objekt (@code{BarLine}) sich nicht
1197 im @code{Voice}-Kontext befindet.  Wenn der Kontext
1198 falsch angegeben wird, bewirkt der Befehl einfach gar
1199 nichts.  Keine Fehlermeldung wird ausgegeben und auch
1200 nichts in die Log-Datei geschrieben.  Versuchen wir also,
1201 den richtigen Kontext mit anzugeben:
1202
1203 @cindex Taktlinie, Beispiel zur Veränderung
1204 @cindex stencil-Eigenschaft, Beispiel
1205
1206 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1207 {
1208   \time 12/16
1209   \override Staff.BarLine #'stencil = ##f
1210   c4 b8 c d16 c d8
1211   g,8 a16 b8 c d4 e16
1212   e8
1213 }
1214 @end lilypond
1215
1216 @noindent
1217 Jetzt sind die Taktlinien wirklich verschwunden.
1218
1219 Es sollte jedoch beachtet werden, dass das Setzen der
1220 @code{stencil}-Eigenschaft auf @code{#f} zu Fehlerhinweisen führen
1221 kann, wenn die Dimensionen des Objekts für die richtige Behandlung
1222 benötigt werden.  Zum Beispiel werden Fehler ausgegeben, wenn
1223 die @code{stencil}-Eigenschaft des @code{NoteHead}-Objekts auf
1224 @code{#f} gesetzt wird. Wenn dieser Fall auftritt, kann anstatt
1225 dessen die @code{point-stencil}-Funktion benutzt werden, welche
1226 den Stencil auf ein Objekt mit der Größe Null setzt:
1227
1228 @lilypond[quote,verbatim,relative=2]
1229 {
1230   c4 c
1231   \once \override NoteHead #'stencil = #point-stencil
1232   c4 c
1233 }
1234 @end lilypond
1235
1236
1237 @subheading break-visibility (unsichtbar machen)
1238
1239 @cindex break-visibility-Eigenschaft
1240 @cindex Unsichtbar machen (break-visibility)
1241
1242 Aus der Beschreibung der Eigenschaften für @code{BarLine}
1243 in der IR geht hervor, dass die @code{break-visibility}-Eigenschaft
1244 einen Vektor mit drei Booleschen Werten benötigt. Diese
1245 kontrollieren jeweils, ob die Taktlinien am Ende einer Zeile,
1246 in der Mitte einer Zeile und am Anfang einer Zeile ausgegeben
1247 werden.  Wenn also alle Taktlinien unsichtbar sein sollen, wie in
1248 unserem Beispiel, brauchen wir den Wert @code{'#(#f #f #f)}.
1249 Versuchen wir es also, und berücksichtigen wir auch den
1250 @code{Staff}-Kontext.  Beachten Sie auch, dass Sie @code{#'#}
1251 vor der öffnenden Klammer schreiben müssen:
1252 @code{'#} wird benötigt als Teil des Wertes, um einen Vektor zu
1253 signalisieren, und das erste@tie{}@code{#} wird benötigt, um
1254 den Wert in einem @code{\override}-Befehl anzuführen.
1255
1256 @cindex Taktlinie, Beispiel zur Veränderung
1257 @cindex break-visibility-Eigenschaft, Beispiel
1258
1259 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1260 {
1261   \time 12/16
1262   \override Staff.BarLine #'break-visibility = #'#(#f #f #f)
1263   c4 b8 c d16 c d8 |
1264   g,8 a16 b8 c d4 e16 |
1265   e8
1266 }
1267 @end lilypond
1268
1269 @noindent
1270 Auch auf diesem Weg gelingt es, die Taktlinien unsichtbar zu machen.
1271
1272
1273 @subheading transparent (durchsichtig)
1274
1275 @cindex transparent-Eigenschaft
1276 @cindex Durchsichtig machen (transparent)
1277
1278 Aus den Eigenschaftsdefinitionen auf der @code{grob-interface}-Seite
1279 in der IR geht hervor, dass die @code{transparent}-Eigenschaft
1280 boolesch ist.  Mit @code{#t} (wahr) wird also ein Grob durchsichtig
1281 gemacht.  Im unserem Beispiel soll jetzt die Taktart durchsichtig
1282 gemacht werden, anstatt die Taktlinien durchsichtig zu machen.
1283 Wir brauchen also wieder die Grob-Bezeichnung für die Taktart.
1284 Auf der @qq{All layout objects}-Seite in der IR müssen wir die
1285 Eigenschaften des @code{TimeSignature}-Layout-Objekts suchen
1286 Das Objekt wird vom @code{Time_signature_engraver} erstellt,
1287 der sich auch im @code{Staff}-Kontext befindet und genauso das
1288 @code{grob-interface} unterstützt, wie Sie sich
1289 überzeugen können.  Der Befehl, um die Taktangabe unsichtbar zu
1290 machen, ist also:
1291
1292 @cindex Taktart, Beispiel zur Veränderung
1293 @cindex transparent-Eigenschaft, Beispiel
1294
1295 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1296 {
1297   \time 12/16
1298   \override Staff.TimeSignature #'transparent = ##t
1299   c4 b8 c d16 c d8 |
1300   g,8 a16 b8 c d4 e16 |
1301   e8
1302 }
1303 @end lilypond
1304
1305 @noindent
1306 Die Taktangabe ist verschwunden, aber mit diesem Befehl wird ein
1307 freier Platz gelassen, wo sich die Taktangabe eigentlich befinden
1308 würde.  Das braucht man vielleicht für eine Schulaufgabe, in der
1309 die richtige Taktangabe eingefügt werden soll, aber in anderen
1310 Fällen ist diese Lücke nicht schön.  Um auch die Lücke zu entfernen,
1311 muss die Matrize (stencil) der Taktangabe auf @code{#f} (falsch)
1312 gesetzt werden:
1313
1314 @cindex Taktart, Beispiel zur Veränderung
1315 @cindex stencil-Eigenschaft, Beispiel
1316
1317 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1318 {
1319   \time 12/16
1320   \override Staff.TimeSignature #'stencil = ##f
1321   c4 b8 c d16 c d8 |
1322   g,8 a16 b8 c d4 e16 |
1323   e8
1324 }
1325 @end lilypond
1326
1327 @noindent
1328 Und der Unterschied wird deutlich: hiermit wird das gesamte Objekt
1329 entfernt, während man mit @code{transparent} ein Objekt
1330 unsichtbar machen kann, es aber an seinem Platz gelassen wird.
1331
1332
1333 @subheading color (Farbe)
1334
1335 @cindex color-Eigenschaft
1336 @cindex Farb-Eigenschaft
1337
1338 Abschließend wollen wir die Taktlinien unsichtbar machen, indem
1339 wir sie weiß einfärben.  (Es gibt hier eine Schwierigkeit: die weiße
1340 Taktlinie übermalt manchmal die Taktlinien, wo sie sie kreuzt,
1341 manchmal aber auch nicht.  Sie können in den Beispielen unten
1342 sehen, dass das nicht vorhersagbar ist.  Die Einzelheiten dazu, warum
1343 das passiert und wie sie es kontrollieren können, werden dargestellt
1344 in @ruser{Objekte weiß malen}.  Im Moment wollen wir lernen, wie
1345 man mit Farbe arbeitet, akzeptieren Sie bitte an dieser Stelle die
1346 Beschränkung.)
1347
1348 Das @code{grob-interface} bestimmt, dass der Wert der Farb-Eigenschaft
1349 eine Liste ist, aber es gibt keine Erklärung, was für eine Liste das
1350 sein soll.  Die Liste, die benötigt wird, ist eine Liste mit Werten in
1351 internen Einheiten, aber damit Sie nicht wissen müssen, wie diese
1352 aussehen, gibt es mehrere Wege, Farben anzugeben.  Der erste
1353 Weg ist es, @qq{normale} Farben zu benutzen, wie sie in der
1354 Tabelle in @ruser{Liste der Farben} aufgelistet sind.  Beachten Sie,
1355 dass die Bezeichnungen auf Englisch sind.  Um die Taktlinien auf
1356 weiß zu setzen, können Sie schreiben:
1357
1358 @cindex Taktlinie, Beispiel zur Veränderung
1359 @cindex color-Eigenschaft, Beispiel
1360
1361 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1362 {
1363   \time 12/16
1364   \override Staff.BarLine #'color = #white
1365   c4 b8 c d16 c d8 |
1366   g,8 a16 b8 c d4 e16 |
1367   e8
1368 }
1369 @end lilypond
1370
1371 @noindent
1372 und die Taktlinien verschwinden in der Tat.  Beachten Sie,
1373 dass @emph{white} nicht mit einem Apostroph angeführt
1374 wird -- es ist kein Symbol, sondern eine @emph{Funktion}.
1375 Wenn sie aufgerufen wird, stellt sie eine Liste mit internen
1376 Werten zu Verfügung, mit welcher die Farbe auf weiß
1377 gestellt wird.  Die anderen Farben in der Liste sind auch
1378 Funktionen.  Um sich zu überzeugen, dass der Befehl auch
1379 wirklich funktioniert, können Sie die Farbe auf eine der
1380 anderen Funktionen dieser Liste abändern.
1381
1382 @cindex Farben, X11
1383 @cindex X11-Farben
1384 @funindex x11-color
1385
1386 Die zweite Art die Farbe zu ändern geschieht, indem die Liste
1387 der X11-Farbbezeichnungen einzusetzen, siehe die zweite Liste
1388 in @ruser{Liste der Farben}.  Diesen Farben muss jedoch eine
1389 andere Funktion vorangestellt werden, die die X11-Farbbezeichnungen
1390 in interne Werte konvertiert:
1391 @code{x11-color}.  Das geschieht wie folgt:
1392
1393 @cindex Taktlinie, Beispiel zur Veränderung
1394 @cindex color-Eigenschaft, Beispiel
1395
1396 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1397 {
1398   \time 12/16
1399   \override Staff.BarLine #'color = #(x11-color 'white)
1400   c4 b8 c d16 c d8 |
1401   g,8 a16 b8 c d4 e16 |
1402   e8
1403 }
1404 @end lilypond
1405
1406 @noindent
1407 In diesem Fall hat die Funktion @code{x11-color} ein Symbol
1408 als Argument, darum muss dem Symbol ein Apostroph vorangestellt
1409 und beide zusammen in Klammern gesetzt werden.
1410
1411 @cindex RGB-Farben
1412 @cindex Farben, RGB
1413 @funindex rgb-color
1414
1415 Es gibt noch eine dritte Funktion, die RGB-Werte in die
1416 internen Werte übersetzt -- die @code{rgb-color}-Funktion.  Sie
1417 braucht drei Argumente, um die Stärke von Rot, Grün und
1418 Blau darzustellen. Die Werte befinden sich zwischen
1419 0 und 1.  Um also die Farbe Rot darzustellen, muss der
1420 Wert der Funktion lauten: @code{(rgb-color 1 0 0)}, weiß
1421 würde sein: @code{(rgb-color 1 1 1)}.
1422
1423 @cindex Taktlinie, Beispiel zur Veränderung
1424 @cindex color-Eigenschaft, Beispiel
1425
1426 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1427 {
1428   \time 12/16
1429   \override Staff.BarLine #'color = #(rgb-color 1 1 1)
1430   c4 b8 c d16 c d8 |
1431   g,8 a16 b8 c d4 e16 |
1432   e8
1433 }
1434 @end lilypond
1435
1436 Schließlich gibt es noch eine Grauskala, die zu den X11-Farben
1437 gehört.  Sie reicht von schwarz (@code{'grey0'}) bis
1438 weiß (@code{'grey100}), in Einerschritten.  Wir wollen das
1439 illustrieren, indem alle Layout-Objekte im Beispiel
1440 verschiede Grauschattierungen erhalten:
1441
1442 @cindex StaffSymbol, Beispiel zur Veränderung
1443 @cindex TimeSignature, Beispiel zur Veränderung
1444 @cindex Schlüssel, Beispiel zur Veränderung
1445 @cindex Notenhals, Beispiel zur Veränderung
1446 @cindex Taktlinie, Beispiel zur Veränderung
1447 @cindex Farbeigenschaft, Beispiel
1448 @cindex x11-Farben, Beispiel
1449 @cindex Taktlinien, Beispiel zur Veränderung
1450 @cindex Taktart, Beispiel zur Veränderung
1451 @cindex Clef, Beispiel zur Veränderung
1452 @cindex Stem, Beispiel zur Veränderung
1453 @cindex NoteHead, Beispiel zur Veränderung
1454 @cindex Notenkopf, Beispiel zur Veränderung
1455
1456 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1457 {
1458   \time 12/16
1459   \override Staff.StaffSymbol   #'color = #(x11-color 'grey30)
1460   \override Staff.TimeSignature #'color = #(x11-color 'grey60)
1461   \override Staff.Clef          #'color = #(x11-color 'grey60)
1462   \override Voice.NoteHead      #'color = #(x11-color 'grey85)
1463   \override Voice.Stem          #'color = #(x11-color 'grey85)
1464   \override Staff.BarLine       #'color = #(x11-color 'grey10)
1465   c4 b8 c d16 c d8 |
1466   g,8 a16 b8 c d4 e16 |
1467   e8
1468 }
1469 @end lilypond
1470
1471 @noindent
1472 Beachten Sie die Kontexte, die mit jedem einzelnen Layout-Objekt
1473 verbunden sind.  Es ist wichtig, den richtigen Kontext einzusetzen,
1474 damit die Befehle funktionieren.  Denken Sie daran, dass der
1475 Kontext sich daran orientiert, wo sich der entsprechende
1476 Engraver befindet.  Den Standardkontext für Engraver finden
1477 Sie, indem Sie beim Layout-Objekt beginnen, zum Engraver
1478 gehen, der es produziert und auf der Seite des Engravers in der
1479 IR finden Sie Information, in welchem Kontext sich der
1480 Engraver normalerweise befindet.
1481
1482
1483 @node Größe von Objekten
1484 @subsection Größe von Objekten
1485 @translationof Size of objects
1486
1487 @cindex Veränderung von Objektgrößen
1488 @cindex Objektgrößen, verändern
1489 @cindex Größen von Objekten verändern
1490
1491 Als Startpunkt wollen wir wieder ein früheres Beispiel
1492 wählen, siehe @ref{Musikalische Ausdrücke ineinander verschachteln}. Hier wurde
1493 ein neues Notensystem erstellt, wie man es für ein @rglos{ossia}
1494 braucht.
1495
1496 @cindex alignAboveContext-Eigenschaft, Beispiel
1497 @cindex über dem System anordnen, Beispiel
1498 @cindex @code{\with}-Beispiel
1499
1500 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1501 \new Staff ="main" {
1502   \relative g' {
1503     r4 g8 g c4 c8 d |
1504     e4 r8
1505     <<
1506       { f c c }
1507       \new Staff \with {
1508         alignAboveContext = #"main" }
1509       { f8 f c }
1510     >>
1511     r4 |
1512   }
1513 }
1514 @end lilypond
1515
1516 Ossia-Systeme werden normalerweise ohne Schlüssel und Taktangabe
1517 geschrieben, und sie werden etwas kleiner als das Hauptsystem gesetzt.
1518 Wie man Schlüssel und Taktangabe entfernt, wissen wir schon:
1519 wir setzen den Stencil von beiden auf @code{#f}:
1520
1521 @cindex alignAboveContext-Eigenschaft, Beispiel
1522 @cindex über dem System anordnen, Beispiel
1523 @cindex @code{\with}-Beispiel
1524 @cindex stencil-Eigenschaft, Beispiel
1525 @cindex Schlüssel, Beispiel zur Veränderung
1526 @cindex Taktart, Beispiel zur Veränderung
1527
1528 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1529 \new Staff ="main" {
1530   \relative g' {
1531     r4 g8 g c4 c8 d
1532     e4 r8
1533     <<
1534       { f8 c c }
1535       \new Staff \with {
1536         alignAboveContext = #"main"
1537       }
1538       {
1539         \override Staff.Clef #'stencil = ##f
1540         \override Staff.TimeSignature #'stencil = ##f
1541         { f8 f c }
1542       }
1543     >>
1544     r4
1545   }
1546 }
1547 @end lilypond
1548
1549 @noindent
1550 wobei ein zusätzliches Klammerpaar nach der @code{\with}-Konstruktion
1551 erforderlich ist um sicherzugehen, dass die Modifikation und
1552 die Noten sich auch auf das Ossia-System beziehen.
1553
1554 Was für einen Unterschied macht es, ob man den @code{Staff}-Kontext
1555 mit @code{\with} verändert, oder ob man die Stencils mit
1556 @code{\override} beeinflusst?  Der größte Unterschied liegt
1557 darin, dass Änderungen, die mit @code{\with} eingeführt werden,
1558 während der Erstellung des Kontextes miterzeugt werden und
1559 als @strong{Standardeinstellungen} für diesen Kontext während seiner
1560 gesamten Dauer gelten, während @code{\set}- oder @code{\override}-Befehle
1561 dynamisch in die Noten eingebettet werden -- sie führen die
1562 Änderungen synchron mit einem bestimmten Zeitpunkt in
1563 der Musik aus.  Wenn die Änderungen mit  @code{\unset}
1564 oder @code{\revert} rückgängig gemacht werden, werden
1565 wieder die Standardwerte eingesetzt, die also die sind, die
1566 mit einer @code{\with}-Konstruktion definiert wurden, oder
1567 wenn hier keine definiert worden sind, die normalen
1568 Standardwerte.
1569
1570 Manche Kontexteigenschaften können nur ein einer
1571 @code{\with}-Konstruktion verändert werden.  Das sind
1572 Eigenschaften, die nicht sinnvoll mitten im System geändert
1573 werden können.  @code{alignAboveContext} (Orientierung
1574 über dem Kontext) und die Parallele,
1575 @code{alignBelowContext} (Orientierung unter dem Kontext)
1576 sind zwei derartige Eigenschaften -- wenn das Notensystem
1577 einmal erstellt wurde, ist die Orientierung schon bestimmt
1578 und es wäre nicht sinnvoll, sie später zu ändern.
1579
1580 Die Standardwerte für Layout-Objekt-Eigenschaften können
1581 auch in der @code{\with}-Konstruktion gesetzt werden.
1582 Benutzen Sie einfach den normalen @code{\override}-Befehl
1583 ohne den Kontext, denn der Kontext ist eindeutig definiert
1584 durch die Stelle, an welcher sich @code{\with} befindet.
1585 Wenn an dieser Stelle ein Kontext angegeben wird, produziert LilyPond
1586 eine Fehlermeldung.
1587
1588 Das obige Beispiel könnte also auch so aussehen:
1589
1590 @cindex alignAboveContext-Eigenschaft, Beispiel
1591 @cindex über dem System anordnen, Beispiel
1592 @cindex @code{\with}-Beispiel
1593 @cindex stencil-Eigenschaft, Beispiel
1594 @cindex Schlüssel, Beispiel zur Veränderung
1595 @cindex Taktart, Beispiel zur Veränderung
1596
1597 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1598 \new Staff ="main" {
1599   \relative g' {
1600     r4 g8 g c4 c8 d
1601     e4 r8
1602     <<
1603       { f8 c c }
1604       \new Staff \with {
1605         alignAboveContext = #"main"
1606         % Don't print clefs in this staff
1607         \override Clef #'stencil = ##f
1608         % Don't print time signatures in this staff
1609         \override TimeSignature #'stencil = ##f
1610       }
1611       { f8 f c }
1612     >>
1613     r4
1614   }
1615 }
1616 @end lilypond
1617
1618 Nun können wir daran gehen, auch wirklich die
1619 Größe der Objekte zu ändern.
1620
1621 Manche Layout-Objekte werden aus Glyphen erstellt,
1622 die sich in einer Schriftartdatei befinden.  Dazu gehören
1623 die Notenköpfe, Versetzungszeichen, Text, Schlüssel,
1624 Taktbezeichnung, Dynamik und Gesangstext.  Ihre
1625 Größe wird verändert, indem die
1626 @code{font-size}- (Schriftgröße)-Eigenschaft geändert wird, wie
1627 wir bald sehen werden.  Andere Layout-Objekte, wie
1628 Bögen -- oder allgemein Strecker-Objekte -- werden
1629 individuell gezeichnet, es gibt dazu also keine
1630 @code{font-size}, die mit ihnen verknüpft wäre.
1631 Weitere Eigenschaften wie die Länge von Hälsen und
1632 Taktlinien, Dicke von Balken und anderen Linien und
1633 der Abstand der Notenlinien voneinander müssen auf
1634 spezielle Weise verändert werden.
1635
1636 In unserem Ossia-Beispiel wollen wir zuerst die
1637 Schriftgröße verändern.  Das ist auf zwei Arten möglich.
1638 Entweder wir ändern die Schriftgröße für jede Objektart
1639 mit einem eigenen Befehl, etwa:
1640
1641 @example
1642 \override NoteHead #'font-size = #-2
1643 @end example
1644
1645 @noindent
1646 oder wir ändern die Größe aller Schriftobjekte, indem wir
1647 den Wert einer besonderen Eigenschaft, @code{fontSize},
1648 mit dem @code{\set}-Befehl bestimmen oder sie in
1649 eine @code{\with}-Konstruktion (ohne @code{\set} einschließen.
1650
1651 @example
1652 \set fontSize = #-2
1653 @end example
1654
1655 Beide Beispiele reduzieren die Schriftgröße um zwei Schritte
1656 im Vergleich zum vorigen Wert, wobei jeder Schritt die
1657 Schriftgröße um etwa 12% verändert.
1658
1659 Setzen wir das also in unserem Ossia-Beispiel ein:
1660
1661 @cindex alignAboveContext-Eigenschaft, Beispiel
1662 @cindex über dem System anordnen, Beispiel
1663 @cindex @code{\with}-Beispiel
1664 @cindex stencil-Eigenschaft, Beispiel
1665 @cindex Schlüssel, Beispiel zur Veränderung
1666 @cindex Taktart, Beispiel zur Veränderung
1667
1668 @lilypond[quote,verbatim,fragment,ragged-right,relative=2]
1669 \new Staff ="main" {
1670   \relative g' {
1671     r4 g8 g c4 c8 d
1672     e4 r8
1673     <<
1674       { f8 c c }
1675       \new Staff \with {
1676         alignAboveContext = #"main"
1677         \override Clef #'stencil = ##f
1678         \override TimeSignature #'stencil = ##f
1679         % Reduce all font sizes by ~24%
1680         fontSize = #-2
1681       }
1682       { f8 f c }
1683     >>
1684     r4
1685   }
1686 }
1687 @end lilypond
1688
1689 Das sieht aber immer noch nicht richtig aus.  Die Notenköpfe
1690 und Fähnchen sind kleiner, aber die Hälse im Vergleich
1691 dazu zu lang und die Notenlinien zu weit auseinander.
1692 Sie müssen auch proportional zur Schriftart verkleinert
1693 werden.  Der nächste Abschnitt behandelt diese Anpassung.
1694
1695
1696 @node Länge und Dicke von Objekten
1697 @subsection Länge und Dicke von Objekten
1698 @translationof Length and thickness of objects
1699
1700 @cindex Entfernungen
1701 @cindex Dicke
1702 @cindex Länge
1703 @funindex magstep
1704 @cindex Größe, verändern
1705 @cindex Notenhalslänge, verändern
1706 @cindex Hälse, Länge verändern
1707 @cindex Notenlinien, Länge verändern
1708
1709 Abstände und Längen werden in LilyPond üblicherweise
1710 in Notenlinienabständen (engl. staff-spaces) gemessen.
1711 Das ist der Abstand zwischen zwei Notenlinien im System.
1712 Die meisten Dicken (engl. thickness) dagegen werden in
1713 einer internen Einheit Linien-Dicke (engl. line-thickness)
1714 gemessen.  Die Linien von Dynamikklammern zum Beispiel
1715 haben standardmäßig eine Dicke von einer Einheit
1716 @code{line-thickness}, während die Dicke eines
1717 Notenhalses 1,3 ist.  Beachten Sie jedoch, dass sich
1718 manche Dicken anders verhalten: die Dicke von
1719 Balken etwa wird in Notenlinienabständen gemessen.
1720
1721 Wie also werden Längen skaliert um der Schriftgröße
1722 zu entsprechen?  Das kann mit einer besonderen Funktion
1723 @code{magstep} vorgenommen werden, die genau für
1724 diesen Zweck vorhanden ist.  Sie nimmt ein Argument auf,
1725 die Änderung der Schriftgröße (#-2 im obigen Beispiel)
1726 und gibt einen Skalierungsfaktor aus, der dazu dient,
1727 Objekte proportionell zueinander zu verändern.  So wird
1728 sie benutzt:
1729
1730 @cindex alignAboveContext-Eigenschaft, Beispiel
1731 @cindex über dem System anordnen, Beispiel
1732 @cindex @code{\with}-Beispiel
1733 @cindex stencil-Eigenschaft, Beispiel
1734 @cindex Schlüssel, Beispiel zur Veränderung
1735 @cindex Taktart, Beispiel zur Veränderung
1736 @cindex Notenlinienabstände verändern
1737 @cindex staff-space-Eigenschaft verändern
1738 @cindex magstep-Funktion, Beispiel
1739 @cindex Schriftart-Eigenschaft, Beispiel
1740
1741 @lilypond[quote,verbatim,fragment,ragged-right,relative=2]
1742 \new Staff ="main" {
1743   \relative g' {
1744     r4 g8 g c4 c8 d
1745     e4 r8
1746     <<
1747       { f8 c c }
1748       \new Staff \with {
1749         alignAboveContext = #"main"
1750         \override Clef #'stencil = ##f
1751         \override TimeSignature #'stencil = ##f
1752         fontSize = #-2
1753         % Reduce stem length and line spacing to match
1754         \override StaffSymbol #'staff-space = #(magstep -2)
1755       }
1756       { f8 f c }
1757     >>
1758     r4
1759   }
1760 }
1761 @end lilypond
1762
1763 @noindent
1764 Da die Länge eines Halses und viele andere Längeneigenschaften
1765 relativ zum Wert des Notenlinienabstands (@code{staff-space})
1766 errechnet werden, werden sie auch automatisch verkleinert.
1767 Das wirkt sich jedoch nur auf die vertikale Skalierung des Ossias
1768 aus -- die horizontale Skala ist durch das Layout des Haupsystems
1769 bestimmt und wird also von diesen Größenänderungen nicht
1770 betroffen.  Wenn natürlich die Größe der gesamten Noten reduziert
1771 würde, würde sich auch die horizontalen Abstände ändern.  Dass
1772 wird später im Layout-Abschnitt betrachtet.
1773
1774 Mit dieser Änderung ist unser Ossia fertig.  Die Größen und Längen
1775 aller anderen Objekte können auf analoge Weise geändert
1776 werden.
1777
1778 Für kleine Größenänderungen, wie in dem obigen Beispiel,
1779 braucht die Dicke der verschiedenen Linien, wie Taktlinien,
1780 Notenlinien, Balken, Dynamikklammern usw. normalerweise
1781 keine spezielle Anpassung.  Wenn die Dicke eines bestimmten
1782 Layout-Objektes angepasst werden muss, kann man das erreichen,
1783 indem die entsprechende @code{thickness}-Eigenschaft des
1784 Objekts mit @code{\override} verändert wird.  Ein Beispiel,
1785 wie man die Dicke von Bögen ändert, wurde schon gezeigt,
1786 siehe @ref{Eigenschaften von Layoutobjekten}.  Die Dicke aller
1787 gezeichneten Objekte (die also nicht aus einer Schriftart
1788 stammen) können auf gleiche Weise geändert werden.
1789
1790
1791 @node Positionierung von Objekten
1792 @section Positionierung von Objekten
1793 @translationof Placement of objects
1794
1795 @menu
1796 * Automatisches Verhalten::
1797 * within-staff (Objekte innerhalb des Notensystems)::
1798 * Objekte außerhalb des Notensystems::
1799 @end menu
1800
1801
1802 @node Automatisches Verhalten
1803 @subsection Automatisches Verhalten
1804 @translationof Automatic behavior
1805
1806 @cindex within-staff-Objekte
1807 @cindex outside-staff-Objekte
1808 @cindex Objekte innerhalb des Notensystems
1809 @cindex Objekte außerhalb des Notensystems
1810
1811 Es gibt Objekte der Notation, die zum Notensystem gehören, und
1812 andere, die außerhalb des Systems gesetzt werden müssen.  Sie
1813 werden @code{within-staff}-Objekte bzw.
1814 @code{outside-staff}-Objekte genannt.
1815
1816 @code{within-staff}-Objekte werden innerhalb des Notensystems
1817 (engl. staff) gesetzt: Notenköpfe, Hälse, Versetzungszeichen
1818 usw.  Ihre Position ist üblicherweise durch die notierte Musik
1819 bestimmt -- sie werden vertikal auf bestimmten Linien notiert
1820 oder sind an andere Objekte gebunden, die vertikal festgelegt
1821 sind.  Kollisionen von Notenköpfen, Hälsen und Versetzungszeichen
1822 werden normalerweise automatisch vermieden.  Es gibt
1823 Befehle, um dieses automatische Verhalten zu verändern, wie
1824 unten gezeigt werden soll.
1825
1826 Objekte, die außerhalb des Notensystems gesetzt werden, sind
1827 unter Anderem Übungsmarkierungen, Text und Dynamikzeichen.
1828 LilyPonds Regel für ihre vertikale Positionierung lautet, sie so nah wie
1829 möglich am Notensystem zu setzen, aber nicht so nah, dass
1830 sie mit anderen Objekten kollidieren.  Dabei wird die
1831 @code{outside-staff-priority}-(Priorität außerhalb des Notensystems)-Eigenschaft
1832 eingesetzt, um die Reihenfolge zu bestimmen, in denen Objekte gesetzt werden
1833 sollen.
1834
1835 Zuerst werden alle Innersystemobjekte von LilyPond gesetzt.
1836 Dann werden die Objekte außerhalb des Systems nach
1837 ihrer
1838 @code{outside-staff-priority} geordnet.  Die @code{outside-staff}-Objekte
1839 werden dann nacheinander gesetzt, mit der niedrigsten
1840 Priorität beginnend, und so gesetzt, dass sie nicht mit anderen
1841 Objekten kollidieren, die schon gesetzt wurden.  Wenn also zwei
1842 @code{outside-staff}-Objekte um den selben Platz streiten,
1843 wird das mit der geringeren @code{outside-staff-priority} näher
1844 am System gesetzt werden.  Wenn zwei Objekte die selbe Priorität
1845 haben, wird das näher am System gesetzt, welches zuerst
1846 auftritt.
1847
1848 Im folgenden Beispiel haben alle Textbeschriftungen die gleiche
1849 Priorität (weil sie nicht explizit gesetzt worden ist).  Beachten Sie,
1850 dass @qq{Text3} wieder dicht am System gesetzt wurde, weil
1851 er unter @qq{Text2} passt.
1852
1853 @cindex Textbeschriftungsbeispiel
1854
1855 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1856 c2^"Text1"
1857 c2^"Text2"
1858 c2^"Text3"
1859 c2^"Text4"
1860 @end lilypond
1861
1862 Notensysteme werden in den Standardeinstellungen auch so dicht
1863 beieinander gesetzt wie es möglich ist (mit einem minimalen Abstand).
1864 Wenn Noten sehr weit aus einem System herausragen, zwingen sie
1865 das nächste System weiter weg, wenn eine Kollision drohen würde.
1866 Im nächsten Beispiel sehen Sie, wie Noten auf zwei Systemen
1867 @qq{ineinander greifen}.
1868
1869 @lilypond[quote,ragged-right,verbatim]
1870 <<
1871   \new Staff {
1872     \relative c' { c4 a, }
1873   }
1874   \new Staff {
1875     \relative c'''' { c4 a, }
1876   }
1877 >>
1878 @end lilypond
1879
1880
1881 @node within-staff (Objekte innerhalb des Notensystems)
1882 @subsection within-staff (Objekte innerhalb des Notensystems)
1883 @translationof Within-staff objects
1884
1885 Es wurde schon gezeigt, wie die Befehle @code{\voiceXXX} die Richtung
1886 von Bögen, Fingersatz und allen anderen Objekten beeinflusst,
1887 die von der Richtung der Notenhälsen abhängen.  Diese Befehle
1888 sind nötig, wenn polyphone Musik geschrieben wird, damit sich
1889 die einzelnen Melodielinien klar abzeichnen.  Es kann aber von Zeit
1890 zu Zeit nötig sein, dieses automatische Verhalten zu verändern.  Das
1891 kann entweder für ganze Abschnitte, aber genauso auch nur für eine
1892 einzelne Note vorgenommen werden.  Die Eigenschaft, die die Richtung
1893 bestimmt, ist die @code{direction}-Eigenschaft jedes Layout-Objekts.
1894 Es soll erst erklärt werden, was sie bewirkt und dann eine Anzahl
1895 an fertigen Befehlen für die üblicheren Situationen präsentiert werden,
1896 mit denen Sie gleich loslegen können.
1897
1898 Manche Layout-Objekte, wie Legato- und Bindebögen, biegen sich
1899 oder zeigen entweder nach oben oder nach unten, andere, wie
1900 Hälse und Fähnchen, verändern auch die Position rechts oder links,
1901 je nach der Richtung, in die sie zeigen.  Das wird automatisch
1902 berücksichtigt, wenn die @code{direction}-Eigenschaft verändert
1903 wird.
1904
1905 @funindex down
1906 @funindex up
1907 @funindex center
1908 @funindex neutral
1909 @cindex hoch-Eigenschaft
1910 @cindex runter-Eigenschaft
1911 @cindex zentriert-Eigenschaft
1912 @cindex neutral-Eigenschaft
1913
1914 Das folgende Beispiel zeigt im ersten Takt die Standardeinstellung
1915 für Hälse, die bei hohen Noten nach unten zeigen und bei tiefen
1916 noten nach oben. Im nächsten Takt werden alle Hälse nach unten
1917 gezwungen, im dritten Takt nach oben, und im vierten wird wieder
1918 der Standard eingestellt.
1919
1920 @cindex Notenhals, Beispiel zur Veränderung
1921 @cindex Richtungseigenschaft, Beispiel
1922
1923 @lilypond[quote,verbatim,relative=2]
1924 a4 g c a
1925 \override Stem #'direction = #DOWN
1926 a4 g c a
1927 \override Stem #'direction = #UP
1928 a4 g c a
1929 \revert Stem #'direction
1930 a4 g c a
1931 @end lilypond
1932
1933 Hier werden die Konstanten @code{DOWN} und @code{UP}
1934 eingesetzt.  Sie haben die Werte @w{@code{-1}} bzw. @code{+1}, und
1935 diese numerischen Werte können ebenso benutzt werden.  Auch
1936 der Wert @code{0} kann in manchen Fällen benutzt werden.  Er
1937 bedeutet für die Hälse das gleiche wie @code{UP}, für einige
1938 andere Objekte jedoch @qq{zentriert}.  Es gibt hierzu die Konstante
1939 @code{CENTER}, die den Wert @code{0} hat.
1940
1941 Es gibt aber einfachere Befehle, die normalerweise benutzt werden.
1942 Hier eine Tabelle der häufigsten.  Die Bedeutung des Befehls wird
1943 erklärt, wenn sie nicht selbstverständlich ist.
1944
1945 @multitable @columnfractions .2 .2 .25 .35
1946 @headitem Runter/Links
1947   @tab Rauf/Rechts
1948   @tab Rückgängig
1949   @tab Wirkung
1950 @item @code{\arpeggioArrowDown}
1951   @tab @code{\arpeggioArrowUp}
1952   @tab @code{\arpeggioNormal}
1953   @tab Arpeggio mit Pfeil nach unten, oben oder ohne Pfeil
1954 @item @code{\dotsDown}
1955   @tab @code{\dotsUp}
1956   @tab @code{\dotsNeutral}
1957   @tab Richtung der Verschiebung eines Punktes, um Notenlinien zu vermeiden
1958 @item @code{\dynamicDown}
1959   @tab @code{\dynamicUp}
1960   @tab @code{\dynamicNeutral}
1961   @tab Position der Dynamik-Bezeichnung relativ zum System
1962 @item @code{\phrasingSlurDown}
1963   @tab @code{\phrasingSlurUp}
1964   @tab @code{\phrasingSlurNeutral}
1965   @tab Befehl für Richtung von Phrasierungsbögen
1966 @item @code{\slurDown}
1967   @tab @code{\slurUp}
1968   @tab @code{\slurNeutral}
1969   @tab Befehl für Richtung von Legatobögen
1970 @item @code{\stemDown}
1971   @tab @code{\stemUp}
1972   @tab @code{\stemNeutral}
1973   @tab Befehl für Richtung von Hälsen
1974 @item @code{\textSpannerDown}
1975   @tab @code{\textSpannerUp}
1976   @tab @code{\textSpannerNeutral}
1977   @tab Position von Textbeschriftungen, die als Strecker eingegeben werden
1978 @item @code{\tieDown}
1979   @tab @code{\tieUp}
1980   @tab @code{\tieNeutral}
1981   @tab Befehl für Richtung von Bindebögen
1982 @item @code{\tupletDown}
1983   @tab @code{\tupletUp}
1984   @tab @code{\tupletNeutral}
1985   @tab Befehl für Richtung von Klammern/Zahlen der N-tolen
1986 @end multitable
1987
1988 Diese vordefinierten Befehl können allerdings @strong{nicht}
1989 zusammen mit @code{\once} benutzt werden.  Wenn Sie die
1990 Wirkung eines Befehl auf eine einzige Noten begrenzen wollen,
1991 müssen Sie den entsprechenden
1992 @code{\once \override}-Befehl benutzen oder den definierten
1993 Befehl, gefolgt von dem entsprechenden neutralisierenden
1994 @code{xxxNeutral}-Befehl nach der Note.
1995
1996
1997 @subheading Fingersatz
1998
1999 @cindex Fingersatz, Positionierung
2000 @cindex Fingersatz, Akkorde
2001
2002 Die Positionierung von Fingersatz kann auch durch den Wert
2003 seiner @code{direction}-Eigenschaft beeinflusst werden, aber
2004 eine Veränderung von  @code{direction} hat keinen Einfluss auf
2005 Akkorde. es gibt auch hier
2006 besondere Befehle, mit denen der Fingersatz von einzelnen
2007 Noten in Akkorden kontrolliert werden kann, wobei mögliche
2008 Positionen über, unter der Note und rechts bzw. links von
2009 ihr sind.
2010
2011 Zunächst die Wirkungsweise von @code{direction} auf
2012 den Fingersatz: im ersten Takt der Standard, dann
2013 die Wirkung von @code{DOWN} (runter) und @code{UP}
2014 (hinauf).
2015
2016 @cindex Fingersatz, Beispiel zur Veränderung
2017 @cindex direction-Eigenschaft, Beispiel
2018
2019 @lilypond[quote,verbatim,relative=2]
2020 c4-5 a-3 f-1 c'-5
2021 \override Fingering #'direction = #DOWN
2022 c4-5 a-3 f-1 c'-5
2023 \override Fingering #'direction = #UP
2024 c4-5 a-3 f-1 c'-5
2025 @end lilypond
2026
2027 Eine Beeinflussung der @code{direction}-Eigenschaft ist jedoch
2028 nicht die einfachste Art, Fingersatzbezeichnungen manuell über oder
2029 unter das System zu setzen.  Normalerweise bietet es sich an,
2030 @code{_} oder @code{^} anstelle von @code{-} vor der Fingersatz-Zahl
2031 zu benutzen.  Hier das vorherigen Beispiel mit dieser Methode:
2032
2033 @cindex Fingersatz-Beispiel
2034
2035 @lilypond[quote,verbatim,relative=2]
2036 c4-5 a-3 f-1 c'-5
2037 c4_5 a_3 f_1 c'_5
2038 c4^5 a^3 f^1 c'^5
2039 @end lilypond
2040
2041 Die @code{direction}-Eigenschaft wirkt sich nicht auf
2042 Akkorde aus, während die Präfixe @code{_} und @code{^} funktionieren.
2043 Standardmäßig wird der Fingersatz automatisch entweder
2044 über oder unter dem Akkord gesetzt:
2045
2046 @cindex Fingersatz-Beispiel
2047
2048 @lilypond[quote,verbatim,relative=2]
2049 <c-5 g-3>4
2050 <c-5 g-3 e-2>4
2051 <c-5 g-3 e-2 c-1>4
2052 @end lilypond
2053
2054 @noindent
2055 aber das kann manuell geändert werden, um einzelne Fingersatzanweisungen
2056 nach oben oder unten zu zwingen:
2057
2058 @cindex Fingersatz-Beispiel
2059
2060 @lilypond[quote,verbatim,relative=2]
2061 <c-5 g-3 e-2 c-1>4
2062 <c^5 g_3 e_2 c_1>4
2063 <c^5 g^3 e^2 c_1>4
2064 @end lilypond
2065
2066 Noch bessere Kontrolle über die Positionierung von Fingersatz für
2067 einzelne Noten in einem Akkord ist mit dem
2068 @code{\set fingeringOrientations}-Befehl möglich.  Die Syntax
2069 lautet:
2070
2071 @example
2072 @code{\set fingeringOrientations = #'([up] [left/right] [down])}
2073 @end example
2074
2075 @noindent
2076 @code{\set}wird benutzt, weil @code{fingeringOrientations} eine
2077 Eigenschaft des @code{Voice}-Kontextes ist, erstellt und eingesetzt
2078 vom @code{New_fingering_engraver}.
2079
2080 Die Eigenschaft kann als Wert eine Liste mit einem bis drei Einträgen
2081 haben.  Damit wird bestimmt, ob Fingersatz oberhalb gesetzt
2082 werden kann (wenn @code{up} in der Liste auftaucht), darunter
2083 (wenn@code{down} auftaucht), links (wenn @code{left} auftaucht)
2084 oder rechts (wenn @code{right} auftaucht).  Wenn andererseits
2085 ein Wert nicht auftaucht, wir auch kein Fingersatz in dieser Richtung
2086 gesetzt.  LilyPond nimmt diese Beschränkung als Bedingung und
2087 errechnet die besten Positionen für die Noten des nächsten Akkordes.
2088 Die seitliche Positionierung kann nur auf einer Seite des Akkordes
2089 geschehen, nicht auf beiden gleichzeitig, es kann also nur entweder
2090 @code{left} oder @code{right} auftreten, nicht beide gleichzeitig.
2091
2092 @warning{Damit eine einzelne Note mit diesem Befehl beeinflusst werden
2093 kann, muss sie als ein @qq{Ein-Noten-Akkord} geschrieben
2094 werden, indem einfache spitze Klammern um die Note positioniert
2095 werden.}
2096
2097 Hier ein paar Beispiele:
2098
2099 @cindex Fingersatz-Beispiel
2100 @cindex @code{\set}, Benutzungsbeispiel
2101 @cindex fingerOrientations-Eigenschaft, Beispiel
2102
2103 @lilypond[quote,verbatim,relative=1]
2104 \set fingeringOrientations = #'(left)
2105 <f-2>4
2106 <c-1  e-2 g-3 b-5>4
2107 \set fingeringOrientations = #'(left)
2108 <f-2>4
2109 <c-1  e-2 g-3 b-5>4
2110 \set fingeringOrientations = #'(up left down)
2111 <f-2>4
2112 <c-1  e-2 g-3 b-5>4
2113 \set fingeringOrientations = #'(up left)
2114 <f-2>4
2115 <c-1  e-2 g-3 b-5>4
2116 \set fingeringOrientations = #'(right)
2117 <f-2>4
2118 <c-1  e-2 g-3 b-5>4
2119 @end lilypond
2120
2121 @noindent
2122 Wenn die Fingersatzbezeichnung zu gedrungen aussieht,
2123 kann auch die Schriftgröße (@code{font-size}) verringert
2124 werden.  Der Standardwert kann aus dem
2125 @code{Fingering}-Objekt in der IR entnommen werden,
2126 er ist @w{@code{-5}}, versuchen wir es also mit @w{@code{-7}}.
2127
2128 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2129 \override Fingering #'font-size = #-7
2130 \set fingeringOrientations = #'(left)
2131 <f-2>4
2132 <c-1  e-2 g-3 b-5>4
2133 \set fingeringOrientations = #'(left)
2134 <f-2>4
2135 <c-1  e-2 g-3 b-5>4
2136 \set fingeringOrientations = #'(up left down)
2137 <f-2>4
2138 <c-1  e-2 g-3 b-5>4
2139 \set fingeringOrientations = #'(up left)
2140 <f-2>4
2141 <c-1  e-2 g-3 b-5>4
2142 \set fingeringOrientations = #'(right)
2143 <f-2>4
2144 <c-1  e-2 g-3 b-5>4
2145 @end lilypond
2146
2147
2148
2149 @node Objekte außerhalb des Notensystems
2150 @subsection Objekte außerhalb des Notensystems
2151 @translationof Outside-staff objects
2152
2153 Objekte außerhalb des Notensystems werden automatisch gesetzt,
2154 um Kollisionen zu vermeiden.  Objekten mit einem geringeren
2155 Prioritätswert der Eigenschaft @code{outside-staff-priority}
2156 werden näher an das System gesetzt, und andere Objekte außerhalb
2157 des Systems werden dann soweit vom System entfernt gesetzt, dass
2158 Zusammenstöße vermieden werden.  Die
2159 @code{outside-staff-priority}-Eigenschaft ist im
2160 @code{grob-interface} definiert und ist also eine Eigenschaft
2161 von allen Layout-Objekten.  Standardmäßig ist sie für alle Objekte
2162 auf falsch (@code{#f}) gesetzt; dieser Wert wird in einen numerischen
2163 Wert dem Objekt entsprechend geändert, wenn das Objekt für die
2164 Notenausgabe erstellt wird.  Die Tabelle unten zeigt die
2165 Standardwerte für die meistbenutzten @code{outside-staff}-Objekte.
2166
2167 @cindex spanners
2168 @cindex Strecker
2169
2170 Achtung bei einigen ungewöhnlichen Objektbezeichnungen: Strecker-Objekte
2171 werden automatisch erstellt, um die vertikale Position von Grobs
2172 zu kontrollieren, die an unterschiedlichen musikalischen Momenten
2173 beginnen und enden (könnten).  Wenn also @code{outside-staff-priority}
2174 des darunterliegenden Grobs geändert wird, hat das keine Auswirkung.
2175 Zum Beispiel bringt das Ändern von @code{outside-staff-priority}
2176 des @code{Hairpin}-(Dynamikklammer)-Objekts keine Änderung in der
2177 vertikalen Position von Crescendo-Klammern -- anstatt dessen muss
2178 @code{outside-staff-priority} des hiermit assoziierten
2179 @code{DynamicLineSpanne}-Objekts geändert werden.  Dieser
2180 @code{\override}-Befehl muss zu Beginn des Streckers gesetzt werden,
2181 welcher womöglich mehrere verbundene Dynamikklammern und Dynamikbezeichnung
2182 beinhaltet.
2183
2184 @multitable @columnfractions .3 .3 .3
2185 @headitem Layout-Objekt
2186   @tab Priorität
2187   @tab Kontrolliert Position von:
2188 @item @code{RehearsalMark}
2189   @tab @code{1500}
2190   @tab Übungszeichen
2191 @item @code{MetronomeMark}
2192   @tab @code{1000}
2193   @tab Metronomzeichen
2194 @item @code{VoltaBracketSpanner}
2195   @tab @code{600}
2196   @tab Volta-Wiederholungsklammern
2197 @item @code{TextScript}
2198   @tab @code{450}
2199   @tab Textbeschriftung
2200 @item @code{MultiMeasureRestText}
2201   @tab @code{450}
2202   @tab Text über Ganztaktpausen
2203 @item @code{OttavaBracket}
2204   @tab @code{400}
2205   @tab Ottava (Oktavierungsklammern)
2206 @item @code{TextSpanner}
2207   @tab @code{350}
2208   @tab Text-Strecker
2209 @item @code{DynamicLineSpanner}
2210   @tab @code{250}
2211   @tab Alle Dynamik-Bezeichnungen
2212 @item @code{BarNumber}
2213   @tab @code{ 100}
2214   @tab Taktzahlen
2215 @item @code{TrillSpanner}
2216   @tab @code{50}
2217   @tab Triller-Strecker
2218 @end multitable
2219
2220 Hier ein Beispiel, das die Standardpositionierung von einigen
2221 Objekten zeigt.
2222
2223 @cindex Text-Strecker
2224 @cindex Text-Spanner
2225 @funindex \startTextSpan
2226 @funindex \stopTextSpan
2227 @funindex startTextSpan
2228 @funindex stopTextSpan
2229 @cindex Ottava-Klammer
2230 @cindex Oktavierungsklammer
2231
2232 @cindex TextSpanner, Beispiel zur Veränderung
2233 @cindex bound-details-Eigenschaft, Beispiel
2234
2235 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2236 % Set details for later Text Spanner
2237 \override TextSpanner #'(bound-details left text)
2238     = \markup { \small \bold Slower }
2239 % Place dynamics above staff
2240 \dynamicUp
2241 % Start Ottava Bracket
2242 \ottava #1
2243 c'4 \startTextSpan
2244 % Add Dynamic Text and hairpin
2245 c4\pp\<
2246 c4
2247 % Add Text Script
2248 c4^Text
2249 c4 c
2250 % Add Dynamic Text and terminate hairpin
2251 c4\ff c \stopTextSpan
2252 % Stop Ottava Bracket
2253 \ottava #0
2254 c,4 c c c
2255 @end lilypond
2256
2257 Dieses Beispiel zeigt auch, wie man Text-Strecker erstellt, d.h.
2258 Text mit Bindestrichen, der sich über eine bestimmte Länge
2259 erstreckt.  Der Strecker beginnt mit dem
2260 @code{\startTextSpan}-Befehl und endet mit dem
2261 @code{\stopTextSpan}-Befehl, und das Format des Textes
2262 wird mit dem @code{\override TextSpanner}-Befehl bestimmt.
2263 Mehr Einzelheiten siehe @ruser{Text mit Verbindungslinien}.
2264
2265 Im Beispiel wird auch gezeigt, wie Oktavierungsklammern
2266 (Ottava) erstellt werden.
2267
2268 @cindex Taktzahlposition verändern
2269 @cindex Verändern der Taktzahlposition
2270 @cindex Position der Taktzahl, verändern
2271 @cindex Metronom-Bezeichnungsposition verändern
2272 @cindex Verändern der Metronom-Bezeichnungsposition
2273 @cindex Übungszeichenposition verändern
2274 @cindex Verändern der Übungszeichenposition
2275
2276 Wenn die Standardwerte der @code{outside-staff-priority} nicht
2277 die Positionierung hervorrufen, die Sie wünschen, kann die
2278 Priorität eines jeden Objektes geändert werden.  Als Beispiel
2279 wollen wir zeigen, wie sich die Oktavierungsklammer unter
2280 den Textstrecker des vorigen Beispiels setzen lässt.  Wir müssen
2281 nur die Priorität des
2282 @code{OttavaBracket}-Objektes in der IR oder der Tabelle oben
2283 herausfinden und einen kleineren Wert angeben als der Wert, den
2284 das @code{TextSpanner}-(Strecker)-Objekt bekommt, wobei noch daran
2285 zu denken ist, dass @code{OttavaBracket} im @code{Staff}-Kontext
2286 erstellt wird:
2287
2288 @cindex TextSpanner, Beispiel zur Veränderung
2289 @cindex bound-details-Eigenschaft, Beispiel
2290
2291 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2292 % Set details for later Text Spanner
2293 \override TextSpanner #'(bound-details left text)
2294     = \markup { \small \bold Slower }
2295 % Place dynamics above staff
2296 \dynamicUp
2297 % Place following Ottava Bracket below Text Spanners
2298 \once \override Staff.OttavaBracket #'outside-staff-priority = #340
2299 % Start Ottava Bracket
2300 \ottava #1
2301 c'4 \startTextSpan
2302 % Add Dynamic Text
2303 c4\pp
2304 % Add Dynamic Line Spanner
2305 c4\<
2306 % Add Text Script
2307 c4^Text
2308 c4 c
2309 % Add Dynamic Text
2310 c4\ff c \stopTextSpan
2311 % Stop Ottava Bracket
2312 \ottava #0
2313 c,4 c c c
2314 @end lilypond
2315
2316 Beachten Sie, dass einige dieser Objekte, insbesondere Taktzahlen,
2317 Metronomzeichen und Übungszeichen standardmäßig im @code{Score}-Kontext
2318 zu Hause sind; benutzen Sie also den richtigen Kontext, wenn sie
2319 deren Einstellungen verändern wollen.
2320
2321 @cindex Legatobögen und outside-staff-priority
2322 @cindex Legatobögen und Artikulationszeichen
2323 @cindex Artikulationszeichen und Legatobögen
2324
2325 Legatobögen werden als Innersystem-Objekte klassifiziert, aber
2326 sie erscheinen oft auch über dem System, wenn die Noten, an die
2327 sie verbunden sind, sehr hoch im System notiert sind.  Dadurch
2328 können Außersystem-Objekte, wie Artikulationszeichen, zu hoch
2329 gerückt werden.  Die @code{avoid-slur}-Eigenschaft hat nur
2330 eine Auswirkung, wenn auch die @code{outside-staff-priority}
2331 auf @code{#f} gesetzt ist.  Alternativ kann die
2332 @code{outside-staff-priority}  des Legatobogens auf einen
2333 numerischen Wert gesetzt werden, sodass er mit anderen
2334 Außersystem-Objekten anhand dieses Wertes gesetzt wird.
2335 Hier ein Beispiel, das die beiden Möglichkeiten veranschaulicht:
2336
2337 @lilypond[quote,verbatim,relative=2]
2338 c4( c^\markup { \tiny \sharp } d4.) c8
2339 c4(
2340 \once \override TextScript #'avoid-slur = #'inside
2341 \once \override TextScript #'outside-staff-priority = ##f
2342 c4^\markup { \tiny \sharp } d4.) c8
2343 \once \override Slur #'outside-staff-priority = #500
2344 c4( c^\markup { \tiny \sharp } d4.) c8
2345 @end lilypond
2346
2347 Eine Änderung der @code{outside-staff-priority} kann auch dazu
2348 benutzt werden, die vertikale Plazierung von individuellen Objekten
2349 zu kontrollieren, auch wenn das Ergebnis nicht immer optimal
2350 ist.  Im nächsten Beispiel soll @qq{Text3} oberhalb von @qq{Text4}
2351 gesetzt werden, das Beispiel wurde behandelt in
2352 @ref{Automatisches Verhalten}.  Der Wert der Priorität muss also für
2353 die Eigenschaft @code{TextScript} entweder in der IR oder in der
2354 Tabelle oben festgestellt werden und dann die Priorität für
2355 @qq{Text3} höher eingestellt werden:
2356
2357 @cindex TextScript, Beispiel zur Veränderung
2358 @cindex outside-staff-priority-Eigenschaft, Beispiel
2359
2360 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2361 c2^"Text1"
2362 c2^"Text2" |
2363 \once \override TextScript #'outside-staff-priority = #500
2364 c2^"Text3"
2365 c2^"Text4" |
2366 @end lilypond
2367
2368 Damit wird zwar @qq{Text3} ganz richtig über @qq{Text4}
2369 platziert, aber auch über @qq{Text2}, und @qq{Text4}
2370 wird jetzt weiter unten gesetzt.  Eigentlich sollten ja alle
2371 diese Anmerkungen gleichweit vom System entfernt sein.
2372 Dazu muss offensichtlich horizontal etwas Platz gemacht
2373 werden.  Das kann erreicht werden mit dem
2374 @code{textLengthOn}-(Textlänge an)-Befehl.
2375
2376 @subheading \textLengthOn (Textlänge berücksichtigen)
2377
2378 @cindex Noten, durch Text gespreizt
2379 @funindex \textLengthOn
2380 @funindex textLengthOn
2381 @funindex \textLengthOff
2382 @funindex textLengthOff
2383
2384 Standardmäßig wird Text, der mit dem Beschriftungsbefehl
2385 @code{\markup} bzw. Äquivalenten erstellt wird, kein
2386 zusätzlicher Platz in Bezug auf die Positionierung der Noten
2387 zugestanden.  Der @code{\textLengthOn}-Befehl ändert
2388 dieses Verhalten, so dass die Noten gespreizt werden, wenn
2389 die Breite des Textes es erfordert:
2390
2391 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2392 \textLengthOn  % Cause notes to space out to accommodate text
2393 c2^"Text1"
2394 c2^"Text2" |
2395 c2^"Text3"
2396 c2^"Text4" |
2397 @end lilypond
2398
2399 Dieses Verhalten wird mit dem @code{\textLengthOff}-Befehl
2400 rückgängig gemacht.  Erinnern Sie sich, dass @code{\once} nur mit
2401 @code{\override}, @code{\set}, @code{\revert} oder @code{unset}
2402 funktioniert, der Befehl kann also nicht zusammen mit
2403 @code{\textLengthOn} benutzt werden.
2404
2405 @cindex Textbeschriftung, Vermeidung von Zusammenstößen
2406 @cindex Zusammenstöße vermeiden mit Textbeschriftung
2407
2408 Textbeschriftung vermeidet auch Noten, die über das System hinausstehen.
2409 Wenn das nicht gewünscht ist, kann die automatische Verschiebung
2410 nach oben hin auch vollständig ausgeschaltet werden, indem die
2411 Priorität auf @code{#f} gesetzt wird.  Hier ein Beispiel, wie
2412 eine Textbeschriftung mit diesen Noten reagiert:
2413
2414 @cindex Textbeschriftung, Beispiel zur Veränderung
2415 @cindex outside-staff-priority-Eigenschaft, Beispiel
2416
2417 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2418 % This markup is short enough to fit without collision
2419 c2^"Tex" c'' |
2420 R1 |
2421
2422 % This is too long to fit, so it is displaced upwards
2423 c,,2^"Text" c'' |
2424 R1 |
2425
2426 % Turn off collision avoidance
2427 \once \override TextScript #'outside-staff-priority = ##f
2428 c,,2^"Long Text   " c'' |
2429 R1 |
2430
2431 % Turn off collision avoidance
2432 \once \override TextScript #'outside-staff-priority = ##f
2433 \textLengthOn        % and turn on textLengthOn
2434 c,,2^"Long Text   "  % Spaces at end are honored
2435 c''2 |
2436 @end lilypond
2437
2438
2439 @subheading Dynamik
2440
2441 @cindex Verändern der Positionierung von Dynamikzeichen
2442 @cindex Dynamikzeichen: Positionierung verändern
2443
2444 Dynamikbezeichnung wird üblicherweise unter dem System
2445 gesetzt, kann aber auch nach oben mit dem Befehl
2446 @code{dynamicUp} gezwungen werden.  Die Bezeichnung
2447 wird vertikal relativ zu der Note positioniert, an die sie angefügt
2448 wurde.  Sie wird vertikal variabel gesetzt in Bezug zu
2449 Innersystemobjekten wie Bögen oder Taktnummern. Damit
2450 können oft recht gute Resultate erreicht werden, wie im
2451 folgenden Beispiel:
2452
2453 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2454 \clef "bass"
2455 \key aes \major
2456 \time 9/8
2457 \dynamicUp
2458 bes4.~\f\< \( bes4 bes8 des4\ff\> c16 bes\!
2459 ees,2.~\)\mf ees4 r8
2460 @end lilypond
2461
2462 Wenn aber Noten und Dynamikzeichen sehr dicht beieinander
2463 stehen, positioniert die automatische Kollisionsvermeidung
2464 später kommende Dynamikzeichen weiter weg, was allerdings
2465 nicht immer die beste Möglichkeit ist, wie in dem folgenden,
2466 etwas gewollten Beispiel zu sehen ist:
2467
2468 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2469 \dynamicUp
2470 a4\f b\mf c\mp b\p |
2471 @end lilypond
2472
2473 @noindent
2474 Wenn eine ähnliche Situation in @qq{echter} Musik auftaucht,
2475 kann es nötig sein, die Noten etwas zu spreizen, damit die
2476 Dynamikzeichen alle auf der selben vertikalen Position
2477 gesetzt werden können.  Dieses Verhalten war im Falle von
2478 Textbeschriftungen möglich mit dem @code{\textLengthOn}-Befehl,
2479 aber es gibt keinen entsprechenden Befehl für Dynamik.  Wir
2480 müssen also unsere eigenen Befehle mit @code{\override}
2481 konstruieren.
2482
2483
2484 @subheading Verändern der Größe von grobs
2485
2486 @cindex Grob, Größenveränderung
2487 @cindex Größenveränderung von grobs
2488
2489 Zuallererst müssen wir lernen, wie die Größe von Grobs verändert
2490 wird.  Alle Grobs besitzen einen Referenzpunkt, der
2491 benutzt wird, um ihre Position in Relation zu ihnen übergeordneten
2492 Objekten zu bestimmen.  Dieser Punkt innerhalb des Grobs wird dann
2493 auf einer horizontalen Position (@code{X-offset}) und einer
2494 vertikalen Position (@code{Y-offset}) ausgerichtet, immer bezüglich
2495 des übergeordneten Objektes.  Eine horizontale Strecke wird
2496 durch ein Zahlenpaar angegeben (@code{X-extent}), welche
2497 die linke und rechte Grenze relativ zum übergeordneten Objekt
2498 bezeichnen.  Die vertikale Strecke wir genauso durch ein
2499 Zahlenpaar (@code{Y-extent}) definiert.  Diese Eigenschaften
2500 gehören zu allen Grobs, die das
2501 @code{grob-interface} unterstützen.
2502
2503 @cindex @code{extra-spacing-width}
2504
2505 Standardmäßig haben Außersystemobjekte eine Länge von Null,
2506 so dass sie sich in horizontaler Richtung überlappen können.  Das
2507 geschieht, indem dem linken Rand Unendlich zugewiesen wird
2508 und dem rechten Rand minus Unendlich (der Code der
2509 @code{extra-spacing-width}-(zusätzliche Positionierungslänge)-Eigenschaft
2510 lautet: @code{'(+inf.0 . -inf.0)}).
2511 Damit sich diese Objekte also horizontal nicht überschneiden, muss
2512 der Wert von @code{extra-spacing-width} auf
2513 @code{'(0 . 0)} gesetzt werden, sodass die wirkliche Länge eines
2514 Objektes zur Geltung kommt.  Mit diesem Befehl wird das für
2515 Dynamik-Zeichen erledigt:
2516
2517 @example
2518 \override DynamicText #'extra-spacing-width = #'(0 . 0)
2519 @end example
2520
2521 @noindent
2522 Schauen wir uns an, wie es mit dem vorigen Beispiel funktioniert:
2523
2524 @cindex DynamicText, Beispiel zur Veränderung
2525 @cindex extra-spacing-width-Eigenschaft, Beispiel
2526
2527 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2528 \dynamicUp
2529 \override DynamicText #'extra-spacing-width = #'(0 . 0)
2530 a4\f b\mf c\mp b\p
2531 @end lilypond
2532
2533 @noindent
2534 Damit werden die Dynamik-Zeichen also wirklich nebeneinander
2535 gesetzt, aber es gibt noch zwei Probleme.  Die Zeichen sollten
2536 etwas weiter außeinander stehen und es wäre gut, wenn sie alle
2537 den gleichen Abstand zum System hätte.  Das erste Problem ist
2538 einfach behoben.  Anstatt der @code{extra-spacing-width}-Eigenschaft
2539 Null zuzuweisen, können wir auch einen etwas größeren Wert
2540 wählen.  Die Einheit wird gemessen in dem Abstand zwischen zwei
2541 Notenlinien, es scheint also gut, den rechten und linken
2542 Rand eine halbe Einheit zu vergrößern:
2543
2544 @cindex DynamicText, Beispiel zur Veränderung
2545 @cindex extra-spacing-width-Eigenschaft, Beispiel
2546
2547 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2548 \dynamicUp
2549 % Extend width by 1 staff space
2550 \override DynamicText #'extra-spacing-width = #'(-0.5 . 0.5)
2551 a4\f b\mf c\mp b\p
2552 @end lilypond
2553
2554 @noindent
2555 Das sieht schon besser aus, aber es wäre noch besser, wenn die
2556 Dynamik-Zeichen alle an einer Linie ausgerichtet wären, anstatt
2557 höher und tiefer zu sitzen.  Das kann mit der
2558 @code{staff-padding}-Eigenschaft erreicht werden,
2559 die wir uns im folgenden Abschnitt genauer anschauen werden.
2560
2561
2562
2563 @node Kollision von Objekten
2564 @section Kollision von Objekten
2565 @translationof Collisions of objects
2566
2567 @menu
2568 * Verschieben von Objekten::
2569 * Überlappende Notation in Ordnung bringen::
2570 * Beispiele aus dem Leben::
2571 @end menu
2572
2573 @node Verschieben von Objekten
2574 @subsection Verschieben von Objekten
2575 @translationof Moving objects
2576
2577 @cindex Verschieben von überschneidenden Objekten
2578 @cindex Verschieben von Zusammenstößen
2579 @cindex Zusammenstöße vermeiden
2580 @cindex Objekte, verschieben von Zusammestößen
2581 @cindex Vermeiden von Zusammenstößen
2582
2583 Es wird vielleicht eine Überraschung sein, aber LilyPond ist nicht
2584 perfekt. Einige Notationselemente können sich überschneiden. Das
2585 ist nicht schön, aber zum Glück sehr selten.  Normalerweise müssen
2586 die Objekte zur Klarheit oder aus ästhetischen Gründen verschoben
2587 werden -- sie könnten besser aussehen, wenn sie etwas zusätzlichen
2588 Platz erhalten.
2589
2590 Es gibt im Grunde drei Herangehensweisen, überlappende Notation
2591 zu verbessern.  Man sollte sie in der folgenden Reihenfolge
2592 anwenden:
2593
2594 @enumerate
2595 @item
2596 Die @strong{Richtung} eines der überlappenden Objekte kann
2597 geändert werden, indem die vordefinierten Befehle für
2598 Innersystemobjekte verwendet werden, wie beschrieben in
2599 @ref{within-staff (Objekte innerhalb des Notensystems)}.  Hälse, Bögen, Balken, Dynamik-Zeichen
2600 und Triolen können auf diese Weise einfach umgeordnet
2601 werden.  Beschränkt ist diese Methode insofern, als es nur
2602 zwei Möglichkeiten zur Veränderung gibt: oben oder unten.
2603
2604 @item
2605 Die @strong{Objekteigenschaft}, die LilyPond benutzt um die
2606 Layout-Objekte zu platzieren, können mit dem
2607 @code{\override}-Befehl positioniert werden.  Die Vorteile
2608 von Änderungen dieser Art sind a) dass einige Objekte
2609 automatisch verschoben werden, wenn es nötig ist Platz zu
2610 schaffen und b) ein einziges @code{\override} sich auf
2611 alle Fälle eines Objekttyps bezieht.  Zu diesen Eigenschaften
2612 gehören:
2613
2614 @itemize
2615
2616 @item
2617 @code{direction} (Richtung)
2618
2619 Das wurde schon detailliert behandelt, siehe
2620 @ref{within-staff (Objekte innerhalb des Notensystems)}.
2621
2622 @item
2623 @code{padding}, @code{right-padding}, @code{staff-padding} (Verschiebung)
2624
2625 @cindex Padding-Eigenschaft
2626 @cindex right-padding-Eigenschaft
2627 @cindex staff-padding-Eigenschaft
2628 @cindex Verschieben (padding)
2629 @cindex Füllung (padding)
2630 @cindex padding (Füllung)
2631
2632 Wenn ein Objekt platziert wird, bestimmt der Wert seiner
2633 @code{padding}-(Füllungs)-Eigenschaft die Größe des
2634 Abstandes, der zwischen dem Objekt selber und dem
2635 Objekt, relativ zu welchem es positioniert wird, gelassen
2636 werden muss.  Dabei zählt der @code{padding}-Wert
2637 des Objektes, das platziert werden soll, der @code{padding}-Wert
2638 des Objektes, das schon gesetzt wurde, wird hingegen
2639 ignoriert.  Abstände mit @code{padding} können zu
2640 allen Objekten hinzugefügt werden, die das
2641 @code{side-position-interface} unterstützen.
2642
2643 Anstelle von @code{padding} wird die Position von
2644 Versetzungszeichengruppen durch die Eigenschaften
2645 @code{right-padding} bestimmt. Diese Eigenschaft wird im
2646 @code{AccidentalPlacement}-(Versetzungszeichen-Positionierungs)-Objekt
2647 gefunden, das sich innerhalb des @strong{Staff}-Kontexts
2648 befindet.  Während des Notensatzes werden die Notenköpfe
2649 zuerst gesetzt und dann die Versetzungszeichen, wenn denn
2650 welche gesetzt werden, durch die @code{right-padding}-Eigenschaft
2651 auf die linke Seite der Notenköpfe positioniert, um die Entfernung
2652 von den Notenköpfen und zwischen den einzelnen Versetzungszeichen zu
2653 bestimmen.  Also nur die @code{right-padding}-(Verschiebung nach rechts)-Eigenschaft
2654 des @code{AccidentalPlacement}-Objekts hat Einfluss auf die
2655 Positionierung der Versetzungszeichen.
2656
2657 Die @code{staff-padding}-(Verschiebung zum System)-Eigenschaft
2658 ist sehr ähnlich wie die @code{padding}-Eigenschaft:
2659 @code{padding} bestimmt den Minimalabstand zwischen
2660 einem Objekt, das das @code{side-position-interface}
2661 unterstützt, und dem nächsten anderen Objekt (normalerweise
2662 die Note oder Notenlinie); @code{staff-padding} dagegen
2663 wirkt nur auf Objekte die immer außerhalb des Notensystems
2664 sind -- damit wird der minimale Abstand bestimmt, der
2665 zwischen dem Objekt und dem Notensystem gelassen werden
2666 soll.  @code{staff-padding} hat also @strong{keinen Einfluss}
2667 auf Objekte, die relativ zu einer Note positioniert werden, sondern
2668 nur auf solche, die zum System relativ stehen. Wenn es mit einem
2669 anderen Objekt eingesetzt wird, erhält man keine Fehlermeldung, aber
2670 der Befehl hat auch keine Auswirkungen.
2671
2672 Um herauszufinden, welche @code{padding}-Eigenschaft für
2673 das bestimmte Objekt nötig, ist, das Sie verschieben wollen,
2674 müssen Sie in der IR nach den Objekt-Eigenschaften schauen.
2675 Dabei sollten Sie bedenken, dass sich die @code{padding}-Eigenschaften
2676 nicht unbedingt in dem Objekt selber befinden, schauen Sie
2677 also auch in Objekten nach, die offensichtlich Ähnlichkeiten
2678 haben.
2679
2680 Alle @code{padding}-Werte werden in Notenlinienabständen
2681 gemessen.  Für die meisten Objekte ist der Wert ungefähr auf
2682 1.0 oder weniger gesetzt (das variiert von Objekt zu Objekt).
2683 Der Wert kann geändert werden, wenn ein größerer (oder
2684 kleinerer) Abstand gewünscht wird.
2685
2686 @item
2687 @code{self-alignment-X} (Selbstpositionierung)
2688
2689 @cindex self-alignment-X-Eigenschaft
2690 @cindex Selbstpositionierung von Objekten
2691 @cindex Ausrichtung von Objekten
2692
2693 Diese Eigenschaft kann benutzt werden, um ein Objekt
2694 nach links, rechts oder zentriert an dem Referenzpunkt des Objekts
2695 auszurichten, an das es verknüpft ist.  Es kann bei allen
2696 Objekten benutzt werden, die das @code{self-alignment-interface}
2697 unterstützen.  Das sind üblicherweise Objekte, die Text
2698 enthalten.  Die möglichen Werte der Eigenschaft sind @code{LEFT},
2699 @code{RIGHT} oder @code{CENTER}.  Alternativ kann ein
2700 numerischer Wert zwischen @w{@code{-1}} und @code{+1}
2701 bestimmt werden: @w{@code{-1}} heißt linksbündig, @code{+1}
2702 rechtsbündig und Zahlen dazwischen bewegen den Text
2703 schrittweise von links nach rechts.  Zahlen größer als
2704 @code{1} können angegeben werden, um den Text
2705 noch weiter nach links zu bewegen, oder weniger als @w{@code{-1}},
2706 um ihn weiter nach rechts zu schieben.  Eine Änderung
2707 um @code{1} des Wertes entspricht einer Bewegung um
2708 die halbe Textbreite.
2709
2710 @item
2711 @code{extra-spacing-width} (zusätzliche Breite)
2712
2713 @cindex extra-spacing-width-Eigenschaft
2714
2715 Diese Eigenschaft steht für alle Objekte zur Verfügung, die
2716 das @code{item-interface} unterstützen.  Es braucht zwei
2717 Zahlen als Argument, die erste wird zur rechten Ausdehnung,
2718 die zweite zur linken Ausdehnung hinzugerechnet.  Negative
2719 Zahlen verschieben die Ausdehnung nach rechts, positive nach
2720 links, um also ein Objekt zu verbreitern, muss die erste
2721 Zahl negativ und die zweite positiv sein.  Allerdings beachten
2722 nicht alle Objekte beide Zahlen.  Das
2723 @code{accidental}-(Versetzungszeichen)-Objekt etwa beachtet
2724 nur erste Zahl für die linke Ausdehnung.
2725
2726 @item
2727 @code{staff-position} (Notensystempositionierung)
2728
2729 @cindex staff-position-Eigenschaft
2730
2731 @code{staff-position} ist eine Eigenschaft des
2732 @code{staff-symbol-referencer-interface}, die von Objekten unterstützt
2733 wird, die relativ zum Notensystem (engl. staff) positioniert werden.
2734 Hiermit wird die vertikale Position eines Objekts relativ zur
2735 Mittellinie des Systems in halben Notenlinienabständen angegeben.
2736 Das ist sehr nützlich, um Zusammenstöße zwischen Layout-Objekten
2737 wie Ganztaktpausen, Bögen und Noten in verschiedenen Stimmen
2738 zu lösen.
2739
2740 @item
2741 @code{force-hshift} (vertikale Verschiebung erzwingen)
2742
2743 @cindex force-hshift-Eigenschaft
2744
2745 Eng beieinander stehende Noten in einem Akkord oder Noten, die zum
2746 gleichen Zeitpunkt in unterschiedlichen Stimmen stehen, werden
2747 in zwei oder manchmal auch mehr Kolumnen gesetzt, um Kollisionen
2748 zu umgehen.  Diese Kolumnen werden Notenkolumnen genannt;
2749 ein @code{NoteColumn}-Objekt wird erstellt um die Noten in den
2750 Kolumnen zu setzen.
2751
2752 Die @code{force-hshift}-(erzwinge horizontale Verschiebung)-Eigenschaft
2753 ist eine Eigenschaft von @code{NoteColumn} (bzw. vom
2754 @code{note-column-interface}).  Eine Veränderung dieser Eigenschaft
2755 macht es möglich, eine Notenkolumne zu verschieben, dabei gilt als
2756 Einheit die Breite einer Kolumne, also die Breite des Notenkopfes der
2757 ersten Stimme.  Diese Eigenschaft kann in Situationen benutzt werden,
2758 in denen die normalen @code{\shiftOn}-Befehle (siehe auch
2759 @ref{Stimmen explizit beginnen}) das Problem nicht beseitigen.
2760 Diese Eigenschaft ist besser in solchen Fällen zu verwenden als die
2761 @code{extra-offset}-Eigenschaft, weil man die richtige Entfernung nicht
2762 in Notenlinienabständen ausrechnen muss.  Wenn eine Note in eine
2763 Notenkolumne oder aus ihr heraus geschoben wird, werden auch andere
2764 Funktionen beeinflusst, wie etwa die Verschmelzung von Notenköpfen.
2765
2766 @end itemize
2767
2768 @item
2769 Zu guter Letzt, wenn alles andere nicht funktioniert, können Objekte auch
2770 manuell positioniert werden, entweder vertikal in Bezug auf die
2771 Mittellinie des Systems, oder indem sie einen beliebigen Abstand weit
2772 auf eine neue Position verschoben werden.  Der Nachteil ist, dass die
2773 richtigen Werte für eine gute Position manuell ausprobiert werden müssen,
2774 meistens durch Herantasten an den richtigen Wert, und das für jedes
2775 einzelne Objekt extra.  Und weil diese Verschiebungen erst vorgenommen
2776 werden, wenn LilyPond alle anderen Objekte gesetzt hat, ist man als
2777 Notensetzer selber dafür verantwortlich, ob es Zusammenstöße gibt.
2778 Am schwerwiegendsten ist aber die Tatsache, dass die
2779 Verschiebungskoordinaten wahrscheinlich neu errechnet oder
2780 ausprobiert werden müssen, wenn sich an den Noten und deren
2781 Layout später irgend etwas ändert.  Die Eigenschaften, die für diese
2782 Arte der manuellen Verschiebung verwendet werden können, sind:
2783
2784 @table @code
2785 @item extra-offset (zusätzlicher Abstand)
2786
2787 @cindex extra-offset-Eigenschaft
2788
2789 Diese Eigenschaft gehört zu jedem Layout-Objekt, das das
2790 @code{grob-interface} unterstützt.  Sie braucht ein Zahlenpaar,
2791 das die exakte Verschiebung in horizontaler und vertikaler Richtung
2792 bezeichnet.  Negative Zahlen verschieben das Objekt nach links oder
2793 unten.  Die Einheit sind Notenlinienabstände.  Die zusätzliche
2794 Positionierung wird vorgenommen, nachdem alle anderen Objekte
2795 platziert sind, weshalb ein Objekt irgendwohin verschoben werden
2796 kann, ohne den restlichen Satz zu beeinflussen.
2797
2798 @item positions (Position)
2799
2800 @cindex positions-Eigenschaft
2801
2802 Diese Eigenschaft ist am sinnvollsten, um die Steigung und die
2803 Höhe von Balken, Bögen und Triolenklammern anzupassen.
2804 Sie braucht ein Zahlenpaar, das die Position des rechten und linken
2805 Endes relativ zur Mittellinie des Notensystems bestimmt.  Die
2806 Einheit sind Notenlinienabstände.  Bögen allerdings können nicht
2807 beliebig weit weg positioniert werden.  LilyPond erstellt zunächst eine
2808 Liste an möglichen Positionen für den Bogen und findet normalerweise
2809 die Version, die @qq{am besten aussieht}.  Wenn die
2810 @code{positions}-Eigenschaft verändert worden ist, wird der
2811 Bogen aus der Liste gewählt, der der gewünschten Position am
2812 nächsten kommt.
2813 @end table
2814
2815 @end enumerate
2816
2817 Ein bestimmtes Objekt hat vielleicht nicht alle dieser Eigenschaften.
2818 Darum ist es nötig, in der IR nachzuschlagen, welche Eigenschaften
2819 ein bestimmtes Objekt unterstützt.
2820
2821 Hier ist eine Liste an Objekten, die am wahrscheinlichsten an einer
2822 Kollision beteiligt sind, daneben findet sich die Bezeichnung des
2823 Objektes, mit der Sie es in der IR finden, um zu bestimmen,
2824 welche Eigenschaften benutzt werden können, um es zu verschieben.
2825
2826 @multitable @columnfractions .5 .5
2827 @headitem Objekttyp           @tab Objektbezeichnung
2828 @item Articulationszeichen             @tab @code{Script}
2829 @item Balken                     @tab @code{Beam}
2830 @item Dynamikzeichen (vertikal)     @tab @code{DynamicLineSpanner}
2831 @item Dynamikzeichen (horizontal)   @tab @code{DynamicText}
2832 @item Fingersatz                @tab @code{Fingering}
2833 @item Übungs-/Textmarken    @tab @code{RehearsalMark}
2834 @item Legatobögen                     @tab @code{Slur}
2835 @item Text z. B. @code{^"text"}  @tab @code{TextScript}
2836 @item Bindebögen                      @tab @code{Tie}
2837 @item N-tolen                   @tab @code{TupletBracket}
2838 @end multitable
2839
2840
2841 @node Überlappende Notation in Ordnung bringen
2842 @subsection Überlappende Notation in Ordnung bringen
2843 @translationof Fixing overlapping notation
2844
2845 Hier soll nun gezeigt werden, wie die Eigenschaften, die im
2846 vorigen Abschnitt vorgestellt wurden, bei der Problemlösung
2847 mit sich überschneidenden Notationselementen eingesetzt
2848 werden können.
2849
2850 @subheading padding (Fülleigenschafte)
2851
2852 @cindex padding (Verschiebungs-Eigenschaft)
2853 @cindex Überschneidende Notation korrigieren
2854 @cindex Korrigieren von überschneidender Notation
2855
2856 Die @code{padding}-(Verschiebungs-)Eigenschaft kann benutzt
2857 werden, um den Abstand zwischen Symbolen zu vergößern (oder
2858 zu verkleinern), die über oder unter den Noten gesetzt werden.
2859
2860 @cindex Script, Beispiel zur Veränderung
2861 @cindex Verschiebungs-Eigenschaft, Beispiel
2862 @cindex padding (Verschiebuns-Eigenschaft), Beispiel
2863
2864 @lilypond[quote,fragment,relative=1,verbatim]
2865 c2\fermata
2866 \override Script #'padding = #3
2867 b2\fermata
2868 @end lilypond
2869
2870 @cindex MetronomMark, Beispiel zur Veränderung
2871 @cindex Verschiebungs-Eigenschaft, Beispiel
2872 @cindex padding (Verschiebuns-Eigenschaft), Beispiel
2873
2874 @lilypond[quote,fragment,relative=1,verbatim]
2875 % This will not work, see below
2876 \override MetronomeMark #'padding = #3
2877 \tempo 4 = 120
2878 c1 |
2879 % This works
2880 \override Score.MetronomeMark #'padding = #3
2881 \tempo 4 = 80
2882 d1 |
2883 @end lilypond
2884
2885 Im zweiten Beispiel können Sie sehen, wie wichtig es ist den richtigen
2886 Kontext anzugeben.  Weil das @code{MetronomeMark}-Objekt
2887 sich im @code{Score}-Kontext befindet, werden Eigenschaftsänderungen
2888 im @code{Voice}-Kontext einfach ignoriert.  Für mehr Einzelheiten siehe
2889 @ruser{Eigenschaften verändern}.
2890
2891 Wenn die @code{padding}-Eigenschaft eines Objektes erhöht wird, das
2892 sich in einem Stapel von Objekten befindet, die nach ihrer
2893 Außersystempriorität (@code{outside-staff-priority}) positioniert werden,
2894 werden das Objekt und alle,  die sich außerhalb davon befinden,
2895 entsprechend verschoben.
2896
2897 @subheading right-padding (Verschieben nach links)
2898
2899 @cindex Verschiebung nach rechts
2900 @cindex right-padding-Eigenschaft (Verschiebung nach rechts)
2901
2902 Die @code{right-padding}-Eigenschaft wirkt sich auf den Abstand
2903 zwischen einem Versetzungszeichen und der Note, auf das sie sich
2904 bezieht, aus.  Sie wird nicht sehr oft benötigt, aber die
2905 Standardanordnung kann für einige spezielle Versetzungszeichen-Glyphen
2906 oder Kombinationsglyphen,
2907 wie sie für Mikrotonale Musik benutzt werden, falsch sein.  Derartige
2908 Glyphen müssen notiert werden, indem man den Stencil des
2909 Versetzungszeichens mit einer Textbeschriftung (Markup) ersetzt,
2910 wie im folgenden Beispiel:
2911
2912 @cindex Versetzungszeichen, Beispiel zur Veränderung
2913 @cindex Accidental, Beispiel zur Veränderung
2914 @cindex Text-Eigenschaft, Beispiel
2915 @cindex stencil-Eigenschaft, Beispiel
2916 @cindex AccidentalPlacement, Beispiel zur Veränderung
2917 @cindex right-padding-Eigenschaft, Beispiel
2918 @cindex Verschiebung nach rechts (rigth-padding), Beispiel
2919
2920 @lilypond[quote,ragged-right,verbatim]
2921 sesquisharp = \markup { \sesquisharp }
2922  \relative c'' {
2923   c4
2924   % This prints a sesquisharp but the spacing is too small
2925   \once \override Accidental
2926     #'stencil = #ly:text-interface::print
2927   \once \override Accidental #'text = #sesquisharp
2928   cis4 c
2929   % This improves the spacing
2930   \once \override Score.AccidentalPlacement #'right-padding = #0.6
2931   \once \override Accidental
2932     #'stencil = #ly:text-interface::print
2933   \once \override Accidental #'text = #sesquisharp
2934   cis4
2935 }
2936 @end lilypond
2937
2938 @noindent
2939 Dazu ist aber ein @code{\override}-Befehl für den Stencil des
2940 Versetzungszeichens nötig, der bisher nicht behandelt wurde.
2941 Der Typ des Stencils muss eine Prozedur sein, die hier geändert
2942 wurde, um den Inhalt der @code{text}-Eigenschaft des
2943 @code{Accidental} (Versetzungszeichen)-Objekts zu setzen.  Die
2944 @code{text}-Eigenschaft wiederum wird als @code{sesquisharp}-Glyph
2945 definiert.  Dieser Glyph wird dann weiter vom Notenkopf entfernt
2946 durch die Veränderung von @code{right-padding} mit einem
2947 @code{\override}-Befehl.
2948
2949 @subheading staff-padding (Systemfüllungseigenschaft)
2950
2951 @cindex staff-padding-Eigenschaft
2952 @cindex Objekte an der Grundlinie ausrichten
2953 @cindex Ausrichten von Objekten an der Grundlinie
2954
2955 @code{staff-padding} (Verschiebung zum Notensystem) kann
2956 verwendet werden um Objekte wie Dynamikzeichen an einer
2957 Grundlinie auf einer bestimmten Höhe über dem System
2958 auszurichten, sodass sie nicht von der Position der Note abhängen,
2959 an die sie angehängt sind.  Diese Verschiebung ist keine Eigenschaft
2960 von @code{DynamicText}, sondern von @code{DynamicLineSpanner}.
2961 Das liegt daran, dass die Grundlinie sich gleicherweise auf
2962 @strong{alle} Dynamikzeichen beziehen soll, also auch auf die,
2963 die als Strecker erstellt wurden.  Hier also die Lösung, die Dynamikzeichen
2964 aus dem Beispiel des vorigen Abschnitts auszurichten:
2965
2966 @cindex DynamikText, Beispiel zur Veränderung
2967 @cindex extra-spacing-width-Eigenschaft, Beispiel
2968 @cindex DynamicLineSpanner, Beispiel zur Veränderung
2969 @cindex staff-padding-Eigenschaft, Beispiel
2970
2971 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2972 \dynamicUp
2973 % Extend width by 1 unit
2974 \override DynamicText #'extra-spacing-width = #'(-0.5 . 0.5)
2975 % Align dynamics to a base line 2 units above staff
2976 \override DynamicLineSpanner #'staff-padding = #2
2977 a4\f b\mf c\mp b\p
2978 @end lilypond
2979
2980
2981 @subheading self-alignment-X (Selbstausrichtung-X-Eigenschaft)
2982
2983 @cindex self-alignment-X-Eigenschaft
2984
2985 Das nächste Beispiel zeigt, wie man den Zusammenstoß
2986 einer Fingersatzbezeichnung mit einem Notenhals
2987 verhindern kann, indem die rechte Ecke an dem
2988 Referenzpunkt der abhängigen Note angeordnet wird:
2989
2990 @cindex StringNumber, Beispiel zur Veränderung
2991
2992 @lilypond[quote,fragment,ragged-right,verbatim,relative=3]
2993 \voiceOne
2994 < a\2 >
2995 \once \override StringNumber #'self-alignment-X = #RIGHT
2996 < a\2 >
2997 @end lilypond
2998
2999
3000 @subheading staff-position (Position innerhalb des Systems)
3001
3002 @cindex staff-position-Eigenschaft
3003 @cindex Notensystem-Position-Eigenschaft
3004 @cindex Kollision von Objekten im System
3005 @cindex Zusammenstöße von Objekten im System
3006
3007 Vieltaktpausen in einer Stimmen können mit Noten in anderen
3008 Stimmen kollidieren.  Da diese Pausen zentriert zwischen den
3009 Taktlinien gesetzt werden, würde es für LilyPond eine recht große
3010 Anstrengung bedeuten herauszufinden, welche Noten mit ihnen
3011 zusammenstoßen könnten, denn alle Kollisionsvermeidung
3012 für Noten und Pausen funktioniert nur für Noten bzw. Pausen, die
3013 zur selben Zeit auftreten.  Hier ein typisches Beispiel für eine
3014 Kollision dieser Art:
3015
3016 @lilypond[quote,verbatim,fragment,ragged-right, relative=1]
3017 << { c4 c c c } \\ { R1 } >>
3018 @end lilypond
3019
3020 Die beste Lösung ist es, die Ganztaktpause nach unten zu
3021 schieben, denn die Pause ist in der zweiten Stimme.  Per
3022 Standardeinstellung für die zweite Stimme (@code{\voiceTwo},
3023 also die zweite Stimme in der
3024 @code{<<@{...@} \\ @{...@}>>}-Konstruktion) wird die
3025 Position auf dem System (@code{staff-position}) auf -4
3026 für @code{MultiMeasureRest}, in unserem Beispiel muss
3027 es also bspw. auf die Position @w{@code{-8}} gesetzt werden,
3028 d.h. vier halbe Notenlinienabstände weiter nach unten:
3029
3030 @cindex MultiMeasureRest, Beispiel zur Veränderung
3031 @cindex Ganztaktpausen, Beispiel zur Veränderung
3032 @cindex staff-position-Eigenschaft, Beispiel
3033
3034 @lilypond[quote,verbatim,fragment,ragged-right, relative=1]
3035 <<
3036   { c4 c c c }
3037   \\
3038   \override MultiMeasureRest #'staff-position = #-8
3039   { R1 }
3040 >>
3041 @end lilypond
3042
3043 Das ist besser, als etwa @code{extra-offset} zu benutzen, denn
3044 in unserem Fall wird die Hilfslinie der Pause automatisch gesetzt.
3045
3046
3047 @subheading extra-offset (Genaues Positionieren)
3048
3049 @cindex extra-offset-Eigenschaft
3050 @cindex Zusätzlicher Abstand, Positionierung
3051 @cindex Positionierung von Objekten
3052 @cindex Objekte, Positionierung
3053
3054 Die @code{extra-offset}-Eigenschaft bietet vollständige Kontrolle
3055 über die Positionierung von Objekten in horizontaler und vertikaler
3056 Richtung.
3057
3058 Im Beispiel unten ist das zweite Fingersatzzeichen (@code{Fingering}) etwas nach
3059 links und 1,8 Notenlinienabstände nach unten verschoben:
3060
3061 @cindex Fingersatz, Beispiel zur Veränderung
3062 @cindex extra-offset-Eigenschaft, Beispiel
3063
3064 @lilypond[quote,fragment,relative=1,verbatim]
3065 \stemUp
3066 f4-5
3067 \once \override Fingering #'extra-offset = #'(-0.3 . -1.8)
3068 f4-5
3069 @end lilypond
3070
3071
3072 @subheading Ausrichtungseigenschaft
3073
3074 @cindex positions-Eigenschaft
3075 @cindex Kontrolle über Triolen, Bögen und Balken manuell
3076 @cindex manuelle Kontrolle über Triolen, Bögen, Balken
3077 @cindex Balken, manuelle Kontrolle
3078 @cindex Bögen, manuelle Kontrolle
3079 @cindex Legatobögen, manuelle Kontrolle
3080 @cindex Phrasierungsbögen, manuelle Kontrolle
3081 @cindex Triollen-Klammer, manuelle Kontrolle
3082
3083 Die @code{positions}-Eigenschaft erlaubt die Kontrolle von Position und
3084 Steigung von Balken, Legato- und Phrasierungsbögen sowie Triolenklammern.
3085 Hier ein Beispiel, in der ein unschöner Phrasierungsbogen auftritt, weil
3086 er den Bogen des Vorschlags vermeidet:
3087
3088 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
3089 r4  \acciaccatura e8\( d8 c~ c d c d\)
3090 @end lilypond
3091
3092 @noindent
3093 Man könnte einfach den Phrasierungsbogen oberhalb der Noten setzen, und
3094 das wäre auch die beste Lösung:
3095
3096 @cindex Phrasierungsbogen, Beispiel zur Veränderung
3097 @cindex positions-Eigenschaft, Beispiel
3098 @cindex Positionierung, Beispiel
3099
3100 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
3101 r4
3102 \phrasingSlurUp
3103 \acciaccatura e8\( d8 c~ c d c d\)
3104 @end lilypond
3105
3106 @noindent
3107 aber wenn es einen Grund geben sollte, warum das nicht geht, könnte
3108 man das linke Ende des Phrasierungsbogens etwas nach unten verschieben,
3109 indem man die @code{positions}-Eigenschaft einsetzt.  Damit
3110 verschwindet auch die etwas unschöne Form:
3111
3112 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
3113 r4
3114 \once \override PhrasingSlur #'positions = #'(-4 . -3)
3115 \acciaccatura e8\( d8 c~ c d c d\)
3116 @end lilypond
3117
3118 Hier noch ein weiteres Beispiel.  Wie zu sehen ist,
3119 stößt der Balken mit den oberen Bögen zusammen:
3120
3121 @lilypond[quote,verbatim,fragment,ragged-right]
3122 {
3123   \time 4/2
3124   <<
3125     { c'1 ~ c'2. e'8 f' }
3126     \\
3127     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
3128   >>
3129   <<
3130     { c'1 ~ c'2. e'8 f' }
3131     \\
3132     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
3133   >>
3134 }
3135 @end lilypond
3136
3137 @noindent
3138 Das kann manuell gelöst werden, indem beide Enden des Balkens
3139 von ihrer Position 1.81 Notenlinienabstände unter der Mittellinie
3140 hochgeschoben werden, etwa auf 1:
3141
3142 @cindex Balken, Beispiel zur Veränderung
3143 @cindex positions-Eigenschaft, Beispiel
3144 @cindex Positionierung, Beispiel
3145
3146 @lilypond[quote,verbatim,fragment,ragged-right]
3147 {
3148   \time 4/2
3149   <<
3150     { c'1 ~ c'2. e'8 f' }
3151     \\
3152     {
3153       \override Beam #'positions = #'(-1 . -1)
3154       e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g''
3155     }
3156   >>
3157   <<
3158     { c'1 ~ c'2. e'8 f' }
3159     \\
3160     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
3161   >>
3162 }
3163 @end lilypond
3164
3165 @noindent
3166 Hier ist zu beobachten, dass die Veränderung sich auch auf den
3167 die erste Stimme des weiteren Taktes mit Achtelnoten auswirkt, während sie keine
3168 Auswirkung auf die Balken der zweiten Stimme hat.
3169
3170 @subheading force-hshift (vertikale Verschiebunseigenschaft)
3171
3172 @cindex force-hshift-Eigenschaft
3173 @cindex Vertikale Verschiebung erzwingen
3174
3175 An diesem Punkt können wir den letzten Feinschliff an unserem
3176 Chopin-Beispiel vornehmen, das wir behandelt haben in
3177 @ref{Ich höre Stimmen}.  Wir hatten es in folgende Form
3178 gebracht:
3179
3180 @lilypond[quote,verbatim,fragment,ragged-right]
3181 \new Staff \relative c'' {
3182   \key aes \major
3183   <<
3184     { c2 aes4. bes8 }
3185     \\
3186     { <ees, c>2 des }
3187     \\
3188     \\
3189     { aes'2 f4 fes }
3190   >> |
3191   <c ees aes c>1 |
3192 }
3193 @end lilypond
3194
3195 @noindent
3196 Die inneren Noten des ersten Akkordes (also das As in der vierten Stimme)
3197 müssen nicht mit shift verschoben aus der Noten-Kolumne der höheren Stimme
3198 verschoben werden.  Um das zu korrigieren, setzen wir den Wert von
3199 @code{force-hshift}, einer Eigenschaft von @code{NoteColumn}, auf Null.
3200
3201 Im zweiten Akkord wollen wir, dass das F sich am A orientiert und die
3202 tiefste Note leicht nach rechts verschoben wird, damit ein Zusammenstoß
3203 der Hälse vermieden wird.  Das erreicht man mit @code{force-hshift} in
3204 @code{NoteColumn} des unteren Des, um es nach rechts um einen halben
3205 Notenlinienzwischenraum zu verschieben.
3206
3207 Hier das Endergebnis:
3208
3209 @cindex Notenkolumne, Beispiel zur Veränderung
3210 @cindex force-hshift-Eigenschaft, Beispiel
3211 @cindex vertikale Verschiebung, Beispiel
3212
3213 @lilypond[quote,verbatim,fragment,ragged-right]
3214 \new Staff \relative c'' {
3215   \key aes \major
3216   <<
3217     { c2 aes4. bes8 }
3218     \\
3219     {
3220       <ees, c>2
3221       \once \override NoteColumn #'force-hshift = #0.5
3222       des2
3223     }
3224     \\
3225     \\
3226     {
3227       \override NoteColumn #'force-hshift = #0
3228       aes'2 f4 fes
3229     }
3230   >> |
3231   <c ees aes c>1 |
3232 }
3233 @end lilypond
3234
3235
3236 @node Beispiele aus dem Leben
3237 @subsection Beispiele aus dem Leben
3238 @translationof Real music example
3239
3240 Das Kapitel zu Optimierungen soll mit einem komplizierten Beispiel
3241 beendet werden, in dem verschiedene Optimierungen vorgenommen
3242 werden müssen, bis das Ergebnis gut aussieht.  Das Beispiel wurde
3243 ganz bewusst gewählt um die Benutzung der Notationsreferenz
3244 zu zeigen, wenn ungewöhnliche Notationsprobleme gelöst werden
3245 müssen.  Es ist nicht repräsentativ für normale Notationsprojekte,
3246 lassen Sie sich also nicht durch dieses Beispiel entmutigen!  Zum
3247 Glück sind Probleme wie die hier gezeigten nicht sehr häufig.
3248
3249 Das Beispiel stammt aus Chopins Premiére Ballade, Op. 23, Takte
3250 6--9, der Übergang vom Lento der Einleitung zum Moderato.
3251 Hier zunächst der Satz, wie er aussehen soll, allerdings ohne
3252 Dynamik, Fingersatz und Pedalbezeichnung, um das Beispiel nicht
3253 zu kompliziert zu machen.
3254
3255 @c This example should not be indexed
3256 @lilypond[quote,ragged-right,line-width=6\in]
3257 rhMusic = \relative c'' {
3258   \new Voice {
3259     r2 c4.\( g8 |
3260     \once \override Tie #'staff-position = #3.5
3261     bes1~ |
3262     \bar "||"
3263     \time 6/4
3264     \mergeDifferentlyHeadedOn
3265     \mergeDifferentlyDottedOn
3266     bes2.^\markup { \bold "Moderato" } r8
3267     <<
3268       { c,8 d fis bes a }
3269       \new Voice {
3270         \voiceTwo
3271         c,8~
3272         % Reposition the c2 to the right of the merged note
3273         \once \override NoteColumn #'force-hshift = #1.0
3274         % Move the c2 out of the main note column
3275         % so the merge will work
3276         \shiftOnn
3277         c2
3278       }
3279       \new Voice {
3280         \voiceThree
3281         s8
3282         % Stem on the d2 must be down to permit merging
3283         \stemDown
3284         % Stem on the d2 should be invisible
3285         \tweak Stem #'transparent = ##t
3286         \tweak Flag #'transparent = ##t
3287         d2
3288       }
3289       \new Voice {
3290         \voiceFour
3291         s4 fis4.
3292       }
3293     >> |
3294     \mergeDifferentlyHeadedOff
3295     \mergeDifferentlyDottedOff
3296     g2.\)
3297   }
3298 }
3299
3300 lhMusic = \relative c' {
3301   r2 <c g ees>2( |
3302   <d g, d>1)\arpeggio |
3303   r2. d,,4 r4 r |
3304   r4
3305 }
3306
3307 \score {
3308   \new PianoStaff <<
3309     \new Staff = "RH"  <<
3310       \key g \minor
3311       \rhMusic
3312     >>
3313     \new Staff = "LH" <<
3314       \key g \minor
3315       \clef "bass"
3316       \lhMusic
3317     >>
3318   >>
3319 }
3320 @end lilypond
3321
3322 Die erste Überlegung ist, dass das System für die rechte Hand
3323 im dritten Takt vier Stimmen braucht.  Das sind die fünf
3324 Achtelnoten mit Balken, das übergebundene C, die Halbe D, die
3325 mit der Achtel D verschmolzen ist, und die punktierte Viertel
3326 Fis, die auch mit einer Achtelnote verschmolzen ist.  Alles
3327 andere ist eine einzige Stimme, es ist also am einfachsten, die
3328 zusätzlichen drei Stimmen nur zeitweise zu erstellen, wenn sie
3329 auftreten.  Wenn Sie vergessen haben, wie man das anstellt,
3330 schauen Sie sich nochmal den Abschnitt @ref{Ich höre Stimmen}
3331 und @ref{Stimmen explizit beginnen} an.  Hier wollen wir explizit
3332 begonnene Stimmen für die polyphone Stelle benutzen, weil LilyPond
3333 Kollisionen besser vermeidet, wenn alle Stimmen auf diese Weise
3334 explizit begonnen werden.
3335
3336
3337 Wir wollen anfange, indem wir die Noten in zwei Variablen
3338 notieren und dann die Systemstruktur in einer
3339 @code{\score}-Umgebung erstellen.  Das ist, was LilyPond
3340 erstellt:
3341
3342 @c line-width ensures no break
3343 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3344 rhMusic = \relative c'' {
3345   \new Voice {    r2 c4. g8 |
3346     bes1~ |
3347     \time 6/4
3348     bes2. r8
3349     % Start polyphonic section of four voices
3350     <<
3351       { c,8 d fis bes a }  % continuation of main voice
3352       \new Voice {
3353         \voiceTwo
3354         c,8~ c2
3355       }
3356       \new Voice {
3357         \voiceThree
3358         s8 d2
3359       }
3360       \new Voice {
3361         \voiceFour
3362         s4 fis4.
3363       }
3364     >> |
3365     g2.  % continuation of main voice
3366   }
3367 }
3368
3369 lhMusic = \relative c' {
3370   r2 <c g ees>2 |
3371   <d g, d>1 |
3372   r2. d,,4 r4 r |
3373   r4
3374 }
3375
3376 \score {
3377   \new PianoStaff <<
3378     \new Staff = "RH"  <<
3379       \key g \minor
3380       \rhMusic
3381     >>
3382     \new Staff = "LH" <<
3383       \key g \minor
3384       \clef "bass"
3385       \lhMusic
3386     >>
3387   >>
3388 }
3389 @end lilypond
3390
3391 Alle Noten sind richtig, aber die Positionierung sehr
3392 verbesserungsbedürftig.  Der Bindebogen kollidiert mit
3393 der veränderten Taktart zusammen, einige Noten werden nicht
3394 verschmolzen und einige Notationselemente fehlen ganz.
3395 Behandeln wir zunächst die einfacheren Dinge.  Der
3396 Balken kann durch eine manuelle Begrenzung einfach
3397 korrigiert werden, und auch der Legatobogen der linken
3398 Hand und der Phrasierungsbogen der rechten Hand
3399 sind schnell gesetzt, denn sie wurden schon in der
3400 Übung erklärt.  Damit haben wir folgendes Notenbild:
3401
3402 @c line-width ensures no break
3403 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3404 rhMusic = \relative c'' {
3405   \new Voice {
3406     r2 c4.\( g8 |
3407     bes1~ |
3408     \time 6/4
3409     bes2. r8
3410     % Start polyphonic section of four voices
3411     <<
3412       { c,8 d fis bes a }  % continuation of main voice
3413       \new Voice {
3414         \voiceTwo
3415         c,8~ c2
3416       }
3417       \new Voice {
3418         \voiceThree
3419         s8 d2
3420       }
3421       \new Voice {
3422         \voiceFour
3423         s4 fis4.
3424       }
3425     >> |
3426     g2.\)  % continuation of main voice
3427   }
3428 }
3429
3430 lhMusic = \relative c' {
3431   r2 <c g ees>2( |
3432   <d g, d>1) |
3433   r2. d,,4 r4 r |
3434   r4
3435 }
3436
3437 \score {
3438   \new PianoStaff <<
3439     \new Staff = "RH"  <<
3440       \key g \minor
3441       \rhMusic
3442     >>
3443     \new Staff = "LH" <<
3444       \key g \minor
3445       \clef "bass"
3446       \lhMusic
3447     >>
3448   >>
3449 }
3450 @end lilypond
3451
3452 Der erste Takt stimmt jetzt schon.  Der zweite Takt enthält ein
3453 Arpeggio und wird mit einer doppelten Taktlinie beschlossen.
3454 Wie können wir diese notieren, denn sie sind im Handbuch zum
3455 Lernen nicht vorgekommen?  Hier brauchen wir jetzt die
3456 Notationsreferenz.  Ein Blick in den Index zeigt uns die
3457 Einträge für @qq{Arpeggio} und @qq{Taktlinien}: ein
3458 Arpeggio also erstellt man mit dem Befehl @code{\arpeggio}
3459 hinter einem Akkord und eine doppelte Taktlinie wird mit dem
3460 Befehl @code{\bar "||"} erstellt.  Das ist einfach.  Als nächstes
3461 muss der Zusammenstoß des Bindebogens mit der Taktartbezeichnung
3462 gelöst werden.  Das geht am besten, indem wir den Bogen nach
3463 oben verschieben.  Wie man Objekte verschiebt wurde schon
3464 behandelt in @ref{Verschieben von Objekten}, wo stand, dass Objekte
3465 die relativ zum System positioniert werden, vertikal verschoben werden
3466 können, indem ihre @code{staff-position}-Eigenschaft
3467 geändert wird, die in halben Notenlinienabständen relativ
3468 zur Mittellinie angegeben wird.  Dieser @code{\override}-Befehl
3469 also, direkt vor die erste übergebundene Note gestellt, verschiebt
3470 den Bindebogen (@code{tie}) 3,5 halbe Notenlinienabstände
3471 über die Mittellinie:
3472
3473 @code{\once \override Tie #'staff-position = #3.5}
3474
3475 Damit ist auch der zweite Takt vollständig:
3476
3477 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3478 rhMusic = \relative c'' {
3479   \new Voice {
3480     r2 c4.\( g8 |
3481     \once \override Tie #'staff-position = #3.5
3482     bes1~ |
3483     \bar "||"
3484     \time 6/4
3485     bes2. r8
3486     % Start polyphonic section of four voices
3487     <<
3488       { c,8 d fis bes a }  % continuation of main voice
3489       \new Voice {
3490         \voiceTwo
3491         c,8~ c2
3492       }
3493       \new Voice {
3494         \voiceThree
3495         s8 d2
3496       }
3497       \new Voice {
3498         \voiceFour
3499         s4 fis4.
3500       }
3501     >> |
3502     g2.\)  % continuation of main voice
3503   }
3504 }
3505
3506 lhMusic = \relative c' {
3507   r2 <c g ees>2( |
3508   <d g, d>1)\arpeggio |
3509   r2. d,,4 r4 r |
3510   r4
3511 }
3512
3513 \score {
3514   \new PianoStaff <<
3515     \new Staff = "RH"  <<
3516       \key g \minor
3517       \rhMusic
3518     >>
3519     \new Staff = "LH" <<
3520       \key g \minor
3521       \clef "bass"
3522       \lhMusic
3523     >>
3524   >>
3525 }
3526 @end lilypond
3527
3528 In Takt drei beginnt der Moderato-Abschnitt.  In der
3529 Übung wurde behandelt, wie man fetten Text mit dem
3530 @code{\markup}-Befehl eingibt, es ist also einfach, das
3531 @qq{Moderato} in fetter Schrift hinzuzufügen.  Wie aber werden Noten
3532 verschmolzen?  Hier nehmen wir wieder die Notationsreferenz
3533 zu Hilfe.  Die Suche nach @qq{Verschmelzen} (engl. merge)
3534 im Index führt uns zu den Befehlen, um Noten mit
3535 unterschiedlichen Köpfen und unterschiedlichen Punkten
3536 zu verschmelzen, in @ruser{Auflösung von Zusammenstößen}.  In unserem
3537 Beispiel müssen sowohl unterschiedliche Köpfe also auch
3538 unterschiedliche Punktierung verschmolzen werden, wir
3539 brauchen also die Befehle
3540
3541 @example
3542 \mergeDifferentlyHeadedOn
3543 \mergeDifferentlyDottedOn
3544 @end example
3545
3546 @noindent
3547 aus der Notationsreferenz, die wir an den Beginn unseres
3548 Abschnittes stellen und
3549
3550 @example
3551 \mergeDifferentlyHeadedOff
3552 \mergeDifferentlyDottedOff
3553 @end example
3554
3555 @noindent
3556 um das Verhalten wieder auszuschalten. Das sieht so aus:
3557
3558 @cindex Bindebogen, Beispiel zur Veränderung
3559 @cindex staff-position-Eigenschaft, Beispiel
3560
3561 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3562 rhMusic = \relative c'' {
3563   \new Voice {
3564     r2 c4.\( g8 |
3565     \once \override Tie #'staff-position = #3.5
3566     bes1~ |
3567     \bar "||"
3568     \time 6/4
3569     bes2.^\markup { \bold "Moderato" } r8
3570     \mergeDifferentlyHeadedOn
3571     \mergeDifferentlyDottedOn
3572     % Start polyphonic section of four voices
3573     <<
3574       { c,8 d fis bes a }  % continuation of main voice
3575       \new Voice {
3576         \voiceTwo
3577         c,8~ c2
3578       }
3579       \new Voice {
3580         \voiceThree
3581         s8 d2
3582       }
3583       \new Voice {
3584         \voiceFour
3585         s4 fis4.
3586       }
3587     >> |
3588     \mergeDifferentlyHeadedOff
3589     \mergeDifferentlyDottedOff
3590     g2.\)  % continuation of main voice
3591   }
3592 }
3593
3594 lhMusic = \relative c' {
3595   r2 <c g ees>2( |
3596   <d g, d>1)\arpeggio |
3597   r2. d,,4 r4 r |
3598   r4
3599 }
3600
3601 \score {
3602   \new PianoStaff <<
3603     \new Staff = "RH"  <<
3604       \key g \minor
3605       \rhMusic
3606     >>
3607     \new Staff = "LH" <<
3608       \key g \minor
3609       \clef "bass"
3610       \lhMusic
3611     >>
3612   >>
3613 }
3614 @end lilypond
3615
3616 Mit diesen Veränderungen wurden die beiden Fis-Noten
3617 verschmolzen, aber nicht die zwei Ds.  Warum nicht?  Die
3618 Antwort befindet sich im gleicher Abschnitt der Notationsreferenz:
3619 Noten, die verschmolzen werden, müssen Hälse in entgegengesetzte
3620 Richtungen aufweisen und zwei Noten können nicht verschmolzen
3621 werden, wenn eine dritte Noten in der gleichen Kolumne
3622 stört.  In unserem Fall weisen beide Hälse nach oben und es
3623 befindet sich zur gleichen Zeit auch noch eine dritte Note, das C.
3624 Wie die Richtung von Hälsen geändert wird, wissen wir schon:
3625 mit @code{\stemDown}, und in der Notationsreferenz findet
3626 sich auch Information, wie das C verschoben werden kann: mit
3627 dem @code{\shift}-Befehl.  Aber welcher von ihnen?  Das C
3628 befindet sich in der zweiten Stimme, die @qq{shift off} hat,
3629 die zwei Ds sind in den Stimmen eins und drei, die @qq{shift
3630 off} bzw. @qq{shift on} haben.  Das C muss also noch eine
3631 Stufe weiter verschoben werden mit @code{\shiftOnn}, damit
3632 es die Verschmelzung der Ds nicht stört.  Das sieht jetzt so
3633 aus:
3634
3635 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3636 rhMusic = \relative c'' {
3637   \new Voice {
3638     r2 c4.\( g8 |
3639     \once \override Tie #'staff-position = #3.5
3640     bes1~ |
3641     \bar "||"
3642     \time 6/4
3643     bes2.^\markup { \bold "Moderato" } r8
3644     \mergeDifferentlyHeadedOn
3645     \mergeDifferentlyDottedOn
3646     % Start polyphonic section of four voices
3647     <<
3648       { c,8 d fis bes a }  % continuation of main voice
3649       \new Voice {
3650         \voiceTwo
3651         % Move the c2 out of the main note column so the merge will work
3652         c,8~ \shiftOnn c2
3653       }
3654       \new Voice {
3655         \voiceThree
3656         % Stem on the d2 must be down to permit merging
3657         s8 \stemDown d2
3658       }
3659       \new Voice {
3660         \voiceFour
3661         s4 fis4.
3662       }
3663     >> |
3664     \mergeDifferentlyHeadedOff
3665     \mergeDifferentlyDottedOff
3666     g2.\)  % continuation of main voice
3667   }
3668 }
3669
3670 lhMusic = \relative c' {
3671   r2 <c g ees>2( |
3672   <d g, d>1)\arpeggio |
3673   r2. d,,4 r4 r |
3674   r4
3675 }
3676
3677 \score {
3678   \new PianoStaff <<
3679     \new Staff = "RH"  <<
3680       \key g \minor
3681       \rhMusic
3682     >>
3683    \new Staff = "LH" <<
3684       \key g \minor
3685       \clef "bass"
3686       \lhMusic
3687     >>
3688   >>
3689 }
3690 @end lilypond
3691
3692 Fast schon geschafft.  Nur noch ein Problem ist übrig: Der Hals nach
3693 unten des verschmolzenen sollte nicht da sein, und das C sähe
3694 besser auf der rechten Seite des Ds aus.  Beides können wir mit den
3695 gelernten Optimierungsmethoden erreichen. Den Hals machen
3696 wir durchsichtig und das C verschieben wir mit der
3697 @code{force-hshift}-Eigenschaft.  Hier ist das Endergebnis:
3698
3699 @cindex Notenkolumne, Beispiel zur Veränderung
3700 @cindex force-hshift-Eigenschaft, Beispiel
3701 @cindex Hals, Beispiel zur Veränderung
3702 @cindex Notenhals, Beispiel zur Veränderung
3703 @cindex transparent-Eigenschaft, Beispiel
3704
3705 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3706 rhMusic = \relative c'' {
3707   \new Voice {
3708     r2 c4.\( g8 |
3709     \once \override Tie #'staff-position = #3.5
3710     bes1~ |
3711     \bar "||"
3712     \time 6/4
3713     bes2.^\markup { \bold "Moderato" } r8
3714     \mergeDifferentlyHeadedOn
3715     \mergeDifferentlyDottedOn
3716     % Start polyphonic section of four voices
3717     <<
3718       { c,8 d fis bes a }  % continuation of main voice
3719       \new Voice {
3720         \voiceTwo
3721         c,8~
3722         % Reposition the c2 to the right of the merged note
3723         \once \override NoteColumn #'force-hshift = #1.0
3724         % Move the c2 out of the main note column
3725         % so the merge will work
3726         \shiftOnn
3727         c2
3728       }
3729       \new Voice {
3730         \voiceThree
3731         s8
3732         % Stem on the d2 must be down to permit merging
3733         \stemDown
3734         % Stem on the d2 should be invisible
3735         \tweak Stem #'transparent = ##t
3736         \tweak Flag #'transparent = ##t
3737         d2
3738       }
3739       \new Voice {
3740         \voiceFour
3741         s4 fis4.
3742       }
3743     >> |
3744     \mergeDifferentlyHeadedOff
3745     \mergeDifferentlyDottedOff
3746     g2.\)  % continuation of main voice
3747   }
3748 }
3749
3750 lhMusic = \relative c' {
3751   r2 <c g ees>2( |
3752   <d g, d>1)\arpeggio |
3753   r2. d,,4 r4 r |
3754   r4
3755 }
3756
3757 \score {
3758   \new PianoStaff <<
3759     \new Staff = "RH"  <<
3760       \key g \minor
3761       \rhMusic
3762     >>
3763     \new Staff = "LH" <<
3764       \key g \minor
3765       \clef "bass"
3766       \lhMusic
3767     >>
3768   >>
3769 }
3770 @end lilypond
3771
3772
3773 @node Weitere Optimierungen
3774 @section Weitere Optimierungen
3775 @translationof Further tweaking
3776
3777 @menu
3778 * Andere Benutzung von Optimierungen::
3779 * Variablen für Optimierungen einsetzen::
3780 * Globale Formatierung::
3781 * Mehr Information::
3782 * Fortgeschrittene Optimierungen mit Scheme::
3783 @end menu
3784
3785 @node Andere Benutzung von Optimierungen
3786 @subsection Andere Benutzung von Optimierungen
3787 @translationof Other uses for tweaks
3788
3789 @cindex Transparente Objekte
3790 @cindex Entfernen von Objekten
3791 @cindex Verstecken von Objekten
3792 @cindex Unsichtbare Objekte
3793 @cindex transparent-Eigenschaft, Benutzung
3794 @cindex Objekte unsichtbar machen
3795 @cindex Objekte entfernen
3796 @cindex Objekte verstecken
3797 @cindex Noten zwischen Stimmen überbinden
3798 @cindex Überbinden von Noten zwischen Stimmen
3799
3800 @subheading Noten zwischen unterschiedlichen Stimmen überbinden
3801
3802 Das nächste Beispiel zeigt, wie man Noten von verschiedenen
3803 Stimmen miteinander verknüpfen kann, indem man Bindebögen
3804 für Überbindungen benutzt.  Normalerweise können nur zwei
3805 Noten der gleichen Stimme übergebunden werden.  Wenn
3806 man zwei Stimmen benutzt, wobei die überbundenen Noten
3807 sich in der selben befinden,
3808
3809 @lilypond[quote,fragment,relative=2]
3810 << { b8~ b8\noBeam } \\ { b[ g8] } >>
3811 @end lilypond
3812
3813 @noindent
3814 und dann den ersten Hals nach oben unsichtbar macht,
3815 sieht es so aus, als ob die Überbindung zwischen
3816 den Stimmen stattfindet:
3817
3818 @cindex Hals, Beispiel zur Veränderung
3819 @cindex Notenhals, Beispiel zur Veränderung
3820 @cindex transparent-Eigenschaft, Beispiel
3821
3822 @lilypond[quote,fragment,relative=2,verbatim]
3823 <<
3824   {
3825     \tweak Stem #'transparent = ##t
3826     \tweak Flag #'transparent = ##t
3827     b8~ b\noBeam
3828   }
3829 \\
3830   { b8[ g] }
3831 >>
3832 @end lilypond
3833
3834 Um sicherzugehen, dass der unsichtbare Hals den Bindebogen
3835 nicht zu sehr verkleinert, kann er verlängert werden, indem
3836 seine Länge (@code{length}) auf den Wert @code{8}
3837 gesetzt wird:
3838
3839 @lilypond[quote,fragment,relative=2,verbatim]
3840 <<
3841   {
3842     \tweak Stem #'transparent = ##t
3843     \tweak Flag #'transparent = ##t
3844     \tweak Stem #'length = #8
3845     b8~ b\noBeam
3846   }
3847 \\
3848   { b[ g8] }
3849 >>
3850 @end lilypond
3851
3852
3853 @subheading Eine Fermate in MIDI simulieren
3854
3855 @cindex stencil-Eigenschaft, Benutzung
3856 @cindex Fermate, Benutzung in MIDI
3857 @cindex MIDI: Fermate erstellen
3858
3859 Für Objekte außerhalb des Notensystems ist es normalerweise
3860 besser, die @code{stencil}-Eigenschaft anstelle der
3861 @code{transparent}-Eigenschaft zu verändern, wenn man
3862 sie vom fertigen Notensatz entfernen will.  Indem die
3863 @code{stencil}-Eigenschaft auf falsch (@code{#f}) gesetzt
3864 wird, wird das entsprechende Objekt vollständig entfernt.
3865 Das bedeutet, dass es die Positionierung der anderen Objekte
3866 nicht beeinflusst.
3867
3868 Auf diese Art kann etwa das Tempo geändert werden, damit
3869 in der MIDI-Ausgabe eine Fermate zu hören ist, ohne dass
3870 im Notensatz etwas von diesen Tempoänderungen zu sehen
3871 ist.  Die Metronombezeichnung soll auch nicht die Position
3872 von Text an der gleichen Stelle oder die Abstände zwischen
3873 zwei Systemen beeinflussen.  Darum ist es am besten,
3874 @code{stencil} auf @code{#f} zu setzen.  Im Beispiel wird
3875 der Unterschied zwischen einem unsichtbaren Objekt und
3876 einem entfernten Objekt gezeigt:
3877
3878 @cindex Metronom-Bezeichnung, Beispiel zur Veränderung
3879 @cindex transparent-Eigenschaft, Beispiel
3880
3881 @lilypond[quote,verbatim,ragged-right]
3882 \score {
3883   \relative c'' {
3884     % Visible tempo marking
3885     \tempo 4=120
3886     a4 a a
3887     \once \override Score.MetronomeMark #'transparent = ##t
3888     % Invisible tempo marking to lengthen fermata in MIDI
3889     \tempo 4=80
3890     a4\fermata
3891     % New tempo for next section
3892     \tempo 4=100
3893     a4 a a a
3894   }
3895   \layout { }
3896   \midi { }
3897 }
3898 @end lilypond
3899
3900 @lilypond[quote,verbatim,ragged-right]
3901 \score {
3902   \relative c'' {
3903     % Visible tempo marking
3904     \tempo 4=120
3905     a4 a a
3906     \once \override Score.MetronomeMark #'stencil = ##f
3907     % Invisible tempo marking to lengthen fermata in MIDI
3908     \tempo 4=80
3909     a4\fermata
3910     % New tempo for next section
3911     \tempo 4=100
3912     a4 a a a
3913   }
3914   \layout { }
3915   \midi { }
3916 }
3917 @end lilypond
3918
3919 @noindent
3920 Mit beiden Methoden wird die Tempobezeichnung entfernt, mit
3921 der die Fermate verlängert wird, und beide beeinflussen die
3922 MIDI-Ausgabe wie gewünscht.  Die unsichtbare Metronombezeichnung
3923 schiebt aber die folgende Bezeichnung in die Höhe, während
3924 das im zweiten Beispiel, in dem der @code{stencil} entfernt
3925 wurde, nicht passiert.
3926
3927 @seealso
3928 Glossar:
3929 @rglos{system}.
3930
3931
3932 @node Variablen für Optimierungen einsetzen
3933 @subsection Variablen für Optimierungen einsetzen
3934 @translationof Using variables for tweaks
3935
3936 @cindex Variablen, Benutzung zur Optimierung
3937 @cindex Optimierung mit Variablen
3938
3939 @code{\override}-Befehle sind oft lang und mühsam zu
3940 tippen, und sie müssen immer absolut richtig sein.  Wenn
3941 derselbe Befehl mehrere Male benutzt werden muss, lohnt
3942 es sich oft schon, eine Variable zu definieren, in der er
3943 sich befindet.
3944
3945 Als Beispiel sollen einige Worte im
3946 Gesangstext fett und kursiv hervorgehoben werden.
3947 Die Befehle @code{\italic} und @code{\bold} funktionieren
3948 im Gesangstext-Kontext nur, wenn sie gleichzeitig mit den Wörtern,
3949 auf die sie angewendet werden sollen, zusätzlich
3950 in eine @code{\markup}-Umgebung eingeschlossen
3951 werden. Durch diese Einbettung können einzelne Wörter nicht
3952 einfach zu einer Variable umgeformt werden.  Als
3953 Alternative versuchen wir, einen Befehl mit
3954 @code{\override} und @code{\revert} zu konstruieren.
3955
3956 @example
3957 @code{\override Lyrics . LyricText #'font-shape = #'italic}
3958 @code{\override Lyrics . LyricText #'font-series = #'bold}
3959
3960 @code{\revert Lyrics . LyricText #'font-shape}
3961 @code{\revert Lyrics . LyricText #'font-series}
3962 @end example
3963
3964 Das wäre natürlich noch viel mühsamer, wenn viele Wörter eine
3965 Hervorhebung benötigen.  Anstelle dieser Befehlsketten @emph{können}
3966 wir jedoch zwei Variablen definieren.  Mit ihnen und dem entsprechenden
3967 Wort in geschweiften Klammern erreichen wir den gewünschten Effekt.
3968 Ein weiterer Vorteil ist, dass in diesem Fall die Leerzeichen um die
3969 Punkte herum nicht benötigt werden, weil sie nicht innerhalb des
3970 @code{lyricmode}-Kontextes interpretiert werden.  Hier ein Beispiel;
3971 die Bezeichnungen können natürlich auch kürzer sein,
3972 um noch weniger schreiben zu müssen:
3973
3974 @cindex LyricText, Beispiel zur Veränderung
3975 @cindex Gesangstext, Beispiel zur Veränderung
3976 @cindex font-shape-Eigenschaft, Beispiel
3977 @cindex font-series-Eigenschaft, Beispiel
3978
3979 @lilypond[quote,verbatim]
3980 emphasize = {
3981   \override Lyrics.LyricText #'font-shape = #'italic
3982   \override Lyrics.LyricText #'font-series = #'bold
3983 }
3984 normal = {
3985   \revert Lyrics.LyricText #'font-shape
3986   \revert Lyrics.LyricText #'font-series
3987 }
3988
3989 global = { \key c \major \time 4/4 \partial 4 }
3990
3991 SopranoMusic = \relative c' { c4 | e4. e8 g4 g    | a4   a   g  }
3992 AltoMusic    = \relative c' { c4 | c4. c8 e4 e    | f4   f   e  }
3993 TenorMusic   = \relative c  { e4 | g4. g8 c4.  b8 | a8 b c d e4 }
3994 BassMusic    = \relative c  { c4 | c4. c8 c4 c    | f8 g a b c4 }
3995
3996 VerseOne = \lyrics {
3997   E -- | ter -- nal \emphasize Fa -- ther, | \normal strong to save,
3998 }
3999
4000 VerseTwo = \lyricmode {
4001   O | \once \emphasize Christ, whose voice the | wa -- ters heard,
4002 }
4003
4004 VerseThree = \lyricmode {
4005   O | \emphasize Ho -- ly Spi -- rit, | \normal who didst brood
4006 }
4007
4008 VerseFour = \lyricmode {
4009   O | \emphasize Tri -- ni -- ty \normal of | love and pow'r
4010 }
4011
4012 \score {
4013   \new ChoirStaff <<
4014     \new Staff <<
4015       \clef "treble"
4016       \new Voice = "Soprano"  { \voiceOne \global \SopranoMusic }
4017       \new Voice = "Alto" { \voiceTwo \AltoMusic }
4018       \new Lyrics \lyricsto "Soprano" { \VerseOne }
4019       \new Lyrics \lyricsto "Soprano" { \VerseTwo }
4020       \new Lyrics \lyricsto "Soprano" { \VerseThree }
4021       \new Lyrics \lyricsto "Soprano" { \VerseFour }
4022     >>
4023     \new Staff <<
4024       \clef "bass"
4025       \new Voice = "Tenor" { \voiceOne \TenorMusic }
4026       \new Voice = "Bass"  { \voiceTwo \BassMusic }
4027     >>
4028   >>
4029 }
4030 @end lilypond
4031
4032
4033 @node Globale Formatierung
4034 @subsection Globale Formatierung
4035 @translationof Style sheets
4036
4037 Die Ausgabe von LilyPond kann sehr stark verändert werden, siehe
4038 zu Einzelheiten @ref{Die Ausgabe verändern}.  Aber was ist,
4039 wenn man mehrere Eingabedateien hat, die die gleichen Anpassungen
4040 erfahren sollen?  Oder wenn Sie einfach nur die Anpassungen von
4041 der eigentlichen Musik trennen wollen?  Das lässt sich recht einfach
4042 erreichen.
4043
4044 Schauen wir uns ein Beispiel an.  Sorgen Sie sich nicht, wenn Sie
4045 den Abschnitt mit den vielen @code{#()} nicht verstehen.  Das wird
4046 erklärt in @ref{Fortgeschrittene Optimierungen mit Scheme}.
4047
4048 @lilypond[quote,verbatim,ragged-right]
4049 mpdolce =
4050  #(make-dynamic-script
4051   #{ \markup { \hspace #0
4052                \translate #'(5 . 0)
4053                \line { \dynamic "mp"
4054                        \text \italic "dolce" } }
4055   #})
4056
4057 inst =
4058 #(define-music-function
4059      (parser location string)
4060      (string?)
4061     #{ ^\markup \bold \box #string #})
4062
4063 \relative c'' {
4064   \tempo 4=50
4065   a4.\mpdolce d8 cis4--\glissando a |
4066   b4 bes a2 |
4067   \inst "Clarinet"
4068   cis4.\< d8 e4 fis |
4069   g8(\! fis)-. e( d)-. cis2 |
4070 }
4071 @end lilypond
4072
4073 Vielleicht können die Definitionen von @code{mpdolce} und @code{inst} noch
4074 etwas verbessert werden.
4075 Sie erstellen die gewünschte Ausgabe, aber wir wollen sie vielleicht
4076 auch in einem anderen Stück verwenden.  Wir könnten sie immer wieder
4077 kopieren und oben in jedes Stück einfügen, aber das ist sehr aufwändig.
4078 Dadurch werden die Definitionen auch in der Eingabedatei belassen,
4079 und ich finde diese @code{#()} irgendwie hässlich.  Verstecken
4080 wir sie also:
4081
4082 @example
4083 %%% in Datei "definitions.ily" speichern
4084 mpdolce =
4085  #(make-dynamic-script
4086   #@{ \markup @{ \hspace #0
4087                \translate #'(5 . 0)
4088                \line @{ \dynamic "mp"
4089                        \text \italic "dolce" @} @}
4090   #@})
4091
4092 inst =
4093 #(define-music-function
4094      (parser location string)
4095      (string?)
4096         #@{ ^\markup \bold \box #string #@})
4097 @end example
4098
4099 Diese Datei wir mit dem @code{\include}-Befehl ziemlich weit oben
4100 in der Datei eingefügt.  (Die Erweiterung @file{.ily} wird benutzt,
4101 um diese Datei als eine eingefügte, inkludierte zu kennzeichnen, die
4102 man nicht alleinstehend kompilieren kann.)  Jetzt ändern wir die
4103 Noten (in der Datei @file{music.ly}).
4104
4105 @c  We have to do this awkward example/lilypond-non-verbatim
4106 @c  because we can't do the \include stuff in the manual.
4107
4108 @example
4109 \include "definitions.ily"
4110
4111 \relative c'' @{
4112   \tempo 4=50
4113   a4.\mpdolce d8 cis4--\glissando a |
4114   b4 bes a2 |
4115   \inst "Clarinet"
4116   cis4.\< d8 e4 fis |
4117   g8(\! fis)-. e( d)-. cis2 |
4118 @}
4119 @end example
4120
4121 @lilypond[quote,ragged-right]
4122 mpdolce =
4123  #(make-dynamic-script
4124   #{ \markup { \hspace #0
4125                \translate #'(5 . 0)
4126                \line { \dynamic "mp"
4127                        \text \italic "dolce" } }
4128   #})
4129
4130 inst =
4131 #(define-music-function
4132      (parser location string)
4133      (string?)
4134    #{ ^\markup \bold \box #string #})
4135
4136 \relative c'' {
4137   \tempo 4=50
4138   a4.\mpdolce d8 cis4--\glissando a |
4139   b4 bes a2 |
4140   \inst "Clarinet"
4141   cis4.\< d8 e4 fis |
4142   g8(\! fis)-. e( d)-. cis2 |
4143 }
4144 @end lilypond
4145
4146 Das sieht schon besser aus, aber einige Änderungen könnten wir noch vornehmen.
4147 Das Glissando ist kaum sichtbar, machen wir es also etwas dicker und
4148 näher an den Notenkopf.  Die Metronombezeichnung soll über dem
4149 Schlüssel stehen, anstatt über der ersten Note.  Und schließlich
4150 mag mein Kompositionsprofessor keine @qq{C}-Taktangaben, das ändern
4151 wir also in @qq{4/4}.
4152
4153 Ändern Sie jetzt jedoch nicht @file{music.ly}.  Ändern Sie die
4154 @file{definitions.ily} mit dem Folgenden:
4155
4156 @example
4157 %%%  definitions.ily
4158 mpdolce =
4159 #(make-dynamic-script
4160   #@{ \markup @{ \hspace #0
4161                \translate #'(5 . 0)
4162                \line @{ \dynamic "mp"
4163                        \text \italic "dolce" @} @}
4164   #@})
4165
4166 inst =
4167 #(define-music-function
4168      (parser location string)
4169      (string?)
4170    #@{ ^\markup \bold \box #string #@})
4171
4172 \layout@{
4173   \context @{
4174     \Score
4175     \override MetronomeMark #'extra-offset = #'(-9 . 0)
4176     \override MetronomeMark #'padding = #'3
4177   @}
4178   \context @{
4179     \Staff
4180     \override TimeSignature #'style = #'numbered
4181   @}
4182   \context @{
4183     \Voice
4184     \override Glissando #'thickness = #3
4185     \override Glissando #'gap = #0.1
4186   @}
4187 @}
4188 @end example
4189
4190 @lilypond[quote,ragged-right]
4191 mpdolce =
4192 #(make-dynamic-script
4193   #{ \markup { \hspace #0
4194                \translate #'(5 . 0)
4195                \line { \dynamic "mp"
4196                        \text \italic "dolce" } }
4197   #})
4198
4199 inst =
4200 #(define-music-function
4201      (parser location string)
4202      (string?)
4203    #{ ^\markup \bold \box #string #})
4204
4205 \layout{
4206   \context {
4207     \Score
4208     \override MetronomeMark #'extra-offset = #'(-9 . 0)
4209     \override MetronomeMark #'padding = #'3
4210   }
4211   \context {
4212     \Staff
4213     \override TimeSignature #'style = #'numbered
4214   }
4215   \context {
4216     \Voice
4217     \override Glissando #'thickness = #3
4218     \override Glissando #'gap = #0.1
4219   }
4220 }
4221
4222 \relative c'' {
4223   \tempo 4=50
4224   a4.\mpdolce d8 cis4--\glissando a |
4225   b4 bes a2 |
4226   \inst "Clarinet"
4227   cis4.\< d8 e4 fis |
4228   g8(\! fis)-. e( d)-. cis2 |
4229 }
4230 @end lilypond
4231
4232 Das sieht besser aus!  Aber nehmen wir an, Ich will dieses Stück publizieren.
4233 Mein Professor mag die @qq{C}-Taktangabe nicht, mir gefällt sie aber sehr
4234 gut.  Kopieren wir also die Datei @file{definitions.ily} nach
4235 @file{web-publish.ily} und verändern diese.  Weil die Noten als PDF
4236 auf dem Monitor dargestellt werden sollen, wird auch die Notengröße
4237 global geändert.
4238
4239 @example
4240 %%%  definitions.ily
4241 mpdolce =
4242 #(make-dynamic-script
4243   #@{ \markup @{ \hspace #0
4244                \translate #'(5 . 0)
4245                \line @{ \dynamic "mp"
4246                        \text \italic "dolce" @} @}
4247   #@})
4248
4249 inst =
4250 #(define-music-function
4251      (parser location string)
4252      (string?)
4253    #@{ ^\markup \bold \box #string #@})
4254
4255 #(set-global-staff-size 23)
4256
4257 \layout@{
4258   \context @{
4259     \Score
4260     \override MetronomeMark #'extra-offset = #'(-9 . 0)
4261     \override MetronomeMark #'padding = #'3
4262   @}
4263   \context @{
4264     \Staff
4265   @}
4266   \context @{
4267     \Voice
4268     \override Glissando #'thickness = #3
4269     \override Glissando #'gap = #0.1
4270   @}
4271 @}
4272 @end example
4273
4274 @lilypond[quote,ragged-right]
4275 mpdolce =
4276 #(make-dynamic-script
4277   #{ \markup { \hspace #0
4278                \translate #'(5 . 0)
4279                \line { \dynamic "mp"
4280                        \text \italic "dolce" } }
4281   #})
4282
4283 inst =
4284 #(define-music-function
4285      (parser location string)
4286      (string?)
4287    #{ ^\markup \bold \box #string #})
4288
4289 #(set-global-staff-size 23)
4290
4291 \layout{
4292   \context { \Score
4293     \override MetronomeMark #'extra-offset = #'(-9 . 0)
4294     \override MetronomeMark #'padding = #'3
4295   }
4296   \context { \Voice
4297     \override Glissando #'thickness = #3
4298     \override Glissando #'gap = #0.1
4299   }
4300 }
4301
4302 \relative c'' {
4303   \tempo 4=50
4304   a4.\mpdolce d8 cis4--\glissando a |
4305   b4 bes a2 |
4306   \inst "Clarinet"
4307   cis4.\< d8 e4 fis |
4308   g8(\! fis)-. e( d)-. cis2 |
4309 }
4310 @end lilypond
4311
4312 In der Eingabedatei muss jetzt nur noch die Zeile
4313 @code{\include "definitions.ily"} mit
4314 @code{\include "web-publish.ily"} ersetzt werden.  Das könnte
4315 man natürlich noch besser machen.  Es könnte eine Datei
4316 @file{definitions.ily} mit allen Definitionen (also
4317 @code{mpdolce} und @code{inst}) geben, eine Datei
4318 @file{web-publish.ily}, die nur die @code{\layout}-Veränderung
4319 enthält und eine Datei @file{university.ily}, die nur die
4320 Prozedur enthält, die Ausgabe meinem Professor angenehm zu  machen.
4321 Der Anfang von @file{music.ly} würde dann folgendermaßen aussehen:
4322
4323 @example
4324 \include "definitions.ily"
4325
4326 %%%  nur eine der zwei Zeilen auskommentieren!
4327 \include "web-publish.ily"
4328 %\include "university.ily"
4329 @end example
4330
4331 Diese Herangehensweise kann auch schon nützlich sein, wenn man
4332 nur ein paar Stimmen schreiben will.  Ich habe eine ganze Anzahl
4333 an @qq{Stylesheets} für meine Projekte.  Ich fange jede Datei mit
4334 der Zeile @code{\include "../global.ily"} an, die etwa folgendes
4335 einbindet:
4336
4337 @example
4338 %%%   global.ily
4339 \version @w{"@version{}"}
4340
4341 #(ly:set-option 'point-and-click #f)
4342
4343 \include "../init/init-defs.ly"
4344 \include "../init/init-layout.ly"
4345 \include "../init/init-headers.ly"
4346 \include "../init/init-paper.ly"
4347 @end example
4348
4349
4350
4351 @node Mehr Information
4352 @subsection Mehr Information
4353 @translationof Other sources of information
4354
4355 Die Programmreferenz enthält sehr viel Information über LilyPond, aber
4356 noch mehr Information findet sich in den internen
4357 LilyPond-Dateien.  Um sie erforschen zu können, müssen Sie erst
4358 das richtige Verzeichnis auf Ihrem System finden.  Die Position
4359 hängt a) davon ab, ob Ihre LilyPond-Installation mit der vorkompilierten
4360 Version von der LilyPond-Internetseite vorgenommen wurde oder Sie
4361 die Version durch Ihren Paketmanager installiert haben (also
4362 z. B. in einer Linux-Distribution oder unter fink oder cygwin
4363 installiert), und b) auf welchem Betriebssystem Sie das Programm
4364 benutzen:
4365
4366 @strong{Von lilypond.org heruntergeladen}
4367
4368 @itemize @bullet
4369 @item Linux
4370
4371 Wechseln Sie in das Verzeichnis
4372 @example
4373 @file{@var{INSTALL_VERZ}/lilypond/usr/@/share/lilypond/current/}
4374 @end example
4375
4376 @item MacOS X
4377
4378 Wechseln Sie in das Verzeichnis
4379 @example
4380 @file{@var{INSTALL_VERZ}/LilyPond.app/Contents/@/Resources/share/lilypond/current/}
4381 @end example
4382
4383 indem Sie entweder mit dem Befehl @code{cd} vom Terminal aus
4384 in das Verzeichnis wechseln, oder mit Control-Klick auf das
4385 LilyPond-Programmsymbol gehen und @qq{Show Package Contents}
4386 auswählen.
4387
4388 @item Windows
4389
4390 Wechseln Sie mit dem Windows Explorer ins Verzeichnis
4391 @example
4392 @file{@var{INSTALL_VERZ}/LilyPond/usr/@/share/lilypond/current/}
4393 @end example
4394
4395 @end itemize
4396
4397 @strong{Mit einem Paket-Manager installiert oder selber aus
4398 den Quellen kompiliert}
4399
4400 Wechseln Sie in das Verzeichnis
4401 @file{@var{PREFIX}/share/lilypond/@var{X.Y.Z}/}, wobei
4402 @var{PREFIX} bei Ihrem Paket-Manager oder dem
4403 @code{configure}-Skript gesetzt wird, und @var{X.Y.Z}
4404 die LilyPond-Versionsnummer.
4405
4406 @smallspace
4407
4408 In diesem Ordner sind die zwei interessanten Unterordner:
4409
4410 @itemize
4411 @item @file{ly/} - beinhaltet Dateien im LilyPond-Format
4412 @item @file{scm/} - beinhaltet Dateien im Scheme-Format
4413 @end itemize
4414
4415 Schauen wir uns zuerst einige Dateien in @file{ly/} an.
4416 Öffnen Sie @file{ly/property-init.ly} in einem Texteditor.
4417 Der, den Sie normalerweise für @file{.ly}-Dateien benutzen,
4418 genügt.  Diese Datei enthält die Definitionen aller vordefinierten
4419 Befehle für LilyPond, wie etwa @code{\stemUp} und
4420 @code{\slurDotted}.  Sie können sehen, dass es sich um
4421 nichts mehr handelt als Definitionen von Variablen, die eine
4422 oder mehrere @code{\override}-Befehle enthalten.  Der
4423 Befehl @code{/tieDotted} etwa wird folgendermaßen definiert:
4424
4425 @example
4426 tieDotted = @{
4427   \override Tie #'dash-period = #0.75
4428   \override Tie #'dash-fraction = #0.1
4429 @}
4430 @end example
4431
4432 Wenn Sie diese Voreinstellungen der vordefinierten Befehl nicht
4433 mögen, können Sie sie ganz einfach umdefinieren, genauso wie
4434 jede andere Variable auch, indem Sie sie an den Anfang Ihrer
4435 Quelldatei schreiben.
4436
4437 Hier sind die wichtigsten Dateien, die sich im Ordner
4438 @file{ly/} befinden:
4439
4440 @multitable @columnfractions .4 .6
4441 @headitem Dateiname
4442   @tab Inhalt
4443 @item @file{ly/engraver-init.ly}
4444   @tab Definitionen von Engraver-Kontexten
4445 @item @file{ly/paper-defaults-init.ly}
4446   @tab Spezifikationen von Voreinstellungen für Papiermaße
4447 @item @file{ly/performer-init.ly}
4448   @tab Definitionen von Performer-Kontexten
4449 @item @file{ly/property-init.ly}
4450   @tab Definitionen aller vordefinierten Befehle
4451 @item @file{ly/spanner-init.ly}
4452   @tab Definitionen aller vordefinierten Strecker-Befehle
4453 @end multitable
4454
4455 Andere Einstellungen (wie die Definitionen von Beschriftungsbefehlen)
4456 sind in @file{.scm}-(Scheme)-Dateien gespeichert.  Die
4457 Scheme-Programmiersprache wird benutzt, um eine
4458 programmierbare Schnittstelle zu den internen Operationen von
4459 LilyPond zu haben.  Eine weitere Erklärung dieser Dateien ist
4460 im Moment außerhalb des Rahmens dieses Handbuchs, denn
4461 sie erfordern einige Kenntnis der Scheme-Sprache.  Die Warnung
4462 ist hier angebracht, dass des ein gutes technisches Verständnis
4463 oder sehr viel Zeit braucht, um Scheme und diese
4464 Dateien zu verstehen (siehe auch @rextend{Scheme-Übung}).
4465
4466 Wenn Sie sich mit Scheme auskennen, sind hier mögliche
4467 interessante Dateien:
4468
4469 @multitable @columnfractions .4 .6
4470 @headitem Dateiname
4471   @tab Inhalt
4472 @item @file{scm/auto-beam.scm}
4473   @tab Sub-Balken-Voreinstellungen
4474 @item @file{scm/define-grobs.scm}
4475   @tab Voreinstellungen für Grob-Eigenschaften
4476 @item @file{scm/define-markup-commands.scm}
4477   @tab Definition aller Markup-Beschriftungsbefehle
4478 @item @file{scm/midi.scm}
4479   @tab Voreinstellung für die MIDI-Ausgabe
4480 @item @file{scm/output-lib.scm}
4481   @tab Einstellungen mit Einfluss auf die Darstellung von Bunddiagrammen, Farben, Versetzungszeichen, Taktlinien usw.
4482 @item @file{scm/parser-clef.scm}
4483   @tab Definitionen der unterstützten Schlüssel
4484 @item @file{scm/script.scm}
4485   @tab Voreinstellungen für Artikulationszeichen
4486 @end multitable
4487
4488
4489 @node Fortgeschrittene Optimierungen mit Scheme
4490 @subsection Fortgeschrittene Optimierungen mit Scheme
4491 @translationof Advanced tweaks with Scheme
4492
4493 Auch wenn viele Sachen mit @code{\override} und @code{\tweak}
4494 möglich sind, gibt es eine sehr viel mächtigere Möglichkeit, die
4495 Arbeitsweise von LilyPond mit Hilfe der programmierbaren Schnittstelle
4496 zu beeinflussen.  Code, der in der Scheme-Programmiersprache
4497 geschrieben ist, kann direkt in die interne Satzmaschine von LilyPond
4498 eingefügt werden.  Natürlich brauchen Sie dazu wenigstens ein
4499 grundlegendes Verständnis von Scheme.  Eine Einleitung finden
4500 Sie in der @rextend{Scheme-Übung}.
4501
4502 Zur Illustration der vielen Möglichkeiten soll gezeigt werden, dass eine
4503 Eigenschaft nicht nur auf eine Konstante, sondern auch auf eine
4504 Scheme-Prozedur gesetzt werden kann, die dann jedes Mal
4505 aufgerufen wird, wenn die Eigenschaft von LilyPond benutzt
4506 wird.  Die Eigenschaft kann damit dynamisch auf einen Wert
4507 gesetzt werden, der durch die Prozedur jedes Mal neu bestimmt
4508 wird.  In diesem Beispiel wird die Farbe der Notenköpfe entsprechend
4509 zu ihrer Position innerhalb der Tonleiter gesetzt.
4510
4511 @cindex x11-Farben, Beispiel zur Benutzung
4512 @cindex Notenkopf, Beispiel zur Veränderung
4513 @cindex Farb-Eigenschaft, in Scheme-Prozedur gesetzt
4514
4515 @lilypond[quote,verbatim,ragged-right]
4516 #(define (color-notehead grob)
4517    "Color the notehead according to its position on the staff."
4518    (let ((mod-position (modulo (ly:grob-property grob 'staff-position)
4519                                7)))
4520      (case mod-position
4521        ;;   Return rainbow colors
4522        ((1) (x11-color 'red    ))  ; for C
4523        ((2) (x11-color 'orange ))  ; for D
4524        ((3) (x11-color 'yellow ))  ; for E
4525        ((4) (x11-color 'green  ))  ; for F
4526        ((5) (x11-color 'blue   ))  ; for G
4527        ((6) (x11-color 'purple ))  ; for A
4528        ((0) (x11-color 'violet ))  ; for B
4529        )))
4530
4531 \relative c' {
4532   % Arrange to obtain color from color-notehead procedure
4533   \override NoteHead #'color = #color-notehead
4534   a2 b | c2 d | e2 f | g2 a |
4535 }
4536 @end lilypond
4537
4538 Weiter Beispiele, die die Benutzung dieser programmierbaren
4539 Schnittstelle zeigen, finden sich in @rextend{Optimierungen mit Scheme}.