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