]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/it/learning/tweaks.itely
Rerun scripts/auxiliar/update-with-convert-ly.sh
[lilypond.git] / Documentation / it / learning / tweaks.itely
1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: it -*-
2
3 @ignore
4     Translation of GIT committish: 6d501730d319a6456acd13870821f0bcad64bf4e
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.17.11"
12
13 @node Modifica dell'output
14 @chapter Modifica dell'output
15 @translationof Tweaking output
16
17 Questo capitolo spiega come modificare l'output.  LilyPond è estremamente
18 configurabile; praticamente si può modificare qualsiasi elemento dell'output.
19
20
21 @menu
22 * Modifiche di base::
23 * Manuale del Funzionamento interno::
24 * Aspetto degli oggetti::
25 * Posizionamento degli oggetti::
26 * Collisioni tra oggetti::
27 * Altre modifiche::
28 @end menu
29
30 @node Modifiche di base
31 @section Modifiche di base
32 @translationof Tweaking basics
33
34 @menu
35 * Introduzione alle modifiche::
36 * Oggetti e interfacce::
37 * Convenzioni per i nomi di oggetti e proprietà::
38 * Metodi di modifica::
39 @end menu
40
41 @node Introduzione alle modifiche
42 @subsection Introduzione alle modifiche
43 @translationof Introduction to tweaks
44
45 Nella terminologia di LilyPond un @emph{tweak} (modifica, ritocco) si
46 riferisce ai vari metodi che l'utente ha a disposizione per modificare
47 le azioni intraprese durante l'interpretazione del file di input e per
48 cambiare l'aspetto dell'output.  Alcune modifiche sono molto semplici, altre
49 sono più complesse.  Ma nel loro insieme i metodi disponibili permettono
50 di modificare quasi qualsiasi aspetto della partitura come si desidera.
51
52 In questa sezione vengono trattati i concetti di base necessari per
53 comprendere le modifiche.  Più avanti presenteremo vari comandi già
54 pronti che possono essere semplicemente copiati per ottenere lo stesso
55 effetto nelle proprie partiture; allo stesso tempo mostreremo come
56 costruire questi comandi così da rendere possibile imparare a scrivere
57 le proprie modifiche personali.
58
59 Prima di iniziare questo capitolo si consiglia di rileggere la sezione
60 @ref{Contexts and engravers}, perché i contesti, gli incisori e le proprietà
61 contenute al loro interno sono fondamentali per comprendere e
62 costruire le modifiche.
63
64 @node Oggetti e interfacce
65 @subsection Oggetti e interfacce
66 @translationof Objects and interfaces
67
68 @cindex oggetto
69 @cindex oggetto grafico (grob)
70 @cindex estensore (spanner)
71 @cindex interfaccia
72 @cindex oggetto, proprietà dell'
73 @cindex proprietà dell'oggetto
74 @cindex oggetto di formattazione
75 @cindex formattazione, oggetto di
76
77 I @emph{tweak} implicano la modifica delle operazioni e delle strutture
78 interne del programma LilyPond, dunque per prima cosa bisogna
79 introdurre alcuni termini usati per descriverle.
80
81 Il termine @q{Oggetto} è un termine generico che si riferisce all'insieme
82 di strutture interne create da LilyPond durante l'elaborazione
83 di un file di input.  Quando incontra un comando come @code{\new
84 Staff}, LilyPond crea un nuovo oggetto di tipo @code{Staff} (un rigo).  Questo
85 oggetto @code{Staff} possiede tutte le proprietà associate a
86 quel rigo, come ad esempio il suo nome e la sua armatura di chiave,
87 insieme ai dettagli relativi agli incisori assegnati per operare all'interno
88 del contesto di quel rigo.  Analogalmente, ci sono oggetti che hanno
89 le proprietà di tutti gli altri contesti, come  gli oggetti @code{Voice},
90 gli oggetti @code{Score}, gli oggetti @code{Lyrics} e gli oggetti che
91 rappresentano tutti gli elementi della notazione, come le stanghette,
92 le teste di nota, le legature di valore, i segni di dinamica, etc.  A ogni
93 oggetto corrisponde un relativo insieme di valori di proprietà.
94
95 Alcuni tipi di oggetto hanno dei nomi speciali.  Gli oggetti che rappresentano
96 elementi della notazione visibili nell'output come le teste di nota, i gambi,
97 le legature di portamento e di valore, le diteggiature, le chiavi, etc. sono
98 chiamati «Oggetti di formattazione» (in inglese @emph{Layout Objects}).  Sono
99 chiamati anche «Oggetti grafici» (in inglese @emph{Graphical Objects} o
100 @emph{Grob} per brevità).  Si tratta sempre di oggetti nel senso generico
101 descritto prima e quindi hanno tutti delle proprietà a loro associate, come la
102 posizione, la dimensione, il colore, etc.
103
104 Alcuni oggetti di formattazione sono ancora più specializzati.  Le legature
105 di frase, le forcelle del crescendo, i segni di ottava e molti altri @q{grob}
106 non sono localizzati in un punto preciso -- hanno invece un punto iniziale,
107 un punto finale e talvolta altre proprietà relative alla loro forma.  Gli
108 oggetti che hanno una forma estesa in questo modo vengono chiamati «Estensori»
109 (in inglese @emph{Spanner}).
110
111 Resta da spiegare cosa sono le «Interfacce».  Molti oggetti, pur essendo
112 piuttosto diversi, condividono delle caratteristiche comuni che devono
113 essere elaborate nello stesso modo.  Ad esempio, tutti i @emph{grob} hanno un
114 colore, una dimensione, una posizione, etc.; tutte queste proprietà vengono
115 elaborate nello stesso modo durante l'interpretazione del file di input.  Per
116 semplificare queste operazioni interne, le azioni e proprietà comuni
117 sono riunite in un oggetto chiamato @code{grob-interface}.
118 Esistono molti altri raggruppamenti di proprietà comuni come queste, ognuno
119 con un nome che finisce con @code{interface}.  In totale ci sono più di
120 100 interfacce.  Vedremo in seguito perché questo sia di interesse
121 e di utilità per l'utente.
122
123 Questi sono dunque i termini principali riguardanti gli oggetti che useremo
124 in questo capitolo.
125
126 @node Convenzioni per i nomi di oggetti e proprietà
127 @subsection Convenzioni per i nomi di oggetti e proprietà
128 @translationof Naming conventions of objects and properties
129
130 @cindex convenzioni per i nomi di oggetti
131 @cindex convenzioni per i nomi di proprietà
132 @cindex oggetti, convenzioni per i nomi di
133 @cindex proprietà, convenzioni per i nomi di
134
135 Abbiamo già visto, in @ref{Contexts and engravers}, le convenzioni per i
136 nomi di oggetti.  Ecco una lista dei più comuni tipi di oggetti e
137 proprietà insieme alle convenzioni usate per nominarli e alcuni
138 esempi di nomi reali.  Abbiamo usato @q{A} per indicare un
139 qualsiasi carattere alfabetico maiuscolo e @q{aaa} per indicare un qualsiasi
140 numero di caratteri alfabetici minuscoli.  Gli altri caratteri sono indicati
141 normalmente.
142
143 @multitable @columnfractions .33 .33 .33
144 @headitem Tipo di oggetto/proprietà
145   @tab Convenzione per il nome
146   @tab Esempi
147 @item Contesti
148   @tab Aaaa o AaaaAaaaAaaa
149   @tab Staff, GrandStaff
150 @item Oggetti di formattazione
151   @tab Aaaa o AaaaAaaaAaaa
152   @tab Slur, NoteHead
153 @item Incisori
154   @tab Aaaa_aaa_engraver
155   @tab Clef_engraver, Note_heads_engraver
156 @item Interfacce
157   @tab aaa-aaa-interface
158   @tab grob-interface, break-aligned-interface
159 @item Proprietà del contesto
160   @tab aaa o aaaAaaaAaaa
161   @tab alignAboveContext, skipBars
162 @item Proprietà degli oggetti di formattazione
163   @tab aaa o aaa-aaa-aaa
164   @tab direction, beam-thickness
165 @end multitable
166
167 Come vedremo tra poco, ogni tipo di oggetto richiede un comando diverso
168 per modificare le sue proprietà, dunque è utile poter riconoscere i tipi
169 di oggetti e proprietà dai loro nomi.
170
171
172 @node Metodi di modifica
173 @subsection Metodi di modifica
174 @translationof Tweaking methods
175
176 @cindex metodi di modifica
177 @cindex modifica, metodi
178
179 @strong{Il comando \override}
180
181 @cindex override, comando
182 @cindex override, sintassi
183
184 @funindex \override
185 @funindex override
186
187 Abbiamo già incontrato i comandi @code{\set} e @code{\with}, che servono
188 a modificare le proprietà dei @strong{contesti} e a togliere o aggiungere
189 gli @strong{incisori}, nei paragrafi @ref{Modifying context properties} e
190 @ref{Adding and removing engravers}.  Ora dobbiamo introdurre alcuni
191 comandi più importanti.
192
193 Il comando che cambia le proprietà degli @strong{oggetti di formattazione} è
194 @code{\override}.  Dato che questo comando ha il compito di modificare
195 le caratteristiche interne fondamentali di LilyPond, la sua sintassi non è
196 semplice come quella dei comandi presentati finora.  Deve sapere esattamente
197 quale proprietà di quale oggetto in quale contesto deve essere
198 modificata e quale deve essere il suo nuovo valore.  Vediamo come
199 funziona.
200
201 La sintassi generale di questo comando è:
202
203 @example
204 \override @var{Contesto}.@var{OggettoDiFormattazione}.@var{proprietà-formattazione} = #@var{valore}
205 @end example
206
207 @noindent
208 Questo comando assegnerà alla proprietà chiamata @var{proprietà-formattazione}
209 dell'oggetto di formattazione chiamato @var{OggettoDiFormattazione}, che fa
210 parte del contesto @var{Contesto}, il valore @var{valore}.
211
212 Il @var{Contesto} può essere ommesso (e di solito lo è) quando il
213 contesto richiesto è implicito e si trova a uno dei livelli più
214 bassi dei contesti, come ad esempio @code{Voice}, @code{ChordNames} o
215 @code{Lyrics}.  Lo ometteremo in molti degli esempi seguenti; vedremo
216 poi quando deve essere specificato.
217
218 Le sezioni successive tratteranno in modo dettagliato le proprietà e
219 i loro valori, si veda @ref{Types of properties}; in questa sezione, invece,
220 useremo soltanto alcune proprietà e valori di facile comprensione,
221 in modo da spiegare il formato e l'uso di questo comando.
222
223 Le espressioni fondamentali di LilyPond sono gli elementi musicali come le note,
224 le durate e le annotazioni.  Le espressioni basilari come numeri,
225 stringhe di testo e liste sono elaborate nella @q{modalità Scheme}, che viene
226 invocata inserendo @samp{#} prima del valore.  Sebbene i valori possano
227 avere talvolta una valida rappresentazione nella modalità musicale di LilyPond,
228 per coerenza questo manuale li farà sempre precedere da @samp{#}.  Per maggiori
229 informazioni sulla modalità Scheme, si veda @rextend{LilyPond Scheme syntax}.
230
231 @code{\override} è il comando più usato nelle modifiche e quasi tutto
232 il resto del capitolo ha lo scopo di mostrare alcuni esempi
233 di utilizzo.  Ecco un semplice esempio che mostra come cambiare
234 il colore della testa di nota:
235
236 @cindex proprietà del colore, esempio
237 @cindex colore, proprietà del
238 @cindex NoteHead, esempio di sovrascrittura
239
240 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
241 c4 d
242 \override NoteHead.color = #red
243 e4 f |
244 \override NoteHead.color = #green
245 g4 a b c |
246 @end lilypond
247
248 @strong{Il comando \revert}
249
250 @cindex ripristino (revert), comando
251
252 @funindex \revert
253 @funindex revert
254
255 Quando viene sovrascritta, la proprietà mantiene il suo nuovo valore finché
256 non viene sovrascritta di nuovo o non si incontra un comando @code{\revert}.
257 Il comando @code{\revert} fa sì che il valore della proprietà sia ripristinato
258 al suo valore predefinito.  Attenzione: non al suo valore precedente (nel caso
259 siano stati inseriti vari comandi @code{\override}).  Impiega la seguente sintassi:
260
261 @example
262 \revert @var{Contesto}.@var{OggettoDiFormmattazione}.@var{proprietà-formattazione}
263 @end example
264
265 Anche in questo caso, come per il comando @code{\override}, @var{Contesto} di
266 solito non è necessario e verrà omesso in molti degli esempi seguenti.
267 In questo esempio ripristiniamo il colore della testa delle ultime due
268 note al valore predefinito:
269
270 @cindex proprietà del colore, esempio
271 @cindex colore, proprietà del
272 @cindex NoteHead, esempio di sovrascrittura
273
274 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
275 c4 d
276 \override NoteHead.color = #red
277 e4 f |
278 \override NoteHead.color = #green
279 g4 a
280 \revert NoteHead.color
281 b4 c |
282 @end lilypond
283
284 @strong{Il prefisso \once}
285
286 @funindex \once
287 @funindex once
288
289 Sia il comando @code{\override} che il comando @code{\set} possono essere
290 preceduti da @code{\once}.  Questo fa sì che il successivo comando @code{\override}
291 o @code{\set} sia effettivo solo in relazione a quel determinato momento musicale,
292 prima che la proprietà sia ripristinata al suo valore precedente (che può essere diverso da quello predefinito se un altro @code{\override} è
293 ancora attivo).  Usando lo stesso esempio, possiamo cambiare il colore di
294 una singola nota in questo modo:
295
296 @cindex proprietà del colore, esempio
297 @cindex colore, proprietà del
298 @cindex NoteHead, esempio di sovrascrittura
299
300 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
301 c4 d
302 \override NoteHead.color = #red
303 e4 f |
304 \once \override NoteHead.color = #green
305 g4 a
306 \revert NoteHead.color
307 b c |
308 @end lilypond
309
310 @strong{Il comando \overrideProperty}
311
312 @cindex overrideProperty, comando
313
314 @funindex \overrideProperty
315 @funindex overrideProperty
316
317 Esiste un'altra forma di comando di sovrascrittura,
318 @code{\overrideProperty}, che si rende necessario raramente.
319 Lo menzioniamo qui per completezza, ma per approfondire l'argomento
320 si veda @rextend{Difficult tweaks}.
321 @c Maybe explain in a later iteration  -td
322
323 @strong{Il comando \tweak}
324
325 @cindex tweak, comando
326
327 @funindex \tweak
328 @funindex tweak
329
330 L'ultimo comando di modifica a disposizione è @code{\tweak}.  Si usa
331 quando vari oggetti compaiono nello stesso momento musicale,
332 ma si vogliono modificare soltanto le proprietà di alcuni oggetti, come
333 ad esempio una singola nota all'interno di un accordo.  Se si usa @code{\override}
334 la modifica ha effetto su tutte le note di un accordo, mentre @code{\tweak} ha
335 effetto solo sul singolo elemento che segue.
336
337 Per esempio, supponiamo di voler modificare la dimensione della
338 testa della nota centrale (il Mi) in un accordo di Do maggiore.  Vediamo prima
339 cosa succede se si usa @code{\once \override}:
340
341 @cindex proprietà font-size, esempio
342 @cindex font-size, esempio
343 @cindex NoteHead, esempio di sovrascrittura
344
345 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
346 <c e g>4
347 \once \override NoteHead.font-size = #-3
348 <c e g>4
349 <c e g>4
350 @end lilypond
351
352 Come si vede, la sovrascrittura riguarda @emph{tutte} le teste di nota
353 dell'accordo.  Ciò è dovuto al fatto che tutte le note di un accordo
354 si trovano nello stesso @emph{momento musicale} e l'azione di @code{\once}
355 consiste nell'applicare la sovrascrittura a tutti gli oggetti di formattazione
356 del tipo specificato che si trovano nello stesso momento musicale del comando
357 @code{\override} stesso.
358
359 Il comando @code{\tweak} funziona in modo diverso.  Agisce sull'elemento
360 immediatamente successivo nel flusso di codice.  Nella sua forma più
361 semplice funziona solo sugli oggetti creati direttamente dall'elemento
362 seguente, in particolare teste di nota e articolazioni.
363
364 Tornando al nostro esempio, la dimensione della nota centrale
365 di un accordo si cambia in questo modo:
366
367 @cindex proprietà font-size, esempio
368 @cindex font-size, esempio
369 @cindex @code{\tweak}, esempio
370
371 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
372 <c e g>4
373 <c \tweak font-size #-3 e g>4
374 @end lilypond
375
376 Si noti che la sintassi di @code{\tweak} è diversa da quella di
377 @code{\override}.  Il contesto non deve essere specificato; anzi,
378 se lo fosse verrebbe generato un errore.  Sia il contesto che l'oggetto
379 di formattazione sono sottintesi dall'elemento che segue nel flusso di
380 input.  Nota anche che non ci devono essere segni di uguale (@code{=}).  Dunque la
381 forma semplice del comando @code{\tweak} è
382
383 @example
384 \tweak @var{proprietà-formattazione} #@var{valore}
385 @end example
386
387 Il comando @code{\tweak} serve anche a modificare soltanto una di una serie
388 di articolazioni:
389
390 @cindex proprietà del colore, esempio
391 @cindex colore, proprietà del
392 @cindex @code{\tweak}, esempio
393
394 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
395 a4^"Black"
396   -\tweak color #red ^"Red"
397   -\tweak color #green _"Green"
398 @end lilypond
399
400 @noindent
401 Nota che il comando @code{\tweak} deve essere preceduto da un segno di
402 articolazione, perché la stessa espressione modificata deve essere applicata come articolazione.  In caso di più sovrascritture della
403 direzione (@code{^} o @code{_}), prevale la sovrascrittura posizionata più a sinistra,
404 perché viene applicata per ultima.
405
406 @cindex @code{\tweak}, alterazione
407 @cindex @code{\tweak}, oggetto di formattazione specifico
408
409 Alcuni oggetti, come gambi e alterazioni, vengono creati dopo, non
410 direttamente dall'evento che segue.  È comunque possibile usare
411 @code{\tweak} con questi oggetti creati indirettamente se si indica
412 esplicitamente l'oggetto di formattazione, purché LilyPond riesca a
413 seguire la sua origine fino all'evento originale:
414
415 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
416 <\tweak Accidental.color #red   cis4
417  \tweak Accidental.color #green es
418                                   g>
419 @end lilypond
420
421 Questa forma estesa del comando @code{\tweak} può essere descritta così
422 @example
423 \tweak @var{oggetto-formattazione}.@var{proprietà-formattazione} @var{valore}
424 @end example
425
426 @cindex gruppi irregolari, annidati
427 @cindex terzine, annidate
428 @cindex parentesi, gruppo irregolare
429 @cindex parentesi, terzina
430 @cindex parentesi del gruppo irregolare
431 @cindex parentesi della terzina
432
433 @funindex TupletBracket
434
435 Il comando @code{\tweak} è necessario anche quando si vuole cambiare
436 l'aspetto di uno di una serie di gruppi irregolari annidati che iniziano
437 nello stesso momento musicale.  Nell'esempio seguente, la prima lunga
438 parentesi del gruppo irregolare e la prima delle tre brevi parentesi
439 iniziano nello stesso momento musicale, quindi qualsiasi comando
440 @code{\override} produrrebbe degli effetti su entrambi.  In questo esempio,
441 si usa @code{\tweak} per distinguerli.  Il primo comando @code{\tweak}
442 indica che la lunga parentesi del gruppo irregolare deve essere posizionata
443 sopra le note e il secondo indica che il numero del primo gruppo irregolare
444 deve essere in rosso.
445
446 @cindex @code{\tweak}, esempio
447 @cindex proprietà della direzione, esempio
448 @cindex direzione, esempio
449 @cindex proprietà del colore, esempio
450 @cindex colore, esempio
451
452 @lilypond[quote,ragged-right,verbatim,fragment,relative=2]
453 \tweak direction #up
454 \tuplet 3/4 {
455   \tweak color #red
456   \tuplet 3/2 { c8[ c c] }
457   \tuplet 3/2 { c8[ c c] }
458   \tuplet 3/2 { c8[ c c] }
459 }
460 @end lilypond
461
462 Se i gruppi irregolari annidati non iniziano nello stesso momento, il loro
463 aspetto può essere modificato come di consueto con i comandi @code{\override}:
464
465 @cindex proprietà text, esempio
466 @cindex text, esempio
467 @cindex funzione tuplet-number, esempio
468 @cindex proprietà transparent, esempio
469 @cindex transparent, esempio
470 @cindex TupletNumber, esempio di sovrascrittura
471
472 @c NOTE Tuplet brackets collide if notes are high on staff
473 @c See issue 509
474 @lilypond[quote,ragged-right,verbatim,fragment,relative=1]
475 \tuplet 3/2 { c8[ c c] }
476 \once \override TupletNumber.text = #tuplet-number::calc-fraction-text
477 \tuplet 3/2 {
478   c8[ c]
479   c8[ c]
480   \once \override TupletNumber.transparent = ##t
481   \tuplet 3/2 { c8[ c c] }
482   \tuplet 3/2 { c8[ c c] }
483 }
484 @end lilypond
485
486
487 @seealso
488 Guida alla Notazione:
489 @ruser{The tweak command}.
490
491
492 @node Manuale del Funzionamento interno
493 @section Manuale del Funzionamento interno
494 @translationof The Internals Reference manual
495
496 @cindex Guida al Funzionamento interno
497
498 @menu
499 * Proprietà degli oggetti di formattazione::
500 * Proprietà presenti nelle interfacce::
501 * Tipi di proprietà::
502 @end menu
503
504 @node Proprietà degli oggetti di formattazione
505 @subsection Proprietà degli oggetti di formattazione
506 @translationof Properties of layout objects
507
508 @cindex proprietà degli oggetti di formattazione
509 @cindex proprietà degli oggetti grafici (grob)
510 @cindex ogggetti grafici, proprietà degli
511 @cindex oggetti di formattazione, proprietà degli
512 @cindex manuale del Funzionamento Interno
513
514 Immagina di avere una legatura di portamento che ai tuoi
515 occhi appare troppo sottile e che vorresti un po' più spessa.
516 Come fare?  Sai che LilyPond è molto flessibile e che quindi
517 dovrebbe essere possibile farlo; e probabilmente immagini
518 che sia necessario un comando @code{\override}.  Ma esiste una
519 proprietà che controlla lo spessore di una legatura? E se esiste
520 come può essere modificata?  Qui entra in gioco il manuale del Funzionamento
521 Interno, che contiene tutte le informazioni necessarie per costruire
522 tutti i comandi @code{\override}.
523
524 Prima di dare un'occhiata alla guida al Funzionamento Interno, vogliamo
525 avvisarti: si tratta di un documento di @strong{riferimento}, che significa
526 che ci sono poche o nessune spiegazioni al suo interno, dato che il suo
527 scopo è presentare le informazioni in modo preciso e conciso.  Dunque potrà
528 sembrare scoraggiante al primo impatto.  Ma non ti preoccupare!  I consigli
529 e le spiegazioni presentate qui, insieme a un po' di pratica, ti permetteranno
530 di estrarre da solo da quella guida le informazioni che cerchi.
531
532 @cindex esempio di sovrascrittura
533 @cindex sovrascrittura, esempio
534 @cindex Guida al Funzionamento Interno, esempio d'uso
535 @cindex @code{\addlyrics}, esempio
536
537 Partiamo da un esempio concreto, un semplice frammento di musica:
538
539 @c Mozart, Die Zauberflöte Nr.7 Duett
540
541 @lilypond[quote,verbatim,relative=2]
542 {
543   \key es \major
544   \time 6/8
545   {
546     r4 bes8 bes[( g]) g |
547     g8[( es]) es d[( f]) as |
548     as8 g
549   }
550   \addlyrics {
551     The man who | feels love's sweet e -- | mo -- tion
552   }
553 }
554 @end lilypond
555
556 Supponiamo ora che si vogliano rendere un po' più spesse le
557 legature di portamento.  È possibile?  La legatura di portamento
558 è certamente un oggetto di formattazione, dunque la domanda è: @q{Esiste una
559 proprietà che appartiene a una legatura di portamento in grado di controllare
560 lo spessore?}  Per rispondere a questa domanda dobbiamo guardare
561 nella guida al Funzionamento interno.
562
563 Puoi trovare la guida nella versione di LilyPond che stai usando
564 sul sito di LilyPond: @uref{http://lilypond.org}.  Vai alla
565 pagina della documentazione e clicca sul link alla guida del Funzionamento
566 interno.  Per poter seguire questo manuale dovresti usare la versione HTML standard,
567 non quella in un'unica grande pagina né il PDF.  Nei prossimi paragrafi ti
568 servirà per seguire gli esempi che faremo.
569
570 Sotto il titolo vedrai cinque link.  Seleziona il
571 link al @strong{Backend}, dove si trovano le informazioni
572 sugli oggetti di formattazione (@emph{layout objects}).  Poi sotto il titolo
573 @emph{Backend}, seleziona il link a @strong{All layout objects}.
574 La pagina che compare elenca tutti gli oggetti di formattazione usati
575 nella tua versione di LilyPond, in ordine alfabetico.  Seleziona il link a
576 Slur (legatura di portamento) e verranno elencate le sue proprietà.
577
578 Si può trovare questa pagina anche dalla Guida alla notazione.  In una
579 delle pagine che tratta le legature di portamento potrai trovare un
580 link alla Guida al funzionamento interno.  Il link ti porterà direttamente
581 a questa pagina, ma se hai un'idea di quale sia l'oggetto di formattazione
582 da modificare, è più semplice andare direttamente nella guida del Funzionamento
583 interno e cercare lì.
584
585 La pagina sulla legatura di portamento (@emph{Slur}) ci dice per prima cosa che gli
586 oggetti Slur sono creati dall'incisore Slur_engraver.  Poi elenca le impostazioni
587 standard.  Scorrile cercando la proprietà che potrebbe controllare lo spessore
588 delle legature di portamento; dovresti trovare
589
590 @example
591 @code{thickness} (number)
592      @code{1.2}
593      Line thickness, generally measured in @code{line-thickness}
594 @end example
595
596 Sembra che sia quel che stiamo cercando.  Ci dice che il valore
597 di @code{thickness} (spessore) è un semplice @emph{numero},
598 che il valore predefinito è 1.2 e che le unità si trovano in
599 un'altra proprietà chiamata @code{line-thickness}.
600
601 Come abbiamo detto prima, ci sono poche spiegazioni nella guida al
602 Funzionamento interno, tuttavia abbiamo già informazioni sufficienti
603 per cercare di cambiare lo spessore delle legature di portamento.
604 Vediamo che il nome dell'oggetto di formattazione è @code{Slur}, che
605 il nome della proprietà da modificare è @code{thickness} e che il
606 nuovo valore dovrà essere un numero un po' più grande di 1.2
607 se vogliamo rendere più spesse le legature.
608
609 Ora possiamo costruire il comando @code{\override} sostituendo
610 i valori che abbiamo trovato per i nomi e omettendo il
611 contesto.  Inizialmente usiamo un valore molto grande per lo
612 spessore, per essere sicuri che il comando funzioni:
613
614 @example
615 \override Slur.thickness = #5.0
616 @end example
617
618 Non dimenticare il@tie{}@code{#} che precede il nuovo valore!
619
620 L'ultima domanda è: @q{dove va messo questo comando?}  Finché non sei sicuro
621 e stai ancora imparando, la risposta migliore è: @q{dentro la musica, prima della
622 prima legatura di portamento e accanto ad essa.}  Facciamolo:
623
624 @cindex legatura di portamento, esempio di sovrascrittura
625 @cindex proprietà thickness, esempio
626 @cindex thickness (spessore), esempio
627
628 @lilypond[quote,verbatim,relative=2]
629 {
630   \key es \major
631   \time 6/8
632   {
633     % Increase thickness of all following slurs from 1.2 to 5.0
634     \override Slur.thickness = #5.0
635     r4 bes8 bes[( g]) g |
636     g8[( es]) es d[( f]) as |
637     as8 g
638   }
639   \addlyrics {
640     The man who | feels love's sweet e -- | mo -- tion
641   }
642 }
643 @end lilypond
644
645 @noindent
646 e vediamo che la legatura di portamento è davvero più grossa.
647
648 Questi sono i fondamenti per costruire i comandi @code{\override}.  Incontreremo
649 delle situazioni più complesse nelle sezioni successive, ma ora possiedi già
650 tutte le conoscenze di base che ti permetteranno di costruire i tuoi comandi.
651 Ti manca solo un po' di pratica, che potrai fare grazie ai prossimi esempi.
652
653 @subheading Trovare il contesto
654
655 @cindex contesto, trovare il
656 @cindex contesto, identificare il corretto
657
658 E se avessimo bisogno di specificare il contesto?
659 Quale dovrebbe essere?  Potremmo immaginare che le legature
660 di portamento si trovino nel contesto Voice, dato che sono ovviamente
661 collegate strettamente alle singole voci, ma possiamo
662 esserne sicuri?  Per scoprirlo, vai in cima alla pagina del Funzionamento
663 Interno relativa a «Slur», dove dice @q{Slur objects are created by: Slur
664 engraver}.  Significa che le legature di portamento sono create nel contesto
665 in cui si trova l'incisore @code{Slur_engraver}.  Segui il link alla pagina
666 @code{Slur_engraver}.  In fondo dice che lo @code{Slur_engraver} fa parte di
667 vari contesti Voice, incluso il contesto standard della voce, @code{Voice}.
668 Dunque la nostra supposizione era corretta.  E dato che @code{Voice} è uno dei
669 contesti che si trovano al livello più basso, come è sottinteso senza ambiguità
670 dal fatto che stiamo inserendo delle note, in questo caso possiamo ometterlo.
671
672 @subheading Sovrascrivere una volta sola
673
674 @cindex sovrascrivere una volta sola
675 @cindex \once \override
676
677 @funindex \once
678 @funindex once
679
680 Come puoi vedere, @emph{tutte} le legature di portamento sono più spesse nell'ultimo
681 esempio.  E se volessimo rendere più spessa solo la prima legatura di portamento?
682 Dovremmo usare il comando @code{\once}.  Se posto immediatamente prima
683 di @code{\override} fa sì che questo modifichi soltanto la legatura di portamento
684 che inizia sulla nota @strong{immediatamente seguente}.  Se la nota immediatamente
685 seguente non inizia la legatura, il comando non ha alcun effetto -- non è
686 ricordato finché non si incontra una legatura di portamento, ma
687 viene direttamente scartato.  Quindi il comando con @code{\once} deve essere riposizionato
688 nel modo seguente:
689
690 @cindex Slur, esempio di sovrascrittura
691 @cindex proprietà thickness, esempio
692 @cindex thickness (spessore), esempio
693
694 @lilypond[quote,verbatim,relative=2]
695 {
696   \key es \major
697   \time 6/8
698   {
699     r4 bes8
700     % Aumenta lo spessore solo della legatura che segue
701     \once \override Slur.thickness = #5.0
702     bes8[( g]) g |
703     g8[( es]) es d[( f]) as |
704     as8 g
705   }
706   \addlyrics {
707     The man who | feels love's sweet e -- | mo -- tion
708   }
709 }
710 @end lilypond
711
712 @noindent
713 Ora solo la prima legatura è più spessa.
714
715 Il comando @code{\once} può essere usato anche prima del comando @code{\set}.
716
717 @subheading Ripristinare
718
719 @cindex revert
720 @cindex ripristinare le proprietà predefinite
721 @cindex proprietà predefinite, ripristinare le
722
723 @funindex \revert
724 @funindex revert
725
726 E se volessimo che soltanto le prime due legature di portamento fossero
727 più spesse?  Potremmo usare due comandi, ciascuno preceduto da
728 @code{\once}, messo immediatamente prima di ognuna delle note da cui
729 iniziano le legature:
730
731 @cindex Slur, esempio di sovrascrittura
732 @cindex proprietà thickness, esempio
733 @cindex thickness (spessore), esempio
734
735 @lilypond[quote,verbatim,relative=2]
736 {
737   \key es \major
738   \time 6/8
739   {
740     r4 bes8
741     % Aumenta lo spessore solo della legatura che segue
742     \once \override Slur.thickness = #5.0
743     bes[( g]) g |
744     % Aumenta lo spessore solo della legatura che segue
745     \once \override Slur.thickness = #5.0
746     g8[( es]) es d[( f]) as |
747     as8 g
748   }
749   \addlyrics {
750     The man who | feels love's sweet e -- | mo -- tion
751   }
752 }
753 @end lilypond
754
755 @noindent
756 oppure potremmo omettere il comando @code{\once} e usare il comando @code{\revert}
757 per far sì che la proprietà @code{thickness} ritorni al valore predefinito
758 dopo la seconda legatura:
759
760 @cindex Slur, esempio di sovrascrittura
761 @cindex proprietà thickness, esempio
762 @cindex thickness (spessore), esempio
763
764 @lilypond[quote,verbatim,relative=2]
765 {
766   \key es \major
767   \time 6/8
768   {
769     r4 bes8
770     % Aumenta lo spessore di tutte le legature di portamento che seguono da 1.2 a 5.0
771     \override Slur.thickness = #5.0
772     bes[( g]) g |
773     g8[( es]) es
774     % Ripristina lo spessore di tutte le legature di portamento che seguono al valore predefinito 1.2
775     \revert Slur.thickness
776     d8[( f]) as |
777     as8 g
778   }
779   \addlyrics {
780     The man who | feels love's sweet e -- | mo -- tion
781   }
782 }
783 @end lilypond
784
785 @noindent
786 Il comando @code{\revert} serve a riportare qualsiasi proprietà
787 modificata con @code{\override} al suo valore predefinito.
788 Puoi usare qualsiasi metodo si adatti meglio a quello che vuoi fare.
789
790 Si conclude l'introduzione alla guida al Funzionamento interno e ai metodi
791 di base delle modifiche.  Nelle sezioni successive di questo capitolo
792 seguiranno vari esempi, in parte per presentarti ulteriori caratteristiche
793 della guida al Funzionamento interno e in parte per farti esercitare
794 nell'estrarre informazioni da esso.  Questi esempi conterranno sempre meno
795 consigli e spiegazioni.
796
797
798 @node Proprietà presenti nelle interfacce
799 @subsection Proprietà presenti nelle interfacce
800 @translationof Properties found in interfaces
801
802 @cindex interfaccia
803 @cindex proprietà dell'interfaccia
804 @cindex proprietà nelle interfacce
805
806 Supponiamo ora di voler produrre un testo vocale in corsivo.  Che tipo di
807 comando @code{\override} ci serve?  Consultiamo prima la pagina
808 della guida al Funzionamento interno che elenca @q{All layout objects}, come
809 prima, e cerchiamo un oggetto che potrebbe controllare il testo (in inglese
810 @emph{lyrics}).  Troviamo @code{LyricText}, che sembra quello giusto.  Clicchiamo
811 su di esso e troviamo le proprietà del testo.  Queste comprendono @code{font-series}
812 e @code{font-size}, ma niente che possa dare una forma corsiva.  Ciò è dovuto
813 al fatto che la proprietà della forma è comune a tutti gli oggetti di tipi
814 di carattere (@emph{font}).  Quindi, invece di includerla in ogni oggetto di
815 formattazione, viene raggruppata insieme ad altre simili proprietà comuni
816 e inserita in un'@strong{Interfaccia}: @code{font-interface}.
817
818 Ora dobbiamo capire come trovare le proprietà delle interfacce e
819 come scoprire quali oggetti usano queste proprietà.
820
821 Torna a vedere la pagina che descrive LyricText.  In fondo alla
822 pagina c'è una lista di interfacce cliccabili supportate da LyricText.
823 La lista ha molti elementi, incluso @code{font-interface}.  Cliccando
824 su di essa arriviamo alle proprietà associate con questa interfaccia, che
825 sono anche le proprietà di tutti gli oggetti che la supportano, tra cui
826 LyricText.
827
828 Vediamo tutte le proprietà configurabili dall'utente che controllano i
829 tipi di carattere, compresa @code{font-shape(symbol)}, dove @code{symbol} può
830 essere impostato su @code{upright}, @code{italic} o @code{caps}.
831
832 Puoi notare che lì sono elencate anche @code{font-series} e @code{font-size}.
833 Ti potresti chiedere: perché le proprietà comuni dei tipi di carattere
834 @code{font-series} e @code{font-size} fanno parte sia dell'oggetto
835 @code{LyricText} sia dell'interfaccia @code{font-interface} mentre @code{font-shape}
836 è presente solo nell'interfaccia?  Ciò è dovuto al fatto che i valori globali
837 predefiniti di @code{font-series} e @code{font-size} cambiano quando viene
838 creato un oggetto @code{LyricText}, mentre i valori di @code{font-shape} non
839 cambiano.  Gli elementi in @code{LyricText} indicano quali sono i
840 valori per queste due proprietà che si applicano a @code{LyricText}.  Altri
841 oggetti che supportano @code{font-interface} imposteranno queste proprietà
842 in modo diverso quando vengono creati.
843
844 Vediamo se ora riusciamo a costruire il comando @code{\override}
845 per rendere il testo corsivo.  L'oggetto è @code{LyricText},
846 la proprietà è @code{font-shape} e il valore è
847 @code{italic}.  Come in precedenza, ometteremo il contesto.
848
849 Per inciso, è importante notare che alcune proprietà prendono come valori
850 dei simboli, ad esempio @code{italic}; in questo caso i valori devono essere
851 preceduti da un apostrofo, @code{'}.  I simboli vengono letti internamente da
852 LilyPond.  Nota che sono diversi dalle stringhe di testo arbitrarie, che
853 appaiono nella forma @code{"una stringa di testo"}; maggiori informazioni sui
854 simboli e le stringhe si trovano in @rextend{Scheme tutorial}.
855
856 Quindi il comando @code{\override} che rende il testo corsivo è:
857
858 @example
859 \override LyricText.font-shape = #'italic
860 @end example
861
862 @noindent
863 Deve essere posizionato proprio di fronte al testo che vogliamo modificare,
864 in questo modo:
865
866 @cindex proprietà font-shape, esempio
867 @cindex font-shape, esempio
868 @cindex italic, esempio
869 @cindex corsivo, esempio
870 @cindex LyricText, esempio di sovrascrittura
871 @cindex @code{\addlyrics}, esempio
872
873 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
874 {
875   \key es \major
876   \time 6/8
877   {
878     r4 bes8 bes[( g]) g |
879     g8[( es]) es d[( f]) as |
880     as8 g
881   }
882   \addlyrics {
883     \override LyricText.font-shape = #'italic
884     The man who | feels love's sweet e -- | mo -- tion
885   }
886 }
887 @end lilypond
888
889 @noindent
890 e tutto il testo è in corsivo.
891
892 @warning{Nel testo bisogna lasciare sempre uno spazio bianco tra l'ultima
893 sillaba e la parentesi graffa che chiude il blocco.}
894
895
896 @seealso
897 Estendere: @rextend{Scheme tutorial}.
898
899
900 @node Tipi di proprietà
901 @subsection Tipi di proprietà
902 @translationof Types of properties
903
904 @cindex tipi di proprietà
905 @cindex proprietà, tipi di
906
907 Finora abbiamo visto due tipi di proprietà: @code{number} e
908 @code{symbol}.  Per essere valido, il valore dato a una proprietà
909 deve essere del tipo corretto e obbedire alle regole di quel tipo.
910 Nella guida al Funzionamento interno il tipo di proprietà è indicato
911 tra parentesi dopo il nome della proprietà.  Ecco una lista dei tipi
912 che ti possono servire, corredata dalle regole per ciascun tipo e da alcuni
913 esempi.  Ovviamente, se inseriti in un comando @code{\override}, devono
914 essere sempre preceduti dal simbolo di cancelletto, @code{#}.
915
916 @multitable @columnfractions .2 .45 .35
917 @headitem Tipo di proprietà
918   @tab Regole
919   @tab Esempi
920 @item Boolean
921   @tab O Vero (True) o Falso (False), rappresentato da #t o #f
922   @tab @code{#t}, @code{#f}
923 @item Dimension (in staff space)
924   @tab Un numero positivo decimale (nell'unità di misura dello spazio del rigo)
925   @tab @code{2.5}, @code{0.34}
926 @item Direction
927   @tab Una valida direzione costante o il suo equivalente numerico (sono
928 ammessi valori decimali compresi tra -1 e 1)
929   @tab @code{LEFT}, @code{CENTER}, @code{UP},
930        @code{1}, @w{@code{-1}}
931 @item Integer
932   @tab Un numero positivo intero
933   @tab @code{3}, @code{1}
934 @item List
935   @tab Un insieme di valori separato da spazi, racchiuso tra parentesi e
936 preceduto da un apostrofo
937   @tab @code{'(left-edge staff-bar)}, @code{'(1)},
938        @code{'(1.0 0.25 0.5)}
939 @item Markup
940   @tab Qualsiasi valido blocco markup
941   @tab @code{\markup @{ \italic "cresc." @}}
942 @item Moment
943   @tab Una frazione di una nota intera costruita con la
944 funzione make-moment
945   @tab @code{(ly:make-moment 1/4)},
946        @code{(ly:make-moment 3/8)}
947 @item Number
948   @tab Qualsiasi valore decimale positivo o negativo
949   @tab @code{3.5}, @w{@code{-2.45}}
950 @item Pair (of numbers)
951   @tab Due numeri separati da un @q{spazio . spazio} e racchiusi tra
952 parentesi precedute da un apostrofo
953   @tab @code{'(2 . 3.5)}, @code{'(0.1 . -3.2)}
954 @item Symbol
955   @tab Qualsiasi insieme di simboli ammesso per quella proprietà,
956 preceduto da un apostrofo
957   @tab @code{'italic}, @code{'inside}
958 @item Unknown
959   @tab Una procedura o un valore @code{#f} che impedisca l'azione
960   @tab @code{bend::print}, @code{ly:text-interface::print},
961        @code{#f}
962 @item Vector
963   @tab Una lista di tre elementi racchiusi tra parentesi e preceduti
964 da apostrofo-cancelletto, @code{'#}.
965   @tab @code{'#(#t #t #f)}
966 @end multitable
967
968
969 @seealso
970 Estendere: @rextend{Scheme tutorial}.
971
972
973 @node Aspetto degli oggetti
974 @section Aspetto degli oggetti
975 @translationof Appearance of objects
976
977 Mettiamo in pratica quello che abbiamo imparato con un po' di
978 esempi che mostrano come modificare l'aspetto degli elementi
979 di una partitura.
980
981 @menu
982 * Visibilità e colore degli oggetti::
983 * Dimensione degli oggetti::
984 * Lunghezza e spessore degli oggetti::
985 @end menu
986
987 @node Visibilità e colore degli oggetti
988 @subsection Visibilità e colore degli oggetti
989 @translationof Visibility and color of objects
990
991 Potremmo voler creare una partitura priva di alcuni elementi a
992 scopo didattico, perché lo studente possa esercitarsi
993 a inserirli.  Vediamo un semplice esempio e immaginiamo che
994 l'esercizio consista nell'inserire le stanghette mancanti
995 di un brano.  Ma di norma le stanghette sono inserite
996 automaticamente: come lo possiamo impedire?
997
998 Prima di iniziare, occorre ricordare che le proprietà degli oggetti sono
999 raggruppate nelle cosiddette @emph{interfacce} -- si veda @ref{Properties
1000 found in interfaces}.  Queste servono semplicemente a raggruppare quelle
1001 proprietà che possono essere usate insieme per modificare un oggetto
1002 grafico -- se una di queste è ammessa per un oggetto, lo sono anche le
1003 altre.  Alcuni oggetti usano le proprietà di alcune interfacce, altri
1004 quelle di altre interfacce.  Le interfacce che contengono le proprietà
1005 usate da un particolare grob (oggetto grafico) sono elencate nella guida al
1006 Funzionamento interno in fondo alla pagina che descrive il grob; queste
1007 proprietà possono essere individuate consultando quelle interfacce.
1008
1009 In @ref{Properties of layout objects} abbiamo spiegato come trovare le
1010 informazioni sui grob.  Usando lo stesso approccio, andiamo nella guida
1011 al Funzionamento interno per trovare l'oggetto grafico relativo alla
1012 stanghetta (@emph{bar line}).  Passando da @emph{Backend} e @emph{All layout objects}
1013 troviamo un oggetto grafico chiamato @code{BarLine}.  Tra le sue proprietà ce ne sono
1014 due che controllano la visibilità: @code{break-visibility} e @code{stencil}.  Anche
1015 Barline supporta varie interfacce, tra cui la @code{grob-interface},
1016 dove troviamo le proprietà @code{transparent} e @code{color}.
1017 Tutte queste proprietà hanno degli effetti sulla visibilità delle stanghette (e,
1018 ovviamente, anche di molti altri oggetti grafici).  Vediamole una per
1019 volta.
1020
1021 @subheading stencil
1022
1023 @cindex proprietà stencil
1024 @cindex stencil, proprietà
1025
1026 Questa proprietà controlla l'aspetto delle stanghette specificando il
1027 simbolo (glifo) da usare.  Come nel caso di molte altre proprietà,
1028 si può far in modo che non usi nessun simbolo impostando il suo
1029 valore su @code{#f}.  Proviamo, come prima, omettendo il contesto
1030 implicito, @code{Voice}:
1031
1032 @cindex BarLine, esempio di sovrascrittura
1033 @cindex proprietà stencil, esempio
1034 @cindex stencil, esempio
1035
1036 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1037 {
1038   \time 12/16
1039   \override BarLine.stencil = ##f
1040   c4 b8 c d16 c d8 |
1041   g,8 a16 b8 c d4 e16 |
1042   e8
1043 }
1044 @end lilypond
1045
1046 Le stanghette sono ancora visibili.  Cosa abbiamo sbagliato?  Torna alla
1047 guida del Funzionamento interno e scorri di nuovo la pagina che elenca
1048 le proprietà di BarLine.  In cima alla pagina dice @qq{Barline objects are
1049 created by: Bar_engraver}.  Vai alla pagina @code{Bar_engraver}.  In fondo
1050 si trova una lista dei contesti nel quale opera l'incisore della battuta.
1051 Tutti questi sono di tipo @code{Staff}, dunque la ragione per cui il comando
1052 @code{\override} precedente non funziona è che @code{Barline} non si trova
1053 nel contesto predefinito, @code{Voice}.  Se il contesto indicato non è
1054 corretto, il comando non funziona.  Non viene generato alcun messaggio
1055 di errore e non viene registrato niente nel file di log.  Proviamo a
1056 correggerlo specificando il contesto giusto:
1057
1058 @cindex BarLine, esempio di sovrascrittura
1059 @cindex proprietà stencil, esempio
1060 @cindex stencil, esempio
1061
1062 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1063 {
1064   \time 12/16
1065   \override Staff.BarLine.stencil = ##f
1066   c4 b8 c d16 c d8 |
1067   g,8 a16 b8 c d4 e16 |
1068   e8
1069 }
1070 @end lilypond
1071
1072 Ora le stanghette sono sparite.  Impostare la proprietà @code{stencil}
1073 su @code{#f} è un'operazione talmente frequente che è stata creata una
1074 scorciatoia, @code{\omit}:
1075 @funindex \omit
1076
1077 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1078 {
1079   \time 12/16
1080   \omit Staff.BarLine
1081   c4 b8 c d16 c d8 |
1082   g,8 a16 b8 c d4 e16 |
1083   e8
1084 }
1085 @end lilypond
1086
1087 Si noti però che impostare la proprietà @code{stencil} su @code{#f}
1088 causerà degli errori nel caso in cui le dimensioni dell'oggetto
1089 siano necessarie per elaborarlo correttamente.  Ad esempio, si creano
1090 degli errori se la proprietà @code{stencil} dell'oggetto @code{NoteHead} è
1091 impostata su @code{#f}.  In questo caso è possibile usare invece la funzione
1092 @code{point-stencil}, che trasforma lo stencil in un oggetto a dimensione
1093 zero:
1094
1095 @lilypond[quote,verbatim,relative=2]
1096 {
1097   c4 c
1098   \once \override NoteHead.stencil = #point-stencil
1099   c4 c
1100 }
1101 @end lilypond
1102
1103 @subheading break-visibility
1104
1105 @cindex proprietà break-visibility
1106 @cindex break-visibility, proprietà
1107
1108 Nella pagina di @code{BarLine} della guida al Funzionamento interno
1109 vediamo che la proprietà @code{break-visibility} richiede un vettore di
1110 tre valori booleani.
1111 Questi valori controllano rispettivamente se le stanghette debbano
1112 comparire alla fine, in mezzo o all'inizio dei righi.  Dato
1113 che nel nostro esempio vogliamo sopprimere tutte le stanghette, il valore
1114 che ci serve è @code{#(#f #f #f)} (equivalente al nome @code{all-invisible}).
1115 Proviamo, ricordando di includere il contesto @code{Staff}.  Si noti che prima
1116 della parentesi di apertura abbiamo @code{##}.  Un @code{#} è necessario
1117 perché introduce un vettore, mentre il primo@tie{}@code{#} deve precedere, come
1118 sempre, il valore del comando @code{\override}.
1119
1120 @cindex BarLine, esempio di sovrascrittura
1121 @cindex proprietà break-visibility, esempio
1122 @cindex break-visibility, esempio
1123
1124 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1125 {
1126   \time 12/16
1127   \override Staff.BarLine.break-visibility = ##(#f #f #f)
1128   c4 b8 c d16 c d8 |
1129   g,8 a16 b8 c d4 e16 |
1130   e8
1131 }
1132 @end lilypond
1133
1134 E vediamo che anche questo comando elimina tutte le stanghette.
1135
1136 @subheading transparent
1137
1138 @cindex proprietà transparent
1139 @cindex transparent, proprietà
1140 @cindex trasparenza
1141
1142 Nelle proprietà specificate nella pagina @code{grob-interface} della
1143 guida al Funzionamento interno vediamo che la proprietà @code{transparent} è
1144 un booleano.  Quindi deve essere impostata su @code{#t} («true», 'vero') per
1145 rendere trasparente il grob.  Nel prossimo esempio rendiamo trasparente
1146 il segno di tempo invece delle stanghette.  Per farlo dobbiamo trovare
1147 il nome del grob del segno di tempo (in inglese @emph{time signature}).
1148 Torniamo alla pagina @q{All layout objects} per scoprire quali sono le
1149 proprietà dell'oggetto di formattazione @code{TimeSignature}.  Tale grob
1150 è generato dall'incisore @code{Time_signature_engraver}, che opera
1151 nel contesto @code{Staff} e supporta l'interfaccia @code{grob-interface}.
1152 Quindi il comando che rende trasparente l'indicazione di tempo è:
1153
1154 @cindex TimeSignature, esempio di sovrascrittura
1155 @cindex proprietà transparent, esempio
1156 @cindex transparent, esempio
1157
1158 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1159 {
1160   \time 12/16
1161   \override Staff.TimeSignature.transparent = ##t
1162   c4 b8 c d16 c d8 |
1163   g,8 a16 b8 c d4 e16 |
1164   e8
1165 }
1166 @end lilypond
1167
1168 @noindent
1169 Impostare la proprietà @code{transparent} è un'operazione piuttosto
1170 frequente, perciò è stata creata la scorciatoia @code{\hide}:
1171 @funindex \hide
1172
1173 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1174 {
1175   \time 12/16
1176   \hide Staff.TimeSignature
1177   c4 b8 c d16 c d8 |
1178   g,8 a16 b8 c d4 e16 |
1179   e8
1180 }
1181 @end lilypond
1182
1183 @noindent
1184 L'indicazione di tempo è scomparsa; è rimasto però uno spazio al suo posto.  Magari
1185 questo è quello che si desidera, ad esempio per creare un esercizio in cui uno
1186 studente deve riempire degli spazi vuoti.  Ma in altre circostanze ciò può
1187 non essere gradito.  Per eliminare lo spazio vuoto bisogna impostare la
1188 proprietà stencil su @code{#f}:
1189
1190 @cindex TimeSignature, esempio di sovrascrittura
1191 @cindex proprietà stencil, esempio
1192 @cindex stencil, esempio
1193
1194 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1195 {
1196   \time 12/16
1197   \omit Staff.TimeSignature
1198   c4 b8 c d16 c d8 |
1199   g,8 a16 b8 c d4 e16 |
1200   e8
1201 }
1202 @end lilypond
1203
1204 @noindent
1205 la differenza è ovvia: se si imposta lo stencil su @code{#f} (possibilmente
1206 con @code{\omit}) l'oggetto scompare del tutto; se si rende l'oggetto
1207 @code{trasparente} questo resta dove è, anche se invisibile.
1208
1209 @subheading color
1210
1211 @cindex proprietà color
1212 @cindex color, proprietà
1213
1214 Infine, proviamo a rendere le stanghette invisibili colorandole
1215 di bianco.  (Si tratta di un metodo problematico perché la
1216 stanghetta bianca può imbiancare o meno le linee del rigo che
1217 incrocia.  Puoi vedere in alcuni degli esempi successivi che questo
1218 accade in modo imprevedibile.  I motivi per cui questo accade e il
1219 modo in cui è possibile controllarlo sono esposti in @ruser{Painting objects white}.
1220 Ma per il momento stiamo imparando la proprietà color, quindi accettiamo questa limitazione.)
1221
1222 L'interfaccia @code{grob-interface} stabilisce che il valore della
1223 proprietà color è una lista, ma non spiega cosa debba essere questa
1224 lista.  La lista di cui ha bisogno è in realtà una lista di valori
1225 in unità interne, ma per evitare di dover imparare quali siano queste
1226 unità vengono forniti vari modi di specificare un colore.  Il primo
1227 modo consiste nell'usare uno dei colori @q{normali} elencati nella
1228 prima tabella in @ruser{List of colors}.  Per rendere bianche le
1229 stanghette scriviamo:
1230
1231 @cindex BarLine, esempio di sovrascrittura
1232 @cindex proprietà color
1233 @cindex color, proprietà
1234
1235 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1236 {
1237   \time 12/16
1238   \override Staff.BarLine.color = #white
1239   c4 b8 c d16 c d8 |
1240   g,8 a16 b8 c d4 e16 |
1241   e8
1242 }
1243 @end lilypond
1244
1245 @noindent
1246 e di nuovo vediamo che le stanghette non sono visibili.  Si noti
1247 che @emph{white} non è preceduto da un apostrofo, perché non
1248 è un simbolo, ma una @emph{variabile}.  Quando viene esaminata, fornisce
1249 la lista di valori interni necessari per impostare il colore su
1250 bianco.  Gli altri colori nella lista normale sono anch'essi
1251 delle variabili.  Per convincerti che funziona potresti provare a
1252 cambiare il colore e usare una delle altre variabili presenti
1253 nella lista.
1254
1255 @cindex color, X11
1256 @cindex colori X11
1257 @cindex X11, colori
1258
1259 @funindex x11-color
1260
1261 Il secondo modo per cambiare il colore è attraverso la lista
1262 di nomi di colori X11 che si trova in @ruser{List of colors}.
1263 Questi colori vengono trasformati in valori reali dalla funzione
1264 @code{x11-color}, che converte i simboli di colore X11 nella lista
1265 di valori interni:
1266
1267 @cindex BarLine, esempio di sovrascrittura
1268 @cindex proprietà color, esempio
1269 @cindex color, esempio
1270
1271 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1272 {
1273   \time 12/16
1274   \override Staff.BarLine.color = #(x11-color 'white)
1275   c4 b8 c d16 c d8 |
1276   g,8 a16 b8 c d4 e16 |
1277   e8
1278 }
1279 @end lilypond
1280
1281 @noindent
1282 Si noti che in questo caso la funzione @code{x11-color} prende
1283 un simbolo come argomento, dunque il simbolo deve essere preceduto
1284 da un apostrofo per impedire che sia considerato una variabile e
1285 l'intera funzione deve essere racchiusa tra parentesi.
1286
1287 @cindex colori rgb
1288 @cindex rgb, colori
1289 @cindex color, rgb
1290
1291 @funindex rgb-color
1292
1293 Esiste un'altra funzione, che converte i valori RGB in colori
1294 interni, la funzione @code{rgb-color}.  Prende tre argomenti
1295 che specificano l'intensità dei colori rosso, verde e blu.
1296 I valori vanno da 0 a 1.  Quindi per avere il colore rosso
1297 il valore sarà @code{(rgb-color 1 0 0)}
1298 e per avere il bianco sarà @code{(rgb-color 1 1 1)}:
1299
1300 @cindex BarLine, esempio di sovrascrittura
1301 @cindex proprietà color, esempio
1302 @cindex color, esempio
1303
1304 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1305 {
1306   \time 12/16
1307   \override Staff.BarLine.color = #(rgb-color 1 1 1)
1308   c4 b8 c d16 c d8 |
1309   g,8 a16 b8 c d4 e16 |
1310   e8
1311 }
1312 @end lilypond
1313
1314 Infine, è disponibile anche una scala di grigi, appartenente all'insieme
1315 di colori X11.  Questi vanno dal nero, @code{'grey0},
1316 al bianco, @code{'grey100}, con cadenza di 1.  Ecco un
1317 esempio in cui tutti gli oggetti di formattazione sono
1318 impostati su diverse tonalità di grigio:
1319
1320 @cindex StaffSymbol, esempio di sovrascrittura
1321 @cindex TimeSignature, esempio di sovrascrittura
1322 @cindex Clef, esempio di sovrascrittura
1323 @cindex NoteHead, esempio di sovrascrittura
1324 @cindex Stem, esempio di sovrascrittura
1325 @cindex BarLine, esempio di sovrascrittura
1326 @cindex proprietà color, esempio
1327 @cindex color, esempio
1328 @cindex x11-color, esempio di utilizzo
1329
1330 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1331 {
1332   \time 12/16
1333   \override Staff.StaffSymbol.color = #(x11-color 'grey30)
1334   \override Staff.TimeSignature.color = #(x11-color 'grey60)
1335   \override Staff.Clef.color = #(x11-color 'grey60)
1336   \override Voice.NoteHead.color = #(x11-color 'grey85)
1337   \override Voice.Stem.color = #(x11-color 'grey85)
1338   \override Staff.BarLine.color = #(x11-color 'grey10)
1339   c4 b8 c d16 c d8 |
1340   g,8 a16 b8 c d4 e16 |
1341   e8
1342 }
1343 @end lilypond
1344
1345 @noindent
1346 Nota i contesti associati a ciascuno degli oggetti di formattazione.
1347 È importante scegliere quelli giusti, altrimenti i comandi non
1348 funzioneranno!  Ricorda, il contesto è quello in cui si trova il
1349 relativo incisore.  Il contesto predefinito per gli incisori si trova
1350 partendo dall'oggetto di formattazione (@emph{layout object}) per poi
1351 andare all'incisore che lo produce: la pagina dell'incisore nella
1352 guida al Funzionamento interno riporterà a quale contesto
1353 appartenga di norma l'incisore.
1354
1355
1356 @node Dimensione degli oggetti
1357 @subsection Dimensione degli oggetti
1358 @translationof Size of objects
1359
1360 @cindex modificare la dimensione degli oggetti
1361 @cindex dimensione degli oggetti
1362 @cindex oggetti, dimensione degli
1363 @cindex oggetti, modificare la dimensione degli
1364
1365 Iniziamo rivedendo l'esempio precedente (vedi
1366 @ref{Nesting music expressions}) che mostrava come
1367 inserire un nuovo rigo temporaneo, come in un @rglos{ossia}.
1368
1369 @cindex proprietà alignAboveContext, esempio
1370 @cindex @code{\with}, esempio
1371
1372 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1373 \new Staff ="main" {
1374   \relative g' {
1375     r4 g8 g c4 c8 d |
1376     e4 r8
1377     <<
1378       { f8 c c }
1379       \new Staff \with {
1380         alignAboveContext = #"main" }
1381       { f8 f c }
1382     >>
1383     r4 |
1384   }
1385 }
1386 @end lilypond
1387
1388 Gli ossia di norma vengono scritti senza chiave e senza indicazione di
1389 tempo e hanno solitamente una dimensione leggermente inferiore a
1390 quella del rigo pricipale.  Sappiamo già come togliere la chiave e
1391 il segno di tempo, cioè impostando semplicemente la proprietà stencil di
1392 ciascun oggetto su @code{#f}, così:
1393
1394 @cindex proprietà alignAboveContext, esempio
1395 @cindex @code{\with}, esempio
1396 @funindex \omit
1397 @cindex Clef, esempio di sovrascrittura
1398 @cindex TimeSignature, esempio di sovrascrittura
1399
1400 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1401 \new Staff ="main" {
1402   \relative g' {
1403     r4 g8 g c4 c8 d |
1404     e4 r8
1405     <<
1406       { f8 c c }
1407       \new Staff \with {
1408         alignAboveContext = #"main"
1409       }
1410       {
1411         \omit Staff.Clef
1412         \omit Staff.TimeSignature
1413         { f8 f c }
1414       }
1415     >>
1416     r4 |
1417   }
1418 }
1419 @end lilypond
1420
1421 @noindent
1422 dove l'ulteriore coppia di parentesi dopo il blocco @code{\with} è
1423 necessaria perché le sovrascritture e la musica racchiusi
1424 siano applicati al rigo dell'ossia.
1425
1426 Ma qual è la differenza tra modificare il contesto del rigo con
1427 @code{\with} e modificare la proprietà stencil della chiave e
1428 del segno di tempo con @code{\override} o in questo caso @code{\omit}?  La
1429 principale differenza è che le modifiche inserite in un blocco @code{\with}
1430 vengono applicate nel momento in cui viene creato il contesto e permangono
1431 come valori @strong{predefiniti} per la durata di quel contesto, mentre i
1432 comandi @code{\set} o @code{\override} incorporati nel blocco
1433 della musica sono dinamici -- le loro modifiche sono sincronizzate
1434 con un punto preciso della musica.  Se le modifiche sono disattivate o
1435 ripristinate con @code{\unset} o @code{\revert} tornano ai valori
1436 stabiliti nel blocco @code{\with} o, in mancanza di impostazioni
1437 al suo interno, a quelli predefiniti.
1438
1439 Alcune proprietà di contesto possono essere modificate solo nei blocchi
1440 @code{\with}.  Si tratta di quelle proprietà che non si possono
1441 modificare in seguito alla creazione del contesto.  @code{alignAboveContext} e
1442 @code{alignBelowContext} sono due di esse: dopo la creazione
1443 del rigo il suo allineamento è fissato, e non ha
1444 senso tentare di cambiarlo successivamente.
1445
1446 I valori predefiniti delle proprietà degli oggetti di formattazione possono
1447 essere definiti anche nei blocchi @code{\with}.  Basta usare il normale comando
1448 @code{\override} senza specificare il nome del contesto, dato che questo è
1449 definito senza ambiguità come il contesto che il blocco @code{\with} sta
1450 modificando.  Anzi, viene generato un errore se si specifica un contesto
1451 in questa situazione.
1452
1453 Dunque possiamo sostituire l'esempio precedente con
1454
1455 @cindex alignAboveContext property, esempio
1456 @cindex @code{\with}, esempio
1457 @cindex Clef, esempio di sovrascrittura
1458 @cindex TimeSignature, esempio di sovrascrittura
1459
1460 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1461 \new Staff ="main" {
1462   \relative g' {
1463     r4 g8 g c4 c8 d |
1464     e4 r8
1465     <<
1466       { f8 c c }
1467       \new Staff \with {
1468         alignAboveContext = #"main"
1469         % Nasconde le chiavi di questo rigo
1470         \override Clef.stencil = ##f
1471         % Nasconde le indicazioni di tempo di questo rigo
1472         \override TimeSignature.stencil = ##f
1473       }
1474       { f8 f c }
1475     >>
1476     r4 |
1477   }
1478 }
1479 @end lilypond
1480
1481 Si possono usare anche le scorciatoie @code{\hide} e @code{\omit} per
1482 impostare la proprietà @code{transparent} e togliere lo @code{stencil}
1483
1484 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1485 \new Staff ="main" {
1486   \relative g' {
1487     r4 g8 g c4 c8 d |
1488     e4 r8
1489     <<
1490       { f8 c c }
1491       \new Staff \with {
1492         alignAboveContext = #"main"
1493         % Nasconde le chiavi di questo rigo
1494         \omit Clef
1495         % Nasconde le indicazioni di tempo di questo rigo
1496         \omit TimeSignature
1497       }
1498       { f8 f c }
1499     >>
1500     r4 |
1501   }
1502 }
1503 @end lilypond
1504
1505 Infine arriviamo a modificare la dimensione degli oggetti di formattazione.
1506
1507 Alcuni oggetti di formattazione sono dei glifi scelti da un tipo di
1508 carattere.  Ad esempio le teste di nota, le alterazioni, le annotazioni,
1509 le chiavi, le indicazioni di tempo, la dinamica, il testo vocale.  La loro dimensione
1510 varia se si modifica la proprietà @code{font-size}, come vedremo a
1511 breve.  Altri oggetti di formattazione come le legature di portamento e
1512 di valore -- in generale, tutti gli oggetti estensori (@emph{spanner}) -- vengono
1513 disegnati individualmente, dunque non esiste un @code{font-size} a loro
1514 associato.  Questi oggetti generalmente derivano la loro dimensione dagli
1515 oggetti a cui sono connessi, quindi di solito non è necessario modificare
1516 la loro dimensione a mano.  Altre proprietà, come la lunghezza dei gambi
1517 e delle stanghette, lo spessore delle travature e di altre linee e la
1518 separazione delle linee del rigo, devono essere modificate in modi speciali.
1519
1520 Tornando all'esempio dell'ossia, proviamo prima a cambiare font-size.
1521 Possiamo farlo in due modi.  Possiamo modificare la dimensione dei
1522 tipi di carattere di ogni tipo di oggetto, come le teste di nota
1523 (@code{NoteHead}) con un comando di questo tipo
1524
1525 @example
1526 \override NoteHead.font-size = #-2
1527 @end example
1528
1529 oppure possiamo modificare la dimensione di tutti i tipi di carattere usando
1530 una proprietà speciale, @code{fontSize}, con @code{\set} oppure includendola
1531 in un blocco @code{\with} (ma senza @code{\set}).
1532
1533 @example
1534 \set fontSize = #-2
1535 @end example
1536
1537 Entrambe queste dichiarazioni fanno sì che la dimensione del tipo di carattere
1538 sia ridotta di due unità rispetto al valore precedente, dove ogni unità
1539 riduce o aumenta la dimensione di circa il 12%.
1540
1541 Proviamolo nel nostro esempio dell'ossia:
1542
1543 @cindex alignAboveContext property, esempio
1544 @cindex @code{\with}, esempio
1545 @cindex Clef, esempio di sovrascrittura
1546 @cindex TimeSignature, esempio di sovrascrittura
1547 @cindex proprietà fontSize, esempio
1548 @cindex fontSize, esempio
1549
1550 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1551 \new Staff ="main" {
1552   \relative g' {
1553     r4 g8 g c4 c8 d |
1554     e4 r8
1555     <<
1556       { f8 c c }
1557       \new Staff \with {
1558         alignAboveContext = #"main"
1559         \omit Clef
1560         \omit TimeSignature
1561         % Riduce la dimensione di tutti i tipi di carattere di circa il 24%
1562         fontSize = #-2
1563       }
1564       { f8 f c }
1565     >>
1566     r4 |
1567   }
1568 }
1569 @end lilypond
1570
1571 L'esempio non è ancora a posto.  Le teste di nota e  le code sono
1572 più piccole, ma in proporzione i gambi sono troppo lunghi e le linee
1573 del rigo sono troppo separate.  Dovrebbero essere scalati in proporzione
1574 alla riduzione del tipo di carattere.  La prossima sezione spiega come
1575 farlo.
1576
1577 @node Lunghezza e spessore degli oggetti
1578 @subsection Lunghezza e spessore degli oggetti
1579 @translationof Length and thickness of objects
1580
1581 @cindex distanze
1582 @cindex thickness, proprietà
1583 @cindex spessore
1584 @cindex lunghezza
1585 @cindex magstep
1586 @cindex dimensione, modificare la
1587 @cindex lunghezza del gambo, modificare la
1588 @cindex spaziatura delle linee del rigo, modificare la
1589
1590 Distanze e lunghezze in LilyPond sono misurate generalmente in @code{staff-space},
1591 ovvero la distanza tra linee adiacenti del rigo (o talvolta la metà di uno
1592 spazio rigo), mentre gran parte delle proprietà che controllano lo spessore
1593 (@code{thickness}) sono misurate con l'unità di misura di una proprietà
1594 interna chiamata @code{line-thickness.}  Ad esempio, lo spessore predefinito
1595 delle linee delle forcine è di 1 unità di @code{line-thickness},
1596 mentre lo spessore (@code{thickness}) di un gambo di nota è 1.3.  Si noti
1597 che alcune proprietà dello spessore sono diverse; per esempio, lo spessore
1598 delle travature è controllato dal valore della proprietà @code{beam-thickness},
1599 che si misura in @code{staff-space}.
1600
1601 Dunque come si possono scalare le lunghezze in proporzione alla
1602 dimensione del carattere?
1603 È possibile ricorrendo a una funzione speciale chiamata
1604 @code{magstep}, che serve proprio a questo scopo.  Prende un
1605 argomento, la modifica della dimensione del tipo di carattere (#-2
1606 nell'esempio precedente) e restituisce un fattore di ridimensionamento
1607 adatto a ridurre gli altri oggetti proporzionalmente.  Si usa in
1608 questo modo:
1609
1610 @cindex proprietà alignAboveContext, esempio
1611 @cindex alignAboveContext, esempio
1612 @cindex @code{\with}, esempio
1613 @cindex Clef, esempio di sovrascrittura
1614 @cindex TimeSignature, esempio di sovrascrittura
1615 @cindex proprietà fontSize, esempio
1616 @cindex fontSize, esempio
1617 @cindex StaffSymbol, esempio di sovrascrittura
1618 @cindex funzione magstep, esempio di uso
1619 @cindex magstep, esempio di uso
1620 @cindex proprietà staff-space, esempio
1621 @cindex staff-space, esempio
1622 @cindex proprietà stencil, esempio
1623 @cindex stencil, esempio
1624
1625 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1626 \new Staff ="main" {
1627   \relative g' {
1628     r4 g8 g c4 c8 d |
1629     e4 r8
1630     <<
1631       { f8 c c }
1632       \new Staff \with {
1633         alignAboveContext = #"main"
1634         \omit Clef
1635         \omit TimeSignature
1636         fontSize = #-2
1637         % Riduce proporzionalmente la lunghezza dei gambi e la spaziatura tra le linee
1638         \override StaffSymbol.staff-space = #(magstep -2)
1639       }
1640       { f8 f c }
1641     >>
1642     r4 |
1643   }
1644 }
1645 @end lilypond
1646
1647 @noindent
1648 Dato che la lunghezza dei gambi e molte altre proprietà relative alla
1649 lunghezza sono sempre calcolate in relazione al valore della proprietà
1650 @code{staff-space}, anche queste sono automaticamente ridimensionate
1651 in lunghezza.  Nota che ciò riguarda solo la scala verticale
1652 dell'ossia -- la scala orizzontale è determinata dalla formattazione
1653 della musica principale perché deve restare sincronizzata con quest'ultima,
1654 quindi le modifiche di dimensione non la riguardano.  Ovviamente, se
1655 la scala di tutta la musica principale venisse cambiata allora la
1656 spaziatura orizzontale cambierebbe.  Tratteremo questo argomento più
1657 avanti, nella parte relativa alla formattazione.
1658
1659 Questo completa la creazione dell'ossia.  Le dimensioni e le lunghezze
1660 di tutti gli altri oggetti possono essere modificati in modi analoghi.
1661
1662 Per piccole modifiche della dimensione, come nell'esempio precedente, non
1663 sono necessari solitamente degli aggiustamenti globali dello spessore delle
1664 varie linee disegnate (come stanghette, travature, forcine, legature di
1665 portamento, etc.).  Se si deve aggiustare lo spessore di un
1666 particolare oggetto di formattazione, è meglio sovrascrivere la sua
1667 proprietà @code{thickness}.  Un esempio di come modificare lo spessore
1668 delle legature di portamento è stato mostrato prima in @ref{Properties of layout objects}.
1669 Lo spessore di tutti gli oggetti disegnati (ovvero quelli non prodotti
1670 da un tipo di carattere) può essere cambiato nello stesso modo.
1671
1672
1673 @node Posizionamento degli oggetti
1674 @section Posizionamento degli oggetti
1675 @translationof Placement of objects
1676
1677 @menu
1678 * Comportamento automatico::
1679 * Oggetti interni al rigo::
1680 * Oggetti esterni al rigo::
1681 @end menu
1682
1683
1684 @node Comportamento automatico
1685 @subsection Comportamento automatico
1686 @translationof Automatic behavior
1687
1688 @cindex within-staff, oggetti
1689 @cindex outside-staff, oggetti
1690 @cindex oggetti dentro il rigo
1691 @cindex oggetti fuori dal rigo
1692
1693 Nella notazione musicale, alcuni oggetti appartengono al rigo, altri
1694 devono esserne posizionati al di fuori.  In LilyPond si chiamano rispettivamente oggetti within-staff
1695 (dentro il rigo) e oggetti outside-staff (fuori dal rigo).
1696
1697 Gli oggetti within-staff sono quelli che si trovano nel rigo, come
1698 le teste e i gambi delle note, le alterazioni, etc..  La loro posizione
1699 è determinata perlopiù dalla musica stessa: in verticale sono collocati
1700 su determinate posizioni del rigo o sono collegati
1701 ad altri oggetti disposti in questo modo. Di norma LilyPond evita
1702 automaticamente le collisioni tra teste di nota, gambi e alterazioni
1703 in accordi con note ravvicinate.  Esistono comunque dei comandi che
1704 permettono di modificare questo comportamento automatico, come
1705 vedremo tra poco.
1706
1707 Gli oggetti che appartengono allo spazio fuori dal rigo comprendono
1708 gli andamenti, i numeri di chiamata, il testo vocale, le indicazioni dinamiche. Il comportamento di
1709 LilyPond per il posizionamento verticale degli oggetti outside-staff
1710 prevede che questi vengano collocati il più vicino possibile al rigo, mantenendo
1711 però una distanza sufficiente da evitare collisioni con gli altri oggetti.  LilyPond
1712 usa la proprietà @code{outside-staff-priority} per determinare in quale ordine
1713 gli oggetti siano posizionati.
1714
1715 Per prima cosa LilyPond posiziona tutti gli oggetti within-staff.
1716 Poi ordina gli oggetti outside-staff in base alla loro proprietà
1717 @code{outside-staff-priority}.  Gli oggetti outside-staff vengono
1718 considerati uno a uno, a partire dall'oggetto che ha il valore più basso
1719 di priorità (@code{outside-staff-priority}), e disposti in modo
1720 da non entrare in collisione con alcun oggetto già posizionato.
1721 Questo significa che se due oggetti outside-staff si contendono lo
1722 stesso spazio, quello col valore più basso di @code{outside-staff-priority}
1723 sarà più vicino al rigo.  Se due oggetti presentano lo stesso valore per
1724 @code{outside-staff-priority}, quello incontrato per primo viene posizionato
1725 più vicino al rigo.
1726
1727 Nell'esempio seguente tutti i testi hanno la stessa priorità (perché
1728 questa non è impostata in modo esplicito).  Come puoi vedere, @q{Testo3}
1729 è di nuovo posto automaticamente in prossimità del rigo, infilato
1730 sotto @q{Testo2}.
1731
1732 @cindex markup, esempio
1733
1734 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1735 c2^"Testo1"
1736 c2^"Testo2" |
1737 c2^"Testo3"
1738 c2^"Testo4" |
1739 @end lilypond
1740
1741 Di norma, anche i righi sono collocati quanto più possibile ravvicinati
1742 (ma con una distanza minima).  Se delle note si estenderanno molto
1743 al di fuori del rigo, fino a quello adiacente, costringeranno i righi a distanziarsi
1744 solo in caso di sovrapposizione degli elementi della notazione.  L'esempio
1745 seguente mostra questo @q{annidamento} delle note su righi adiacenti:
1746
1747 @lilypond[quote,ragged-right,verbatim]
1748 <<
1749   \new Staff {
1750     \relative c' { c4 a, }
1751   }
1752   \new Staff {
1753     \relative c'''' { c4 a, }
1754   }
1755 >>
1756 @end lilypond
1757
1758
1759 @node Oggetti interni al rigo
1760 @subsection Oggetti interni al rigo
1761 @translationof Within-staff objects
1762
1763 Abbiamo già visto come i comandi @code{\voiceXXX} influenzino
1764 la direzione di legature di portamento e di valore, delle diteggiature e
1765 di qualsiasi altro elemento che dipenda dalla direzione dei gambi (vedi
1766 @ref{Explicitly instantiating voices}).
1767 Questi comandi sono fondamentali quando si scrive musica polifonica,
1768 perché permettono di distinguere le linee melodiche che si intrecciano.
1769 Talvolta, però, capita di voler modificare questo comportamento
1770 automatico.  Si può fare per intere sezioni musicali o anche per
1771 una singola nota.  La proprietà che controlla questo comportamento
1772 è la proprietà @code{direction} di ogni oggetto di formattazione.
1773 Spieghiamo prima che cosa fa e poi presentiamo alcuni comandi
1774 già pronti, che ti eviteranno di dover scrivere sovrascritture
1775 esplicite per le modifiche più comuni.
1776
1777 Alcuni oggetti di formattazione, come le legature di portamento e di
1778 valore, si incurvano, si piegano o puntano verso l'alto o il basso; altri,
1779 come i gambi e le code, a seconda dell'orientamento si dispongono anche sulla
1780 destra o sulla sinistra.  Tutto questo viene controllato automaticamente
1781 quando si imposta la proprietà @code{direction}.
1782
1783 @cindex down
1784 @cindex up
1785 @cindex center
1786 @cindex neutral
1787
1788 L'esempio seguente mostra nella prima battuta il comportamento predefinito
1789 dei gambi, per cui i gambi delle note superiori puntano in basso e quelli delle
1790 note inferiori in alto; poi seguono quattro note con tutti i gambi
1791 forzati verso il basso, quattro con i gambi forzati verso l'alto e, infine, quattro
1792 con i gambi nuovamente disposti secondo il comportamento predefinito.
1793
1794 @cindex Stem, esempio di sovrascrittura
1795 @cindex proprietà direction, esempio
1796 @cindex direction, esempio
1797
1798 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
1799 a4 g c a |
1800 \override Stem.direction = #DOWN
1801 a4 g c a |
1802 \override Stem.direction = #UP
1803 a4 g c a |
1804 \revert Stem.direction
1805 a4 g c a |
1806 @end lilypond
1807
1808 Abbiamo usato le costanti @code{DOWN} (giù) e @code{UP} (su).
1809 Queste hanno rispettivamente i valori @w{@code{-1}} e @code{+1}, ed
1810 è possibile usare tali valori numerici al loro posto.  In alcuni casi
1811 si può usare anche il valore @code{0}, che significa @code{UP} per i
1812 gambi, ma per alcuni oggetti significa @q{center} (centro).
1813 Esiste una costante, @code{CENTER} che ha valore @code{0}.
1814
1815 Tuttavia queste sovrascritture esplicite solitamente non vengono usate, perché
1816 ci sono dei comandi predefiniti equivalenti e più semplici.  Ecco una tabella
1817 con quelli più utilizzati; il significato di ognuno è esplicitato laddove
1818 non è ovvio.
1819
1820 @multitable @columnfractions .2 .2 .25 .35
1821 @headitem Giù/Sinistra
1822   @tab Su/Destra
1823   @tab Ripristina
1824   @tab Effetto
1825 @item @code{\arpeggioArrowDown}
1826   @tab @code{\arpeggioArrowUp}
1827   @tab @code{\arpeggioNormal}
1828   @tab Aggiunge una freccia in fondo, in cima o toglie la freccia
1829 @item @code{\dotsDown}
1830   @tab @code{\dotsUp}
1831   @tab @code{\dotsNeutral}
1832   @tab Direzione dello spostamento per evitare le linee del rigo
1833 @item @code{\dynamicDown}
1834   @tab @code{\dynamicUp}
1835   @tab @code{\dynamicNeutral}
1836   @tab
1837 @item @code{\phrasingSlurDown}
1838   @tab @code{\phrasingSlurUp}
1839   @tab @code{\phrasingSlurNeutral}
1840   @tab Nota: è diverso dai comandi slur
1841 @item @code{\slurDown}
1842   @tab @code{\slurUp}
1843   @tab @code{\slurNeutral}
1844   @tab
1845 @item @code{\stemDown}
1846   @tab @code{\stemUp}
1847   @tab @code{\stemNeutral}
1848   @tab
1849 @item @code{\textSpannerDown}
1850   @tab @code{\textSpannerUp}
1851   @tab @code{\textSpannerNeutral}
1852   @tab Il testo inserito come oggetto estensore (spanner) va sotto/sopra il rigo
1853 @item @code{\tieDown}
1854   @tab @code{\tieUp}
1855   @tab @code{\tieNeutral}
1856   @tab
1857 @item @code{\tupletDown}
1858   @tab @code{\tupletUp}
1859   @tab @code{\tupletNeutral}
1860   @tab I gruppi irregolare sono sotto/sopra le note
1861 @end multitable
1862
1863
1864 Le varianti neutral/normal di questi comandi usano @code{\revert} e quindi
1865 @strong{non} possono essere precedute da @code{\once}.  Se desideri limitare
1866 l'effetto degli altri comandi (che usano @code{\override}) a un singolo
1867 momento temporale, devi farli precedere da @code{\once} come faresti con
1868 delle sovrascritture esplicite.
1869
1870
1871 @unnumberedsubsubsec Diteggiatura
1872
1873 @cindex diteggiatura, posizionamento
1874 @cindex diteggiatura, accordi
1875
1876 Anche il posizionamento della diteggiatura sulle singole note può essere
1877 controllato dalla proprietà @code{direction}, ma la modifica di @code{direction}
1878 non produce effetti sugli accordi.  Come vedremo, ci sono comandi specifici
1879 che permettono di controllare la diteggiatura delle singole note degli
1880 accordi, col segno di diteggiatura posizionato sopra, sotto, a sinistra
1881 o a destra di ogni nota.
1882
1883 Vediamo innanzitutto l'effetto di @code{direction} sulla diteggiatura
1884 attaccata alle singole note.  La prima battuta mostra il comportamento
1885 predefinito e le due battute successive mostrano gli effetti dei valori
1886 @code{DOWN} e @code{UP}:
1887
1888 @cindex Fingering, esempio di sovrascrittura
1889 @cindex proprietà direction, esempio
1890 @cindex direction, esempio
1891
1892 @lilypond[quote,verbatim,relative=2]
1893 c4-5 a-3 f-1 c'-5 |
1894 \override Fingering.direction = #DOWN
1895 c4-5 a-3 f-1 c'-5 |
1896 \override Fingering.direction = #UP
1897 c4-5 a-3 f-1 c'-5 |
1898 @end lilypond
1899
1900 Tuttavia sovrascrivere la proprietà @code{direction} non è il modo
1901 più semplice di definire a mano la diteggiatura sopra o sotto
1902 le note; di solito è preferibile usare @code{_} o @code{^} invece di @code{-}
1903 prima del numero della diteggiatura.  Ecco l'esempio precedente riscritto
1904 usando questo metodo:
1905
1906 @cindex fingering, esempio
1907
1908 @lilypond[quote,verbatim,relative=2]
1909 c4-5 a-3 f-1 c'-5 |
1910 c4_5 a_3 f_1 c'_5 |
1911 c4^5 a^3 f^1 c'^5 |
1912 @end lilypond
1913
1914 La proprietà @code{direction} viene ignorata negli accordi, ma i
1915 prefissi direzionali, @code{_} e @code{^} funzionano.  Per impostazione
1916 predefinita, la diteggiatura viene disposta automaticamente sopra e
1917 sotto le note di un accordo:
1918
1919 @cindex fingering, esempio
1920
1921 @lilypond[quote,verbatim,relative=2]
1922 <c-5 g-3>4
1923 <c-5 g-3 e-2>4
1924 <c-5 g-3 e-2 c-1>4
1925 @end lilypond
1926
1927 @noindent
1928 ma può essere sovrascritta per forzare manualmente in su o in giù tutti o
1929 alcuni dei singoli numeri della diteggiatura:
1930
1931 @cindex fingering, esempio
1932
1933 @lilypond[quote,verbatim,relative=2]
1934 <c-5 g-3 e-2 c-1>4
1935 <c^5 g_3 e_2 c_1>4
1936 <c^5 g^3 e^2 c_1>4
1937 @end lilypond
1938
1939 È possibile avere un controllo ancora maggiore sulla disposizione della
1940 diteggiatura delle singole note di un accordo usando il comando
1941 @code{\set fingeringOrientations}.  Il formato di questo comando è:
1942
1943 @example
1944 @code{\set fingeringOrientations = #'([up] [left/right] [down])}
1945 @end example
1946
1947 @noindent
1948 Si usa @code{\set} perché @code{fingeringOrientations} è una
1949 proprietà del contesto @code{Voice}, creato e usato dall'incisore
1950 @code{New_fingering_engraver}.
1951
1952 Questa proprietà accetta come valori una lista comprendente da uno a tre elementi.
1953 Stabilisce se la diteggiatura debba essere posizionata sopra (se nella
1954 lista c'è @code{up}), sotto (se c'è @code{down}), a sinistra (se c'è
1955 @code{left}) o a destra (se c'è @code{right}).  Nel caso vengano inseriti valori
1956 non accettati dalla lista, non sarà invece collocata alcuna diteggiatura.  LilyPond
1957 prende in considerazione questi limiti e trova la migliore disposizione per
1958 la diteggiatura delle note degli accordi che seguono.  Nota che @code{left} e
1959 @code{right} si escludono a vicenda -- la diteggiatura può essere posta
1960 solo da un lato o dall'altro, non da entrambi.
1961
1962 @warning{Per controllare la posizione della diteggiatura di una
1963 singola nota con questo comando bisogna scrivere la nota come un accordo
1964 con una nota sola, ovvero racchiuderla tra parentesi angolari.}
1965
1966 Ecco alcuni esempi:
1967
1968 @cindex fingering, esempio
1969 @cindex @code{\set}, esempio di utilizzo
1970 @cindex proprietà fingeringOrientations, esempio
1971
1972 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
1973 \set fingeringOrientations = #'(left)
1974 <f-2>4
1975 <c-1 e-2 g-3 b-5>4
1976 \set fingeringOrientations = #'(left)
1977 <f-2>4
1978 <c-1 e-2 g-3 b-5>4 |
1979 \set fingeringOrientations = #'(up left down)
1980 <f-2>4
1981 <c-1 e-2 g-3 b-5>4
1982 \set fingeringOrientations = #'(up left)
1983 <f-2>4
1984 <c-1 e-2 g-3 b-5>4 |
1985 \set fingeringOrientations = #'(right)
1986 <f-2>4
1987 <c-1 e-2 g-3 b-5>4
1988 @end lilypond
1989
1990 @noindent
1991 Se la diteggiatura appare eccessivamente fitta, si può ridurre la dimensione del
1992 tipo di carattere modificando la proprietà @code{font-size}.  Si può vedere
1993 nell'oggetto @code{Fingering} della guida al Funzionamento interno che il
1994 valore predefinito di tale proprietà è @w{@code{-5}}, dunque proviamo
1995 con @w{@code{-7}}:
1996
1997 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
1998 \override Fingering.font-size = #-7
1999 \set fingeringOrientations = #'(left)
2000 <f-2>4
2001 <c-1 e-2 g-3 b-5>4
2002 \set fingeringOrientations = #'(left)
2003 <f-2>4
2004 <c-1 e-2 g-3 b-5>4 |
2005 \set fingeringOrientations = #'(up left down)
2006 <f-2>4
2007 <c-1 e-2 g-3 b-5>4
2008 \set fingeringOrientations = #'(up left)
2009 <f-2>4
2010 <c-1 e-2 g-3 b-5>4 |
2011 \set fingeringOrientations = #'(right)
2012 <f-2>4
2013 <c-1 e-2 g-3 b-5>4
2014 @end lilypond
2015
2016 @node Oggetti esterni al rigo
2017 @subsection Oggetti esterni al rigo
2018 @translationof Outside-staff objects
2019
2020 Gli oggetti esterni al rigo sono disposti automaticamente in modo da evitare
2021 collisioni.  Gli oggetti dai valori più bassi per la proprietà
2022 @code{outside-staff-priority} vengono posizionati più vicino al rigo,
2023 mentre gli altri oggetti esterni al rigo vengono distanziati quanto
2024 basta per evitare collisioni.  La proprietà @code{outside-staff-priority} è
2025 definita nell'interfaccia @code{grob-interface} ed è quindi una proprietà di
2026 tutti gli oggetti di formattazione.  Il valore predefinito è @code{#f} per
2027 tutti gli oggetti interni al rigo e un valore numerico appropriato, determinato
2028 al momento della creazione dell'oggetto, per ogni oggetto esterno al rigo.  La
2029 seguente tabella mostra i valori numerici predefiniti di alcuni dei più comuni
2030 oggetti esterni al rigo.
2031
2032 @cindex estensori (spanner)
2033 @cindex spanner
2034
2035 Si notino i nomi insoliti di alcuni oggetti: gli oggetti estensori (spanner)
2036 sono creati automaticamente per controllare la disposizione verticale dei
2037 grob che (potrebbero) iniziare e finire in diversi momenti musicali, quindi
2038 la modifica della proprietà @code{outside-staff-priority} del grob sottostante
2039 non produrrebbe alcun effetto.  Ad esempio, la modifica di
2040 @code{outside-staff-priority} dell'oggetto @code{Hairpin} non avrà alcun
2041 effetto sulla disposizione verticale delle forcelle.  Occorre invece modificare
2042 la proprietà @code{outside-staff-priority} dell'oggetto associato
2043 @code{DynamicLineSpanner}.  Questa sovrascrittura deve essere posta
2044 all'inizio dell'estensore, che potrebbe includere più forcelle e indicazioni dinamiche
2045 tra loro collegate.
2046
2047 @multitable @columnfractions .3 .3 .3
2048 @headitem Oggetto di formattazione
2049   @tab Priorità
2050   @tab Controlla la posizione di:
2051 @item @code{RehearsalMark}
2052   @tab @code{1500}
2053   @tab Numeri di chiamata (e oggetti di testo analoghi)
2054 @item @code{MetronomeMark}
2055   @tab @code{1000}
2056   @tab Indicazioni metronomiche
2057 @item @code{VoltaBracketSpanner}
2058   @tab @code{600}
2059   @tab Delimitatori dei finali alternativi delle ripetizioni
2060 @item @code{TextScript}
2061   @tab @code{450}
2062   @tab Oggetti di testo
2063 @item @code{MultiMeasureRestText}
2064   @tab @code{450}
2065   @tab Testi sopra pause di più misure
2066 @item @code{OttavaBracket}
2067   @tab @code{400}
2068   @tab Estensioni del segno d'ottava
2069 @item @code{TextSpanner}
2070   @tab @code{350}
2071   @tab Estensori del testo
2072 @item @code{DynamicLineSpanner}
2073   @tab @code{250}
2074   @tab Tutte le indicazioni dinamiche
2075 @item @code{BarNumber}
2076   @tab @code{ 100}
2077   @tab Numeri di battuta
2078 @item @code{TrillSpanner}
2079   @tab @code{50}
2080   @tab Linee ondulate del trillo
2081 @end multitable
2082
2083 Ecco un esempio che mostra il posizionamento predefinito di alcuni di
2084 questi oggetti.
2085
2086 @cindex estensore del testo
2087 @cindex segno del cambio d'ottava
2088
2089 @funindex \startTextSpan
2090 @funindex startTextSpan
2091 @funindex \stopTextSpan
2092 @funindex stopTextSpan
2093
2094 @cindex TextSpanner, esempio di sovrascrittura
2095 @cindex proprietà bound-details, esempio
2096 @cindex bound-details, esempio
2097
2098 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2099 % Set details for later Text Spanner
2100 \override TextSpanner.bound-details.left.text
2101     = \markup { \small \bold Slower }
2102 % Place dynamics above staff
2103 \dynamicUp
2104 % Start Ottava Bracket
2105 \ottava #1
2106 c'4 \startTextSpan
2107 % Add Dynamic Text and hairpin
2108 c4\pp\<
2109 c4
2110 % Add Text Script
2111 c4^Text |
2112 c4 c
2113 % Add Dynamic Text and terminate hairpin
2114 c4\ff c \stopTextSpan |
2115 % Stop Ottava Bracket
2116 \ottava #0
2117 c,4 c c c |
2118 @end lilypond
2119
2120 Questo esempio mostra anche come creare gli estensori (spanner) del testo,
2121 ovvero testo con delle linee che si estendono sopra una sezione musicale.
2122 L'estensore si allunga dal comando @code{\startTextSpan} fino al comando
2123 @code{\stopTextSpan} e il formato del testo è definito dal comando
2124 @code{\override TextSpanner}.  Per maggiori dettagli si veda @ruser{Text spanners}.
2125
2126 Mostra anche come si creano le estensioni del segno d'ottava.
2127
2128 @cindex modificare il posizionamento del numero di battuta
2129 @cindex numeri di battuta, modificare il posizionamento
2130 @cindex modificare il posizionamento dell'indicazione metronomica
2131 @cindex indicazione metronomica, modificare il posizionamento
2132 @cindex modificare il posizionamento dei numeri di chiamata
2133 @cindex numeri di chiamata, modificare il posizionamento
2134
2135 Se i valori predefiniti di @code{outside-staff-priority} non producono
2136 il posizionamento desiderato, è possibile sovrascrivere la priorità di
2137 qualsiasi oggetto.  Immaginiamo di voler posizionare l'estensione del segno d'ottava
2138 sotto l'estensore del testo nell'esempio precedente.  Basta controllare la
2139 priorità dell'oggetto @code{OttavaBracket} nella guida al Funzionamento interno
2140 o nelle tabelle precedenti e ridurla a un valore inferiore di quello di un
2141 oggetto @code{TextSpanner}, ricordando che @code{OttavaBracket} è creato
2142 nel contesto @code{Staff}:
2143
2144 @cindex TextSpanner, esempio di sovrascrittura
2145 @cindex proprietà bound-details, esempio
2146 @cindex bound-details, esempio
2147
2148 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2149 % Imposta i dettagli per l'estensione del testo vocale seguente
2150 \override TextSpanner.bound-details.left.text
2151     = \markup { \small \bold Slower }
2152 % Posiziona le indicazione dinamiche sopra il rigo
2153 \dynamicUp
2154 % Posiziona l'estensione del segno d'ottava sotto il testo vocale
2155 \once \override Staff.OttavaBracket.outside-staff-priority = #340
2156 % Inizia l'estensione del segno d'ottava
2157 \ottava #1
2158 c'4 \startTextSpan
2159 % Aggiunge l'indicazione dinamica
2160 c4\pp
2161 % Aggiunge la forcella della dinamica
2162 c4\<
2163 % Aggiunge l'oggetto di testo
2164 c4^Text |
2165 c4 c
2166 % Aggiunge l'indicazione dinamica
2167 c4\ff c \stopTextSpan |
2168 % Termina l'estensione de segno d'ottava
2169 \ottava #0
2170 c,4 c c c |
2171 @end lilypond
2172
2173 Si noti che alcuni di questi oggetti, in particolare i numeri di
2174 battuta, i segni di metronomo e i numeri di chiamata, si trovano nel
2175 contesto @code{Score}; dunque, assicurati di richiamare il contesto
2176 giusto per sovrascriverli.
2177
2178 @cindex legature di portamento e outside-staff-priority
2179 @cindex legature di portamento e articolazioni
2180 @cindex articolazioni e legature di portamento
2181
2182 Le legature di portamento sono classificate come oggetti interni al rigo, anche
2183 se spesso sono poste sopra il rigo, se le note alle quali sono collegate si
2184 trovano nella aprte superiore del pentagramma.  Questo può far sì che gli oggetti esterni al rigo,
2185 come le articolazioni, siano spinti troppo in alto, dato che la legatura viene
2186 posizionata prima.  La proprietà @code{avoid-slur} dell'articolazione
2187 può essere impostata su @code{'inside} per portare l'articolazione
2188 dentro la legatura, ma la proprietà @code{avoid-slur} funziona solo se anche
2189 @code{outside-staff-priority} è impostata su @code{#f}.
2190 Altrimenti, si può impostare la proprietà @code{outside-staff-priority} della
2191 legatura di portamento su un valore numerico, in modo che sia posizionata
2192 insieme ad altri oggetti esterni al rigo in base a quel valore.  Ecco un
2193 esempio che mostra l'effetto dei due metodi:
2194
2195 @lilypond[quote,verbatim,relative=2]
2196 c4( c^\markup { \tiny \sharp } d4.) c8 |
2197 c4(
2198 \once \override TextScript.avoid-slur = #'inside
2199 \once \override TextScript.outside-staff-priority = ##f
2200 c4^\markup { \tiny \sharp } d4.) c8 |
2201 \once \override Slur.outside-staff-priority = #500
2202 c4( c^\markup { \tiny \sharp } d4.) c8 |
2203 @end lilypond
2204
2205 Attraverso la proprietà @code{outside-staff-priority} si può
2206 regolare anche la disposizone verticale di singoli oggetti;
2207 i risultati potrebbero tuttavia risultare non sempre ottimali.  Supponiamo
2208 di voler posizionare @qq{Testo3} sopra @qq{Testo4} nell'esempio
2209 precedente (si veda @ref{Automatic behavior}).
2210 Basta andare a cercare la priorità di @code{TextScript} nella
2211 guida al Funzionamento interno o nelle tabelle precedenti e
2212 aumentare la priorità di @qq{Testo3} assegnando un valore più alto:
2213
2214 @cindex TextScript, esempio di sovrascrittura
2215 @cindex proprietà outside-staff-priority, esempio
2216 @cindex outside-staff-priority, esempio
2217
2218 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2219 c2^"Testo1"
2220 c2^"Testo2" |
2221 \once \override TextScript.outside-staff-priority = #500
2222 c2^"Testo3"
2223 c2^"Testo4" |
2224 @end lilypond
2225
2226 Questo ovviamente pone @qq{Testo3} sopra @qq{Testo4}, ma anche
2227 sopra @qq{Testo2}, mentre @qq{Testo4} si sposta più in basso.  Forse questo
2228 risultato non ci soddisfa:  vorremmo piuttosto collocare
2229 tutti i testi alla stessa distanza dal rigo.  Per riuscirci,
2230 naturalmente, dobbiamo creare più spazio orizzontale tra le note per
2231 far posto al testo.  Lo si può ottenere con il comando
2232 @code{textLengthOn}.
2233
2234 @subheading \textLengthOn
2235
2236 @cindex note, distanziarle insieme al testo
2237
2238 @funindex \textLengthOn
2239 @funindex textLengthOn
2240 @funindex \textLengthOff
2241 @funindex textLengthOff
2242
2243 Per impostazione predefinita, finché si tratta di formattare la musica il
2244 testo prodotto dal comando \markup non occupa uno spazio orizzontale.
2245 Il comando @code{\textLengthOn} inverte questo comportamento e fa sì che
2246 le note si distanzino quanto basti per introdurre il testo:
2247
2248 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2249 \textLengthOn  % Fa sì che le note si distanzino per introdurre il testo
2250 c2^"Text1"
2251 c2^"Text2" |
2252 c2^"Text3"
2253 c2^"Text4" |
2254 @end lilypond
2255
2256 Il comando che ripristina il comportamento predefinito è
2257 @code{\textLengthOff}.  Ricorda che @code{\once} funziona solo insieme
2258 a @code{\override}, @code{\set}, @code{\revert} o @code{\unset},
2259 dunque non si può usare con @code{\textLengthOn}.
2260
2261 @cindex testo a margine, permettere le collisioni
2262
2263 Per parte sua, anche il testo a margine eviterà le note che si estendono sopra il
2264 rigo.  Se lo si vuole evitare, la disposizione automatica in alto può
2265 essere disattivata impostando la priorità su @code{#f}.  Ecco un esempio
2266 che mostra come il testo a margine interagisce con tali note.
2267
2268 @cindex TextScript, esempio di sovrascrittura
2269 @cindex proprietà outside-staff-priority, esempio
2270 @cindex outside-staff-priority, esempio
2271
2272 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2273 % Questo testo è abbastanza corto per starci senza creare collisioni
2274 c2^"Tes" c'' |
2275 R1 |
2276
2277 % Questo è troppo lungo per starci, quindi è spostato più in alto
2278 c,,2^"Testo" c'' |
2279 R1 |
2280
2281 % Disattiva l'elusione delle collisioni
2282 \once \override TextScript.outside-staff-priority = ##f
2283 c,,2^"Testo Lungo   " c'' |
2284 R1 |
2285
2286 % Disattiva l'elusione delle collisioni
2287 \once \override TextScript.outside-staff-priority = ##f
2288 \textLengthOn        % e attiva textLengthOn
2289 c,,2^"Testo Lungo   "  % Gli spazi finali vengono rispettati
2290 c''2 |
2291 @end lilypond
2292
2293
2294 @subheading Dinamica
2295
2296 @cindex modificare il posizionamento della dinamica
2297 @cindex dinamica, modificare il posizionamento
2298
2299 Le indicazioni dinamiche sono di norma poste sotto il
2300 rigo, ma possono essere collocati al di sopra del pentagramma col comando @code{\dynamicUp}.
2301 Vengono posizionati verticalmente rispetto alla figura cui
2302 si riferiscono e fluttuano sopra (o sotto) tutti gli oggetti
2303 interni al rigo come le legature di fraseggio e i numeri di battuta.
2304 Si ottengono risultati abbastanza accettabili, come dimostra
2305 questo esempio:
2306
2307 @lilypond[quote,fragment,ragged-right,verbatim,relative=1]
2308 \clef "bass"
2309 \key aes \major
2310 \time 9/8
2311 \dynamicUp
2312 bes4.~\f\< \( bes4 bes8 des4\ff\> c16 bes\! |
2313 ees,2.~\)\mf ees4 r8 |
2314 @end lilypond
2315
2316 Tuttavia, se le note e le loro dinamiche sono molto vicine,
2317 la disposizione automatica eviterà le collisioni spostando
2318 più all'esterno i segni di dinamica successivi.  Questo
2319 potrebbe non essere però il posizionamento migliore, come mostra
2320 questo esempio piuttosto improbabile:
2321
2322 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2323 \dynamicUp
2324 a4\f b\mf c\mp b\p
2325 @end lilypond
2326
2327 @noindent
2328 Se si dovesse presentare una situazione simile in un @q{vero} brano musicale,
2329 converrebbe distanziare un po' di più le note, in modo che i segni di dinamica
2330 possano essere tutti collocati alla stessa distanza verticale dal rigo.  Abbiamo
2331 potuto farlo per il testo a margine usando il comando @code{\textLengthOn},
2332 ma non esiste un comando equivalente per i segni di dinamica.  Dunque
2333 dovremo scoprire come farlo usando i comandi @code{\override}.
2334
2335 @subheading Estensione dei grob
2336
2337 @cindex estensione dei grob
2338 @cindex grob, estensione
2339
2340 Dobbiamo innanzitutto sapere come i grob occupano lo spazio.  Tutti i grob
2341 hanno al loro interno un punto di riferimento che viene usato
2342 per posizionarli in modo relativo all'oggetto genitore da cui derivano.  Questo
2343 punto nel grob viene poi disposto a una distanza orizzontale,
2344 @code{X-offset}, e a una distanza verticale, @code{Y-offset}, dall'oggetto
2345 genitore.  L'estensione (@emph{extent}) orizzontale dell'oggetto è data da una
2346 coppia di numeri, @code{X-extent}, che indica dove si trovano i margini
2347 sinistro e destro rispetto al punto di riferimento.  L'ampiezza verticale
2348 è ugualmente definita da una coppia di numeri, @code{Y-extent}.
2349 Queste proprietà appartengono a tutti i grob che supportano l'interfaccia
2350 @code{grob-interface}.
2351
2352 @cindex @code{extra-spacing-width}
2353
2354 Per impostazione predefinita, gli oggetti esterni al rigo presentano estensione
2355 pari a zero, in modo da potersi sovrapporre nella direzione orizzontale.
2356 Ciò si ottiene con un trucco, ovvero aggiungendo infinito all'estensione
2357 sinistra e infinito negativo a quella destra, impostando il valore di
2358 @code{extra-spacing-width} su @code{'(+inf.0 . -inf.0)}.  Dunque, per
2359 assicurarci che non si sovrappongano nella direzione orizzontale, dobbiamo
2360 sovrascrivere il valore di @code{extra-spacing-width} e impostarlo su
2361 @code{'(0 . 0)} in modo da inserire una larghezza vera e propria.  Ecco il
2362 comando che lo fa sul testo della dinamica:
2363
2364 @example
2365 \override DynamicText.extra-spacing-width = #'(0 . 0)
2366 @end example
2367
2368 @noindent
2369 Vediamo se funziona nell'esempio precedente:
2370
2371 @cindex DynamicText, esempio di sovrascrittura
2372 @cindex proprietà extra-spacing-width, esempio
2373 @cindex extra-spacing-width, esempio
2374
2375 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2376 \dynamicUp
2377 \override DynamicText.extra-spacing-width = #'(0 . 0)
2378 a4\f b\mf c\mp b\p |
2379 @end lilypond
2380
2381 @noindent
2382 Sicuramente ha impedito un'errata disposizione delle indicazioni
2383 dinamiche, ma restano due problemi.  Le dinamiche dovrebbero
2384 essere un po' più distanziate; sarebbe inoltre opportuno collocarle
2385 tutte alla stessa distanza dal rigo.
2386 Il primo problema è facilmente risolvibile.  Invece di
2387 impostare @code{extra-spacing-width} su zero, possiamo
2388 aggiungere un po' di spazio.  L'unità è lo spazio tra due linee
2389 del rigo, quindi se spostiamo il margine sinistro mezza unità
2390 a sinistra e il margine destro mezza unità a destra dovrebbe
2391 funzionare:
2392
2393 @cindex DynamicText, esempio di sovrascrittura
2394 @cindex proprietà extra-spacing-width, esempio
2395 @cindex extra-spacing-width, esempio
2396
2397 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2398 \dynamicUp
2399 % Aumenta la larghezza di 1 spazio rigo
2400 \override DynamicText.extra-spacing-width = #'(-0.5 . 0.5)
2401 a4\f b\mf c\mp b\p
2402 @end lilypond
2403
2404 @noindent
2405 L'aspetto è migliore, ma sarebbe preferibile avere i segni di dinamica
2406 allineati alla stessa linea di base invece di spostarsi su e giù seguendo la posizione delle note.
2407 La proprietà che permette di ottenere tale risultato è @code{staff-padding} ed è trattata
2408 nella sezione seguente.
2409
2410
2411 @node Collisioni tra oggetti
2412 @section Collisioni tra oggetti
2413 @translationof Collisions of objects
2414
2415 @menu
2416 * Spostare gli oggetti::
2417 * Correggere la sovrapposizione di elementi della notazione::
2418 * Esempio musicale::
2419 @end menu
2420
2421 @node Spostare gli oggetti
2422 @subsection Spostare gli oggetti
2423 @translationof Moving objects
2424
2425 @cindex spostare gli oggetti che si sovrappongono
2426 @cindex spostare gli oggetti che collidono
2427 @cindex spostare i grob che collidono
2428 @cindex oggetti, spostarli se collidono
2429 @cindex grob, spostarli se collidono
2430
2431 Per quanto possa apparire sorprendente, LilyPond non è perfetto.  Alcuni elementi
2432 della notazione possono sovrapporsi.  Si tratta di un caso spiacevole, anche se in
2433 realtà piuttosto raro.  Di solito l'esigenza di spostare gli
2434 oggetti dipende da motivi di chiarezza o da ragioni estetiche: gli elementi
2435 possono ottenere un aspetto migliore con un po' più o un po' meno
2436 spazio intorno.
2437
2438 Esistono tre principali approcci per risolvere la sovrapposizione
2439 degli elementi della notazione.  Vediamoli nel seguente ordine:
2440
2441 @enumerate
2442 @item
2443 Si può cambiare la @strong{direzione} di uno degli oggetti che si
2444 sovrappongono usando i comandi predefiniti elencati prima, in riferimento agli
2445 oggetti interni al rigo (vedi @ref{Within-staff objects}).
2446 In questo modo si possono riposizionare facilmente gambi, legature di
2447 portamento e di valore, travature, segni di dinamica, testo e gruppi
2448 irregolari.  La limitazione è che si tratta di una scelta circoscritta a due sole
2449 posizioni, nessuna delle quali potrebbe essere appropriata.
2450
2451 @item
2452 Le @strong{proprietà degli oggetti}, che LilyPond usa quando dispone
2453 gli oggetti di formattazione, si possono modificare con @code{\override}.  I
2454 vantaggi dell'intervenire su questo tipo di proprietà sono che (a)
2455 gli altri oggetti saranno spostati automaticamente se è necessario far
2456 spazio, e (b) ogni sovrascrittura può essere applicata a tutte le occorrenze
2457 di oggetti dello stesso tipo.  Tali proprietà sono:
2458
2459 @itemize
2460
2461 @item
2462 @code{direction}
2463
2464 Questa è già stata trattata in dettaglio (vedi
2465 @ref{Within-staff objects}).
2466
2467 @item
2468 @code{padding}, @code{right-padding}, @code{staff-padding}
2469
2470 @cindex distanza
2471 @cindex spaziatura
2472 @cindex proprietà padding
2473 @cindex proprietà right-padding
2474 @cindex proprietà staff-padding
2475 @cindex padding, proprietà
2476 @cindex right-padding, proprietà
2477 @cindex staff-padding, proprietà
2478
2479 Quando un oggetto viene posizionato, il valore della sua proprietà
2480 @code{padding} specifica lo spazio intermedio da lasciare tra l'oggetto stesso
2481 e il bordo più vicino di quello accanto a cui si trova.  Nota che si
2482 tratta del valore di @code{padding} dell'oggetto che @strong{si sta
2483 posizionando}, mentre quello dell'oggetto già posizionato viene
2484 ignorato.  Gli spazi specificati da @code{padding} possono essere
2485 applicati a tutti gli oggetti che supportano l'interfaccia
2486 @code{side-position-interface}.
2487
2488 Invece che da @code{padding}, la disposizione dei gruppi di alterazioni
2489 è regolata da @code{right-padding}.  Questa proprietà appartiene all'oggetto
2490 @code{AccidentalPlacement} che si trova nel contesto @strong{Staff}.  Il
2491 processo di formattazione della partitura crea per prime le teste di
2492 nota e poi, se presenti, aggiunge le alterazioni alla sinistra delle
2493 teste di nota usando la proprietà @code{right-padding} per stabilire
2494 la distanza tra le teste e le singole alterazioni.
2495 Dunque, solo la proprietà @code{right-padding} dell'oggetto @code{AccidentalPlacement}
2496 produce un effetto sul posizionamento delle alterazioni.
2497
2498 La proprietà @code{staff-padding} è strettamente connessa alla proprietà
2499 @code{padding}: @code{padding} regola la quantità minima di spazio tra
2500 qualsiasi oggetto che supporti l'interfaccia @code{side-position-interface} e
2501 quello più vicino (solitamente, la nota o le linee del rigo); @code{staff-padding}
2502 si applica solo a quegli oggetti che stanno sempre fuori dal rigo e regola
2503 la quantità minima di spazio da inserire tra l'oggetto e il rigo.  Nota che
2504 @code{staff-padding} non ha alcun effetto sugli oggetti disposti relativamente
2505 alla nota invece che al rigo, anche se può essere sovrascritto senza generare
2506 degli errori per tali oggetti; quindi viene semplicemente ignorata.
2507
2508 Per scoprire quale proprietà padding è richiesta per l'oggetto che
2509 desideri riposizionare, devi tornare alla guida del Funzionamento
2510 interno e cercare le proprietà dell'oggetto.  Presta attenzione al fatto
2511 che le proprietà padding potrebbero non trovarsi nell'oggetto più
2512 ovvio; in tal caso devi cercare negli oggetti simili.
2513
2514 I valori delle proprietà padding sono misurati in spazi del rigo.  Il valore
2515 predefinito della maggior parte degli oggetti è circa 1.0 o meno (a seconda
2516 dell'oggetto).  Può essere sovrascritto per ottenere una distanza maggiore
2517 o minore.
2518
2519 @item
2520 @code{self-alignment-X}
2521
2522 @cindex proprietà self-alignment-X
2523 @cindex self-alignment-X, proprietà
2524
2525 Questa proprietà serve ad allineare l'oggetto a sinistra, a destra o
2526 al centro rispetto al punto di riferimento dell'oggetto genitore.
2527 Si può usare con tutti gli oggetti che supportano l'interfaccia
2528 @code{self-alignment-interface}.  Generalmente si tratta di oggetti
2529 che contengono testo.  I valori sono @code{LEFT} (sinistra), @code{RIGHT}
2530 (destra) o @code{CENTER} (centro).  Altrimenti, è possibile definire un valore
2531 numerico compreso tra @w{@code{-1}} e @code{+1}, dove @w{@code{-1}} indica
2532 allineamento a sinistra e @code{+1} allineamento a destra, mentre gli altri
2533 numeri spostano progressivamente il testo dall'allineamento a sinistra
2534 all'allineamento a destra.  È possibile specificare valori numerici maggiori
2535 di @code{1}, per spostare il testo ancora più a sinistra, o valori inferiori
2536 a @w{@code{-1}}, per spostarlo ancora più a destra.  Ogni modifica di @code{1}
2537 nel valore corrisponde a uno spostamento pari alla metà della lunghezza
2538 del testo.
2539
2540 @item
2541 @code{extra-spacing-width}
2542
2543 @cindex proprietà extra-spacing-width
2544 @cindex extra-spacing-width, proprietà
2545
2546 Questa proprietà è disponibile per tutti gli oggetti che supportano
2547 l'interfaccia @code{item-interface}. Accetta due numeri: il primo è
2548 aggiunto all'estensione più a sinistra, il secondo a quella più a
2549 destra.  I numeri negativi spostano il bordo verso sinistra, quelli
2550 positivi verso destra: quindi, per allargare un oggetto il primo
2551 numero deve essere negativo, il secondo deve essere positivo.
2552 Nota che non tutti gli oggetti rispettano entrambi i numeri.  Ad
2553 esempio, l'oggetto @code{Accidental} considera soltanto il primo
2554 numero (bordo sinistro).
2555
2556 @item
2557 @code{staff-position}
2558
2559 @cindex proprietà staff-position
2560 @cindex staff-position, proprietà
2561
2562 @code{staff-position} è una proprietà dell'interfaccia
2563 @code{staff-symbol-referencer-interface}, supportata dagli oggetti
2564 che vengono posizionati in relazione al rigo.  Specifica in unità
2565 di mezzo spazio di rigo la posizione verticale dell'oggetto rispetto
2566 alla linea centrale del rigo stesso.  È utile per risolvere collisioni
2567 tra oggetti come le pause di più misure, le legature di valore e le
2568 note in voci diverse.
2569
2570 @item
2571 @code{force-hshift}
2572
2573 @cindex proprietà force-hshift
2574 @cindex force-hshift, proprietà
2575
2576 Le note ravvicinate di un accordo o quelle simultanee appartenenti
2577 a voci diverse sono disposte su due e talvolta più colonne per
2578 impedire la sovrapposizione delle teste.  Tali colonne si chiamano
2579 colonne di note (@emph{note columns}) e l'oggetto che provvede a crearle
2580 si chiama @code{NoteColumn}.
2581
2582 La proprietà @code{force-hshift} appartiene a @code{NoteColumn}
2583 (più precisamente all'interfaccia @code{note-column-interface}).  Modificandola
2584 è possibile spostare la colonna di note proporzionalmente,
2585 assumendo come unità la larghezza della testa della nota nella voce superiore.  Si usa
2586 in situazioni complesse in cui i normali comandi @code{\shiftOn} (vedi
2587 @ref{Explicitly instantiating voices}) non risolvono adeguatamente le collisioni tra le
2588 note.  Per questo scopo, è preferibile alla proprietà @code{extra-offset}
2589 perché non c'è bisogno di trovare la giusta distanza in spazi di rigo e
2590 lo spostamento delle note dentro o fuori da una @code{NoteColumn}
2591 si ripercuote su altre azioni, come il congiungimento delle teste delle note.
2592
2593 @end itemize
2594
2595 @item
2596 Infine, se i metodi precedenti non funzionano, si possono riposizionare
2597 verticalmente gli oggetti rispetto alla linea centrale del rigo
2598 oppure collocarli a una qualsiasi distanza rispetto a una nuova
2599 posizione.  Gli svantaggi di questo metodo consistono nel fatto che i corretti
2600 valori per il riposizionamento debbano essere trovati per tentativi e per ogni
2601 singolo oggetto; inoltre, dato che lo spostamento avviene dopo che LilyPond
2602 ha posizionato tutti gli altri oggetti, spetta all'utente evitare le
2603 eventuali collisioni.  La principale
2604 difficoltà che questo approccio comporta, però, è che i valori di riposizionamento
2605 potrebbero dover essere ricalcolati se la musica venisse successivamente
2606 modificata.  Le proprietà che si possono usare con questo tipo di
2607 riposizionamento manuale sono:
2608
2609 @table @code
2610 @item extra-offset
2611
2612 @cindex proprietà extra-offset
2613 @cindex extra-offset, proprietà
2614
2615 Questa proprietà si applica a qualsiasi oggetto di formattazione che supporta
2616 l'interfaccia @code{grob-interface}.  Accetta come valore una coppia di numeri
2617 che specificano l'ulteriore spostamento nelle direzioni orizzontale e verticale.
2618 I numeri negativi spostano l'oggetto a sinistra o in basso.  Le unità sono
2619 gli spazi del rigo.  Questo spostamento aggiuntivo è applicato dopo la formattazione
2620 degli oggetti, dunque gli oggetti possono essere riposizionati ovunque senza
2621 incidere sugli altri.
2622
2623 @item positions
2624
2625 @cindex proprietà positions
2626 @cindex positions, proprietà
2627
2628 Questa proprietà è utile specialmente per correggere manualmente l'inclinazione e
2629 l'altezza di travature, legature di portamento e graffette dei gruppi irregolari.  Accetta
2630 come valore una coppia di numeri, che specifica la posizione dei bordi sinistro
2631 e destro della travatura, della legatura, etc., rispetto alla linea centrale
2632 del rigo.  L'unità di misura è lo spazio del rigo.  Considera, però,
2633 che le legature di portamento e di frase non possono essere riposizionate
2634 del tutto arbitrariamente.  LilyPond, infatti, genera prima una lista
2635 delle possibili posizioni per la legatura e poi determina la legatura che
2636 @qq{ritiene migliore}.  Se la proprietà @code{positions} è stata sovrascritta,
2637 viene scelta dalla lista la legatura più vicina alle posizioni richieste.
2638 @end table
2639
2640 @end enumerate
2641
2642 Alcuni oggetti potrebbero non disporre di tutte queste proprietà.
2643 Occorre andare a vedere nella guida al Funzionamento interno
2644 quali proprietà siano disponibili per l'oggetto che si intende
2645 modificare.
2646
2647 Segue una lista degli oggetti che hanno la maggiore probabilità
2648 di essere coinvolti in collisioni, insieme al nome dell'oggetto
2649 che deve essere cercato nella guida al Funzionamento interno per
2650 poter sapere quali proprietà si possono usare per spostarlo.
2651
2652 @multitable @columnfractions .5 .5
2653 @headitem Tipo di oggetto            @tab Nome dell'oggetto
2654 @item Articolazioni                  @tab @code{Script}
2655 @item Travature                      @tab @code{Beam}
2656 @item Dinamiche (verticalmente)      @tab @code{DynamicLineSpanner}
2657 @item Dinamiche (orizzontalmente)    @tab @code{DynamicText}
2658 @item Diteggiature                   @tab @code{Fingering}
2659 @item Numeri di chiamata / Testi     @tab @code{RehearsalMark}
2660 @item Legature di portamento         @tab @code{Slur}
2661 @item Testi, ovvero @code{^"testo"}  @tab @code{TextScript}
2662 @item Legature di valore             @tab @code{Tie}
2663 @item Gruppi irregolari              @tab @code{TupletBracket}
2664 @end multitable
2665
2666
2667 @node Correggere la sovrapposizione di elementi della notazione
2668 @subsection Correggere la sovrapposizione di elementi della notazione
2669 @translationof Fixing overlapping notation
2670
2671 Vediamo ora come le proprietà presentate nella sezione precedente possano
2672 aiutare a risolvere la sovrapposizione degli elementi della notazione.
2673
2674 @subheading proprietà padding
2675
2676 @cindex padding
2677 @cindex spaziatura
2678 @cindex correggere la sovrapposizione di elementi della notazione
2679 @cindex sovrapposizione degli elementi della notazione
2680
2681 La proprietà @code{padding} serve a aumentare (o diminuire)
2682 la distanza tra i simboli che si trovano sopra o sotto le
2683 note.
2684
2685 @cindex Script, esempio di sovrascrittura
2686 @cindex proprietà padding, esempio
2687 @cindex padding, esempio
2688
2689 @lilypond[quote,fragment,relative=1,verbatim]
2690 c2\fermata
2691 \override Script.padding = #3
2692 b2\fermata
2693 @end lilypond
2694
2695 @cindex MetronomeMark, esempio di sovrascrittura
2696 @cindex proprietà padding, esempio
2697 @cindex padding, esempio
2698
2699 @lilypond[quote,fragment,relative=1,verbatim]
2700 % Questo non funziona, vedi sotto
2701 \override MetronomeMark.padding = #3
2702 \tempo 4 = 120
2703 c1 |
2704 % Questo funziona
2705 \override Score.MetronomeMark.padding = #3
2706 \tempo 4 = 80
2707 d1 |
2708 @end lilypond
2709
2710 Nota nel secondo esempio come è importante sapere quale contesto
2711 gestisce un certo oggetto.  Dato che l'oggetto @code{MetronomeMark}
2712 è regolato dal contesto @code{Score}, le modifiche della proprietà
2713 nel contesto @code{Voice} non vengono prese in considerazione.  Per
2714 approfondire l'argomento si veda @ruser{Modifying properties}.
2715
2716 Se la proprietà @code{padding} di un oggetto viene aumentata quando
2717 quell'oggetto si trova insieme ad altri oggetti disposti secondo la
2718 loro proprietà @code{outside-staff-priority}, allora si sposteranno
2719 quell'oggetto e tutti gli oggetti esterni a esso.
2720
2721
2722 @subheading right-padding
2723
2724 @cindex proprietà right-padding
2725 @cindex right-padding, proprietà
2726
2727 La proprietà @code{right-padding} agisce sullo spazio tra l'alterazione
2728 e la nota corrispondente.  Non è una necessità frequente, ma la
2729 spaziatura predefinita potrebbe risultare errata nei casi di alcuni
2730 speciali glifi delle alterazioni usati nella musica microtonale.
2731 Questi si inseriscono sovrascrivendo lo stampo (stencil) dell'alterazione
2732 con un segno che contenga il simbolo desiderato:
2733
2734 @cindex Accidental, esempio di sovrascrittura
2735 @cindex proprietà text, esempio
2736 @cindex text, esempio
2737 @cindex proprietà stencil, esempio
2738 @cindex stencil, esempio
2739 @cindex AccidentalPlacement, esempio di sovrascrittura
2740 @cindex proprietà right-padding, esempio
2741 @cindex right-padding, esempio
2742
2743 @lilypond[quote,ragged-right,verbatim]
2744 sesquisharp = \markup { \sesquisharp }
2745 \relative c'' {
2746   c4
2747   % Mostra un triesis (alterazione ascendente di tre quarti di tono) ma lo spazio è troppo stretto
2748   \once \override Accidental.stencil = #ly:text-interface::print
2749   \once \override Accidental.text = #sesquisharp
2750   cis4 c
2751   % Ecco come migliorare lo spazio
2752   \once \override Score.AccidentalPlacement.right-padding = #0.6
2753   \once \override Accidental.stencil = #ly:text-interface::print
2754   \once \override Accidental.text = #sesquisharp
2755   cis4 |
2756 }
2757 @end lilypond
2758
2759 @noindent
2760 Siamo costretti a usare una sovrascrittura dello stampo dell'alterazione che
2761 verrà spiegata successivamente.  Il tipo di stampo deve essere una
2762 procedura e in questo esempio è stato modificato per mostrare i
2763 contenuti della proprietà @code{text} dell'oggetto @code{Accidental}, che
2764 è esso stesso impostato sul segno di triesis.  Poi
2765 questo segno viene distanziato dalla testa di nota grazie alla sovrascrittura
2766 di @code{right-padding}.
2767
2768 @noindent
2769
2770 @subheading proprietà staff-padding
2771
2772 @cindex allineare gli oggetti a una base
2773 @cindex oggetti, allinearli a una base
2774
2775 @code{staff-padding} serve ad allineare gli oggetti come i segni di
2776 dinamica lungo una linea di base a una certa altezza fissa sopra il
2777 rigo, invece che a un'altezza dipendente dalla posizione della nota al
2778 quale sono collegati.  Non è una proprietà di @code{DynamicText} bensì
2779 di @code{DynamicLineSpanner}, perché la base deve essere applicata
2780 ugualmente a @strong{tutti} i segni dinamica, compresi quelli creati
2781 come estensori.  Ecco come allineare i segni di dinamica nell'esempio
2782 preso dalla sezione precedente:
2783
2784 @cindex DynamicText, esempio di sovrascrittura
2785 @cindex proprietà extra-spacing-width, esempio
2786 @cindex extra-spacing-width, esempio
2787 @cindex DynamicLineSpanner, esempio di sovrascrittura
2788 @cindex proprietà staff-padding, esempio
2789 @cindex staff-padding, esempio
2790
2791 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
2792 \dynamicUp
2793 % Aumenta la larghezza di 1 unità
2794 \override DynamicText.extra-spacing-width = #'(-0.5 . 0.5)
2795 % Allinea le dinamiche alla base posta 2 unità sopra il rigo
2796 \override DynamicLineSpanner.staff-padding = #2
2797 a4\f b\mf c\mp b\p
2798 @end lilypond
2799
2800
2801 @subheading proprietà self-alignment-X
2802
2803 L'esempio successivo mostra come questa proprietà possa risolvere la
2804 collisione di un numero di corda con un gambo allineando il bordo
2805 destro del numero al punto di riferimento della nota a cui si riferisce:
2806
2807 @cindex StringNumber, esempio di sovrascrittura
2808 @cindex proprietà self-alignment-X, esempio
2809 @cindex self-alignment-X, esempio
2810
2811 @lilypond[quote,fragment,ragged-right,verbatim,relative=3]
2812 \voiceOne
2813 <a\2>
2814 \once \override StringNumber.self-alignment-X = #RIGHT
2815 <a\2>
2816 @end lilypond
2817
2818 @subheading proprietà staff-position
2819
2820 @cindex collisione tra oggetti all'interno del rigo
2821
2822 Le pause d'intero di una voce possono entrare in collisione con le note
2823 di un'altra.  Dal momento che queste pause sono centrate rispetto
2824 alle stanghette della battuta, calcolare quali altre note potrebbero
2825 sovrapporsi richiederebbe un notevole grado d'elaborazione, dato che l'attuale
2826 gestione delle collisioni tra note e tra note e pause riguarda solo
2827 le note e le pause simultanee.  Ecco un esempio
2828 di collisione di questo tipo:
2829
2830 @lilypond[quote,verbatim,fragment,ragged-right, relative=1]
2831 << { c4 c c c } \\ { R1 } >>
2832 @end lilypond
2833
2834 In questo caso la soluzione migliore è spostare in basso la pausa d'intero, poiché
2835 si trova nella seconda voce.  In @code{\voiceTwo} (ovvero nella seconda
2836 voce di un costrutto @code{<<@{...@} \\ @{...@}>>}) il valore predefinito
2837 di @code{staff-position} è -4 per la pausa multipla (MultiMeasureRest), quindi
2838 dobbiamo spostarla più in basso, ad esempio di altri quattro semispazi del
2839 rigo; il nuovo valore sarà @w{@code{-8}}.
2840
2841 @cindex MultiMeasureRest, esempio di sovrascrittura
2842 @cindex proprietà staff-position, esempio
2843 @cindex staff-position, esempio
2844
2845 @lilypond[quote,verbatim,fragment,ragged-right, relative=1]
2846 <<
2847   { c4 c c c }
2848   \\
2849   \override MultiMeasureRest.staff-position = #-8
2850   { R1 }
2851 >>
2852 @end lilypond
2853
2854 Questa soluzione è preferibile all'uso di @code{extra-offset}, perché
2855 il taglio addizionale sopra la pausa è inserito automaticamente.
2856
2857 @subheading proprietà extra-offset
2858
2859 @cindex posizionare gli oggetti
2860 @cindex posizionare i grob
2861 @cindex oggetti, posizionarli
2862 @cindex grob, posizionarli
2863
2864 La proprietà @code{extra-offset} fornisce un controllo completo
2865 sul posizionamento di un oggetto sia in orizzontale che in verticale.
2866
2867 Nell'esempio seguente, la seconda diteggiatura viene spostata un po' a
2868 sinistra e in basso di 1.8 spazi rigo:
2869
2870 @cindex Fingering, esempio di sovrascrittura
2871 @cindex proprietà extra-offset, esempio
2872 @cindex extra-offset, esempio
2873
2874 @lilypond[quote,fragment,relative=1,verbatim]
2875 \stemUp
2876 f4-5
2877 \once \override Fingering.extra-offset = #'(-0.3 . -1.8)
2878 f4-5
2879 @end lilypond
2880
2881
2882 @subheading proprietà positions
2883
2884 @cindex controllo manuale di graffette dei gruppi irregolari, travature, legature di portamento e di frase
2885 @cindex travature dei gruppi irregolari, controllo manuale
2886 @cindex legature di portamento, controllo manuale
2887 @cindex legature di frase, controllo manuale
2888 @cindex travature, controllo manuale
2889
2890 La proprietà @code{positions} permette di controllare manualmente la posizione e
2891 l'inclinazione delle graffette dei gruppi irregolari, delle legature di portamento e di
2892 frase e delle travature.  Ecco un esempio di una legatura di frase
2893 dall'aspetto orribile, dovuto al suo tentativo di evitare la legatura
2894 di portamento sull'acciaccatura.
2895
2896 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
2897 r4 \acciaccatura e8\( d8 c~ c d c d\)
2898 @end lilypond
2899
2900 @noindent
2901 Potremmo semplicemente spostare la legatura di frase sopra le note:
2902
2903 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
2904 r4
2905 \phrasingSlurUp
2906 \acciaccatura e8\( d8 c~ c d c d\)
2907 @end lilypond
2908
2909 @noindent
2910 Questa sarebbe la soluzione migliore.  Se, invece, per qualche motivo non
2911 fosse possibile, l'alternativa sarebbe spostare un po' più in basso l'estremità
2912 sinistra della legatura di frase tramite la proprietà @code{positions}.  Questo
2913 risolve anche il problema della forma sgraziata.
2914
2915 @cindex PhrasingSlur, esempio di sovrascrittura
2916 @cindex proprietà positions, esempio
2917 @cindex positions, esempio
2918
2919 @lilypond[quote,verbatim,fragment,ragged-right,relative=1]
2920 r4
2921 \once \override PhrasingSlur.positions = #'(-4 . -3)
2922 \acciaccatura e8\( d8 c~ c d c d\)
2923 @end lilypond
2924
2925 Ecco un altro esempio.  Vediamo che le travature collidono
2926 con le legature di valore:
2927
2928 @lilypond[quote,verbatim,fragment,ragged-right]
2929 {
2930   \time 4/2
2931   <<
2932     { c'1 ~ c'2. e'8 f' }
2933     \\
2934     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
2935   >>
2936   <<
2937     { c'1 ~ c'2. e'8 f' }
2938     \\
2939     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
2940   >>
2941 }
2942 @end lilypond
2943
2944 @noindent
2945 Si può risolvere spostando manualmente in su entrambi gli estremi della
2946 travatura dalla loro posizione di 1.81 spazi rigo sotto la linea
2947 centrale a, per esempio, 1:
2948
2949 @cindex Beam, esempio di sovrascrittura
2950 @cindex proprietà positions, esempio
2951 @cindex positions, esempio
2952
2953 @lilypond[quote,verbatim,fragment,ragged-right]
2954 {
2955   \time 4/2
2956   <<
2957     { c'1 ~ c'2. e'8 f' }
2958     \\
2959     {
2960       \override Beam.positions = #'(-1 . -1)
2961       e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g''
2962     }
2963   >>
2964   <<
2965     { c'1 ~ c'2. e'8 f' }
2966     \\
2967     { e''8 e'' e'' e''  e'' e'' e'' e''  f''2 g'' }
2968   >>
2969 }
2970 @end lilypond
2971
2972 @noindent
2973 Come vedi, la sovrascrittura si applica anche alla prima voce della seconda
2974 misura di otto note, ma a nessuna delle travature nella seconda voce.
2975
2976 @subheading proprietà force-hshift
2977
2978 Possiamo vedere ora come applicare le correzioni finali all'esempio di Chopin
2979 introdotto alla fine del paragrafo @ref{I'm hearing Voices}, che avevamo
2980 lasciato così:
2981
2982 @lilypond[quote,verbatim,fragment,ragged-right]
2983 \new Staff \relative c'' {
2984   \key aes \major
2985   <<
2986     { c2 aes4. bes8 }
2987     \\
2988     { <ees, c>2 des }
2989     \\
2990     \\
2991     { aes'2 f4 fes }
2992   >> |
2993   <c ees aes c>1 |
2994 }
2995 @end lilypond
2996
2997 @noindent
2998 La nota interna del primo accordo (ovvero il La bemolle della quarta
2999 voce) non deve essere allontanata dalla colonna della nota più
3000 alta.  Per correggerlo impostiamo @code{force-hshift}, una proprietà
3001 di @code{NoteColumn}, su zero.
3002
3003 Nel secondo accordo preferiamo che il Fa sia allineato al La bemolle e che
3004 la nota più grave sia posizionata leggermente più a destra, in modo da
3005 evitare la collisione dei gambi.  Per farlo dobbiamo impostare
3006 @code{force-hshift} nella colonna (@code{NoteColumn}) del Re bemolle
3007 grave in modo che si sposti a destra di mezzo spazio di rigo.
3008
3009 Ecco il risultato finale:
3010
3011 @cindex NoteColumn, esempio di sovrascrittura
3012 @cindex proprietà force-hshift, esempio
3013 @cindex force-hshift, esempio
3014
3015 @lilypond[quote,verbatim,fragment,ragged-right]
3016 \new Staff \relative c'' {
3017   \key aes \major
3018   <<
3019     { c2 aes4. bes8 }
3020     \\
3021     {
3022       <ees, c>2
3023       \once \override NoteColumn.force-hshift = #0.5
3024       des2
3025     }
3026     \\
3027     \\
3028     {
3029       \override NoteColumn.force-hshift = #0
3030       aes'2 f4 fes
3031     }
3032   >> |
3033   <c ees aes c>1 |
3034 }
3035 @end lilypond
3036
3037
3038 @node Esempio musicale
3039 @subsection Esempio musicale
3040 @translationof Real music example
3041
3042 Completiamo questa sezione delle modifiche (@emph{tweak}) mostrando passo passo
3043 come affrontare un esempio complesso che necessita varie modifiche per
3044 poter raggiungere l'aspetto desiderato.  L'esempio è stato scelto
3045 appositamente per mostrare come usare la guida alla Notazione per
3046 risolvere problemi inusuali di notazione.  Non rispecchia l'uso
3047 abituale di LilyPond, quindi non farti scoraggiare da queste difficoltà!
3048 Per fortuna problemi come questi sono molto rari!
3049
3050 L'esempio è tratto dalla Première Ballade op. 23 di Chopin e va
3051 dalla battuta 6 alla 9, la transizione dal Lento iniziale al Moderato.
3052 Vediamo prima come vogliamo che l'output appaia; per evitare di
3053 complicare troppo l'esempio abbiamo però tolto le dinamiche, le diteggiature
3054 e le pedalizzazioni.
3055
3056 @c The following should appear as music without code
3057 @c This example should not be indexed
3058 @c line-width ensures no break
3059 @lilypond[quote,ragged-right,line-width=6\in]
3060 rhMusic = \relative c'' {
3061   \new Voice {
3062     r2 c4.\( g8 |
3063     \once \override Tie.staff-position = #3.5
3064     bes1~ |
3065     \bar "||"
3066     \time 6/4
3067     \mergeDifferentlyHeadedOn
3068     \mergeDifferentlyDottedOn
3069     bes2.^\markup { \bold "Moderato" } r8
3070     <<
3071       { c,8 d fis bes a }
3072       \new Voice {
3073         \voiceTwo
3074         c,8~
3075         % Reposition the c2 to the right of the merged note
3076         \once \override NoteColumn.force-hshift = #1.0
3077         % Move the c2 out of the main note column
3078         % so the merge will work
3079         \shiftOnn
3080         c2
3081       }
3082       \new Voice {
3083         \voiceThree
3084         s8
3085         % Stem on the d2 must be down to permit merging
3086         \stemDown
3087         % Stem on the d2 should be invisible
3088         \tweak Stem.transparent ##t
3089         \tweak Flag.transparent ##t
3090         d2
3091       }
3092       \new Voice {
3093         \voiceFour
3094         s4 fis4.
3095       }
3096     >> |
3097     \mergeDifferentlyHeadedOff
3098     \mergeDifferentlyDottedOff
3099     g2.\)
3100   }
3101 }
3102
3103 lhMusic = \relative c' {
3104   r2 <c g ees>2( |
3105   <d g, d>1)\arpeggio |
3106   r2. d,,4 r4 r |
3107   r4
3108 }
3109
3110 \score {
3111   \new PianoStaff <<
3112     \new Staff = "RH"  <<
3113       \key g \minor
3114       \rhMusic
3115     >>
3116     \new Staff = "LH" <<
3117       \key g \minor
3118       \clef "bass"
3119       \lhMusic
3120     >>
3121   >>
3122 }
3123 @end lilypond
3124
3125 Vediamo che la parte della mano destra nella terza battuta
3126 richiede quattro voci.  Si tratta delle cinque crome unite da travatura,
3127 il Do legato, la minima di Re che è unita alla croma di
3128 Re, e la semiminima puntata del Fa diesis, anch'essa unita
3129 alla croma della stessa altezza.  Tutto il resto è su una
3130 voce singola, quindi il sistema più semplice è introdurre queste
3131 ulteriori voci temporaneamente, quando sono richieste.  Se ti
3132 sei dimenticato come fare, rileggi i paragrafi @ref{I'm hearing Voices} e
3133 @ref{Explicitly instantiating voices}.  In questo caso scegliamo di
3134 usare per il passaggio polifonico le voci definite esplicitamente, dato
3135 che LilyPond riesce a evitare meglio le collisioni se tutte le voci
3136 sono definite esplicitamente in questo modo.
3137
3138 Dunque iniziamo con l'inserire le note in due variabili, impostare la
3139 struttura del rigo in un blocco \score e vedere che cosa LilyPond
3140 produce senza modifiche manuali:
3141
3142 @c line-width ensures no break
3143 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3144 rhMusic = \relative c'' {
3145   \new Voice {
3146     r2 c4. g8 |
3147     bes1~ |
3148     \time 6/4
3149     bes2. r8
3150     % Inizia la sezione polifonica a quattro voci
3151     <<
3152       { c,8 d fis bes a }  % continuazione della voce principale
3153       \new Voice {
3154         \voiceTwo
3155         c,8~ c2
3156       }
3157       \new Voice {
3158         \voiceThree
3159         s8 d2
3160       }
3161       \new Voice {
3162         \voiceFour
3163         s4 fis4.
3164       }
3165     >> |
3166     g2.  % continuazione della voce principale
3167   }
3168 }
3169
3170 lhMusic = \relative c' {
3171   r2 <c g ees>2 |
3172   <d g, d>1 |
3173   r2. d,,4 r4 r |
3174   r4
3175 }
3176
3177 \score {
3178   \new PianoStaff <<
3179     \new Staff = "RH"  <<
3180       \key g \minor
3181       \rhMusic
3182     >>
3183     \new Staff = "LH" <<
3184       \key g \minor
3185       \clef "bass"
3186       \lhMusic
3187     >>
3188   >>
3189 }
3190 @end lilypond
3191
3192 Le note sono giuste ma l'aspetto è ben lontano dall'essere
3193 soddisfacente.  La legatura collide col nuovo segno di tempo,
3194 alcune note non sono accorpate e mancano vari elementi
3195 della notazione.  Partiamo dalle cose più semplici.  Possiamo
3196 aggiungere la legatura di portamento della mano sinistra e la legatura
3197 di frase della mano destra, dato che queste sono state già trattate
3198 nel Tutorial.  In questo modo abbiamo:
3199
3200 @c line-width ensures no break
3201 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3202 rhMusic = \relative c'' {
3203   \new Voice {
3204     r2 c4.\( g8 |
3205     bes1~ |
3206     \time 6/4
3207     bes2. r8
3208     % Inizia la sezione polifonica a quattro voci
3209     <<
3210       { c,8 d fis bes a }  % continuazione della voce principale
3211       \new Voice {
3212         \voiceTwo
3213         c,8~ c2
3214       }
3215       \new Voice {
3216         \voiceThree
3217         s8 d2
3218       }
3219       \new Voice {
3220         \voiceFour
3221         s4 fis4.
3222       }
3223     >> |
3224     g2.\)  % continuazione della voce principale
3225   }
3226 }
3227
3228 lhMusic = \relative c' {
3229   r2 <c g ees>2( |
3230   <d g, d>1) |
3231   r2. d,,4 r4 r |
3232   r4
3233 }
3234
3235 \score {
3236   \new PianoStaff <<
3237     \new Staff = "RH"  <<
3238       \key g \minor
3239       \rhMusic
3240     >>
3241     \new Staff = "LH" <<
3242       \key g \minor
3243       \clef "bass"
3244       \lhMusic
3245     >>
3246   >>
3247 }
3248 @end lilypond
3249
3250 Ora la prima battuta è corretta.  La seconda battuta contiene un arpeggio e
3251 è terminata da una stanghetta doppia.  Dato che non sono stati menzionati
3252 in questo manuale di Apprendimento, come possiamo ottenerli?  Dobbiamo
3253 andare a vedere nella guida alla Notazione.  Cercando nell'indice
3254 i termini @qq{arpeggio} e @qq{stanghetta}, scopriamo rapidamente che un arpeggio
3255 viene prodotto posponendo @code{\arpeggio} a un accordo e che la stanghetta
3256 doppia si ottiene col comando @code{\bar "||"}.  Questo è stato facile.  Ora
3257 dobbiamo correggere la collisione della legatura di valore con l'indicazione di tempo.
3258 Il modo migliore è spostare la legatura verso l'alto.  Lo spostamento degli oggetti
3259 è stato trattato prima in @ref{Moving objects}, dove si dice che gli oggetti
3260 posizionati relativamente al rigo possono essere spostati verticalmente
3261 sovrascrivendo la proprietà @code{staff-position}, specificata in metà spazi-rigo
3262 rispetto alla linea centrale del rigo.  Dunque la seguente sovrascrittura
3263 posizionata proprio prima della prima nota della legatura sposta la legatura
3264 3.5 mezzi spazi di rigo sopra la linea centrale:
3265
3266 @code{\once \override Tie.staff-position = #3.5}
3267
3268 Questo completa la seconda battuta:
3269
3270 @c line-width ensures no break
3271 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3272 rhMusic = \relative c'' {
3273   \new Voice {
3274     r2 c4.\( g8 |
3275     \once \override Tie.staff-position = #3.5
3276     bes1~ |
3277     \bar "||"
3278     \time 6/4
3279     bes2. r8
3280     % Inizia la sezione polifonica a quattro voci
3281     <<
3282       { c,8 d fis bes a }  % continuazione della voce principale
3283       \new Voice {
3284         \voiceTwo
3285         c,8~ c2
3286       }
3287       \new Voice {
3288         \voiceThree
3289         s8 d2
3290       }
3291       \new Voice {
3292         \voiceFour
3293         s4 fis4.
3294       }
3295     >> |
3296     g2.\)  % continuazione della voce principale
3297   }
3298 }
3299
3300 lhMusic = \relative c' {
3301   r2 <c g ees>2( |
3302   <d g, d>1)\arpeggio |
3303   r2. d,,4 r4 r |
3304   r4
3305 }
3306
3307 \score {
3308   \new PianoStaff <<
3309     \new Staff = "RH"  <<
3310       \key g \minor
3311       \rhMusic
3312     >>
3313     \new Staff = "LH" <<
3314       \key g \minor
3315       \clef "bass"
3316       \lhMusic
3317     >>
3318   >>
3319 }
3320 @end lilypond
3321
3322 Proseguiamo con la terza battuta e l'inizio della sezione del Moderato.  Nel
3323 tutorial abbiamo visto come aggiungere del testo in grassetto tramite il
3324 comando @code{\markup}, quindi aggiungere @qq{Moderato} in grassetto è
3325 facile.  Ma come facciamo ad accorpare le note appartenenti a voci
3326 diverse?  Ancora una volta dobbiamo rivolgerci alla guida alla Notazione per
3327 un aiuto.  Una ricerca del termine @qq{accorpare} (@emph{merge}) nell'indice della
3328 guida ci porta rapidamente al paragrafo @ruser{Collision resolution}, dove
3329 troviamo i comandi per allineare le note con teste e punti diversi.  Nel
3330 nostro esempio abbiamo bisogno di accorpare entrambi i tipi di note per la
3331 durata della sezione polifonica della terza battuta.  Dunque, usando le
3332 informazioni trovate nella guida alla Notazione, aggiungiamo
3333
3334 @example
3335 \mergeDifferentlyHeadedOn
3336 \mergeDifferentlyDottedOn
3337 @end example
3338
3339 @noindent
3340 all'inizio di questa sezione e
3341
3342 @example
3343 \mergeDifferentlyHeadedOff
3344 \mergeDifferentlyDottedOff
3345 @end example
3346
3347 @noindent
3348 alla fine, ottenendo:
3349
3350 @c line-width ensures no break
3351 @lilypond[quote,ragged-right,line-width=6\in]
3352 rhMusic = \relative c'' {
3353   \new Voice {
3354     r2 c4.\( g8 |
3355     \once \override Tie.staff-position = #3.5
3356     bes1~ |
3357     \bar "||"
3358     \time 6/4
3359     bes2.^\markup { \bold "Moderato" } r8
3360     \mergeDifferentlyHeadedOn
3361     \mergeDifferentlyDottedOn
3362     % Inizia la sezione polifonica a quattro voci
3363     <<
3364       { c,8 d fis bes a }  % continuazione della voce principale
3365       \new Voice {
3366         \voiceTwo
3367         c,8~ c2
3368       }
3369       \new Voice {
3370         \voiceThree
3371         s8 d2
3372       }
3373       \new Voice {
3374         \voiceFour
3375         s4 fis4.
3376       }
3377     >> |
3378     \mergeDifferentlyHeadedOff
3379     \mergeDifferentlyDottedOff
3380     g2.\)  % continuazione della voce principale
3381   }
3382 }
3383
3384 lhMusic = \relative c' {
3385   r2 <c g ees>2( |
3386   <d g, d>1)\arpeggio |
3387   r2. d,,4 r4 r |
3388   r4
3389 }
3390
3391 \score {
3392   \new PianoStaff <<
3393     \new Staff = "RH"  <<
3394       \key g \minor
3395       \rhMusic
3396     >>
3397     \new Staff = "LH" <<
3398       \key g \minor
3399       \clef "bass"
3400       \lhMusic
3401     >>
3402   >>
3403 }
3404 @end lilypond
3405
3406 Queste sovrascritture hanno accorpato i due Fa diesis, ma non i due
3407 Re.  Perché?  La risposta si trova nella stessa sezione della
3408 guida alla Notazione: le note da unire devono avere i gambi in
3409 direzioni opposte e due note non possono essere accorpate se c'è
3410 una terza nota nella stessa colonna.  In questo esempio i due Re
3411 hanno entrambi i gambi in su e c'è una terza nota, il Do. Sappiamo
3412 come cambiare la direzione dei gambi con @code{\stemDown} e la
3413 guida alla Notazione ci dice anche come spostare il Do, applicando
3414 uno spostamento con uno dei comandi @code{\shift}.  Ma quale? Il Do
3415 si trova nella seconda voce che ha lo spostamento (@emph{shift}) disattivato,
3416 mentre i due Re sono nella prima e nella terza voce, che ce l'hanno
3417 rispettivamente disattivato e attivato.  Dunque dobbiamo distanziare il
3418 Do di un ulteriore livello usando @code{\shiftOnn} per evitare che
3419 interferisca con i due Re.  Applicando queste modifiche abbiamo:
3420
3421 @cindex Tie, esempio di sovrascrittura
3422 @cindex proprietà staff-position, esempio
3423 @cindex staff-position, esempio
3424
3425 @c line-width ensures no break
3426 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3427 rhMusic = \relative c'' {
3428   \new Voice {
3429     r2 c4.\( g8 |
3430     \once \override Tie.staff-position = #3.5
3431     bes1~ |
3432     \bar "||"
3433     \time 6/4
3434     bes2.^\markup { \bold "Moderato" } r8
3435     \mergeDifferentlyHeadedOn
3436     \mergeDifferentlyDottedOn
3437     % Inizia la sezione polifonica a quattro voci
3438     <<
3439       { c,8 d fis bes a }  % continuazione della voce principale
3440       \new Voice {
3441         \voiceTwo
3442         % Sposta il c2 fuori dalla colonna della nota principale
3443         % in modo che l'unione di note funzioni
3444         c,8~ \shiftOnn c2
3445       }
3446       \new Voice {
3447         \voiceThree
3448         % Il gambo di d2 deve essere in giù per permettere l'unione delle note
3449         s8 \stemDown d2
3450       }
3451       \new Voice {
3452         \voiceFour
3453         s4 fis4.
3454       }
3455     >> |
3456     \mergeDifferentlyHeadedOff
3457     \mergeDifferentlyDottedOff
3458     g2.\)  % continuazione della voce principale
3459   }
3460 }
3461
3462 lhMusic = \relative c' {
3463   r2 <c g ees>2( |
3464   <d g, d>1)\arpeggio |
3465   r2. d,,4 r4 r |
3466   r4
3467 }
3468
3469 \score {
3470   \new PianoStaff <<
3471     \new Staff = "RH"  <<
3472       \key g \minor
3473       \rhMusic
3474     >>
3475     \new Staff = "LH" <<
3476       \key g \minor
3477       \clef "bass"
3478       \lhMusic
3479     >>
3480   >>
3481 }
3482 @end lilypond
3483
3484 Ci siamo quasi, restano solo due problemi: il gambo in giù del
3485 Re unito non ci dovrebbe essere e il Do dovrebbe essere posizionato
3486 a destra dei Re.  Sappiamo come fare grazie alle modifiche precedenti:
3487 rendiamo il gambo trasparente e spostiamo il Do con la proprietà
3488 @code{force-hshift}.  Ecco il risultato finale:
3489
3490 @cindex NoteColumn, esempio di sovrascrittura
3491 @cindex proprietà force-hshift, esempio
3492 @cindex force-hshift, esempio
3493 @cindex Stem, esempio di sovrascrittura
3494 @cindex proprietà transparent, esempio
3495 @cindex transparent, esempio
3496
3497 @c line-width ensures no break
3498 @lilypond[quote,verbatim,ragged-right,line-width=6\in]
3499 rhMusic = \relative c'' {
3500   \new Voice {
3501     r2 c4.\( g8 |
3502     \once \override Tie.staff-position = #3.5
3503     bes1~ |
3504     \bar "||"
3505     \time 6/4
3506     bes2.^\markup { \bold "Moderato" } r8
3507     \mergeDifferentlyHeadedOn
3508     \mergeDifferentlyDottedOn
3509     % Inizia la sezione polifonica a quattro voci
3510     <<
3511       { c,8 d fis bes a }  % continuazione della voce principale
3512       \new Voice {
3513         \voiceTwo
3514         c,8~
3515         % Riposiziona il c2 a destra della nota unita
3516         \once \override NoteColumn.force-hshift = #1.0
3517         % Sposta il c2 fuori dalla colonna della nota principale
3518         % in modo che l'unione di note funzioni
3519         \shiftOnn
3520         c2
3521       }
3522       \new Voice {
3523         \voiceThree
3524         s8
3525         % Il gambo di d2 deve essere in giù per permettere l'unione delle note
3526         \stemDown
3527         % Stem on the d2 should be invisible
3528         \tweak Stem.transparent ##t
3529         \tweak Flag.transparent ##t
3530         d2
3531       }
3532       \new Voice {
3533         \voiceFour
3534         s4 fis4.
3535       }
3536     >> |
3537     \mergeDifferentlyHeadedOff
3538     \mergeDifferentlyDottedOff
3539     g2.\)  % continuazione della voce principale
3540   }
3541 }
3542
3543 lhMusic = \relative c' {
3544   r2 <c g ees>2( |
3545   <d g, d>1)\arpeggio |
3546   r2. d,,4 r4 r |
3547   r4
3548 }
3549
3550 \score {
3551   \new PianoStaff <<
3552     \new Staff = "RH"  <<
3553       \key g \minor
3554       \rhMusic
3555     >>
3556     \new Staff = "LH" <<
3557       \key g \minor
3558       \clef "bass"
3559       \lhMusic
3560     >>
3561   >>
3562 }
3563 @end lilypond
3564
3565
3566 @node Altre modifiche
3567 @section Altre modifiche
3568 @translationof Further tweaking
3569
3570 @menu
3571 * Altri usi delle modifiche::
3572 * Uso delle variabili per le modifiche::
3573 * Fogli di stile::
3574 * Altre fonti di informazione::
3575 * Modifiche avanzate con Scheme::
3576 @end menu
3577
3578 @node Altri usi delle modifiche
3579 @subsection Altri usi delle modifiche
3580 @translationof Other uses for tweaks
3581
3582 @cindex proprietà transparent, uso della
3583 @cindex oggetti, renderli invisibili
3584 @cindex togliere gli oggetti
3585 @cindex oggetti, toglierli
3586 @cindex nascondere gli oggetti
3587 @cindex oggetti, nascondere
3588 @cindex oggetti invisibili
3589 @cindex legature di valore tra note di voci diverse
3590
3591 @subheading Legature di valore tra note di voci diverse
3592
3593 L'esempio seguente mostra come unire con legature di valore
3594 note appartenenti a voci diverse.  Di norma, solo le note nella
3595 stessa voce possono essere unite da una legatura di valore.
3596 Se si usano due voci con le note legate in una voce
3597
3598 @lilypond[quote,fragment,relative=2]
3599 << { b8~ b\noBeam } \\ { b8[ g] } >>
3600 @end lilypond
3601
3602 @noindent
3603 e si cancella il primo gambo di quella voce, la legatura sembra
3604 attraversare le voci:
3605
3606 @cindex Stem, esempio di sovrascrittura
3607 @cindex proprietà transparent, esempio
3608 @cindex transparent, esempio
3609
3610 @lilypond[quote,fragment,relative=2,verbatim]
3611 <<
3612   {
3613     \tweak Stem.transparent ##t
3614     \tweak Flag.transparent ##t
3615     b8~ b\noBeam
3616   }
3617 \\
3618   { b8[ g] }
3619 >>
3620 @end lilypond
3621
3622 Per far sì che il gambo cancellato non schiacci troppo la legatura,
3623 possiamo allungarlo impostando la proprietà
3624 @code{length} su @code{8},
3625
3626 @lilypond[quote,fragment,relative=2,verbatim]
3627 <<
3628   {
3629     \tweak Stem.transparent ##t
3630     \tweak Flag.transparent ##t
3631     \tweak Stem.length #8
3632     b8~ b\noBeam
3633   }
3634 \\
3635   { b8[ g] }
3636 >>
3637 @end lilypond
3638
3639 @funindex \single
3640 @cindex tweak, generated from override
3641 Per @emph{sovrascrivere} la trasparenza di un oggetto grafico,
3642 avremmo potuto usare la scorciatoia @code{\hide}, come spiegato
3643 in precedenza.  Ma la modifica manuale con @emph{\tweak} è un'operazione
3644 diversa, che riguarda solo le proprietà generate da una singola espressione
3645 musicale.  Tuttavia è possibile convertire le sovrascritture in @emph{tweak}
3646 usando @code{\single}. Questo ci permette di riscrivere l'esempio precedente
3647 in questo modo
3648
3649 @lilypond[quote,fragment,relative=2,verbatim]
3650 <<
3651   {
3652     \single \hide Stem
3653     \single \hide Flag
3654     \tweak Stem.length #8
3655     b8~ b\noBeam
3656   }
3657 \\
3658   { b8[ g] }
3659 >>
3660 @end lilypond
3661
3662 In questo caso particolare, la differenza rispetto a @code{\once \hide} non
3663 è evidente.  La differenza è importante quando ci sono vari oggetti che
3664 si trovano nello stesso punto del tempo musicale (come le teste delle note
3665 in un accordo).  In quel caso, @code{\once} avrà effetto su tutti quegli
3666 oggetti mentre @code{\single} solo su uno, ovvero quello generato
3667 dall'espressione musicale immediatamente seguente.
3668
3669 @subheading Simulare una corona nel MIDI
3670
3671 @cindex proprietà stencil, uso della
3672 @cindex corona, usarla nel MIDI
3673
3674 Per gli oggetti esterni al rigo è di solito preferibile sovrascrivere
3675 la proprietà @code{stencil} piuttosto che la proprietà @code{transparent}
3676 dell'oggetto se si desidera toglierlo dall'output.  Se si imposta la
3677 proprietà @code{stencil} su @code{#f} l'oggetto verrà completamente
3678 rimosso dall'output e quindi non potrà influenzare la disposizone
3679 di altri oggetti posizionati rispetto a esso.
3680
3681 Ad esempio, se volessimo modificare il segno di metronomo solo per
3682 simulare una corona nel MIDI, non vorremmo che il segno apparisse
3683 nella partitura né vorremmo influenzare la spaziatura tra i due
3684 sistemi o la posizione di annotazioni adiacenti nel rigo.  Dunque,
3685 il modo migliore è impostare la proprietà @code{stencil} su
3686 @code{#f}.  Ecco l'effetto dei due metodi:
3687
3688 @cindex MetronomeMark, esempio di sovrascrittura
3689 @cindex proprietà transparent, esempio
3690 @cindex transparent, esempio
3691
3692 @lilypond[quote,verbatim,ragged-right]
3693 \score {
3694   \relative c'' {
3695     % Indicazione di tempo visibile
3696     \tempo 4=120
3697     a4 a a
3698     \once \hide Score.MetronomeMark
3699     % Indicazione di tempo invisibile per allungare la fermata nel MIDI
3700     \tempo 4=80
3701     a4\fermata |
3702     % Nuovo tempo per la sezione successiva
3703     \tempo 4=100
3704     a4 a a a |
3705   }
3706   \layout { }
3707   \midi { }
3708 }
3709 @end lilypond
3710
3711 @cindex MetronomeMark, esempio di sovrascrittura
3712 @cindex proprietà stencil, esempio
3713 @cindex stencil, esempio
3714
3715 @lilypond[quote,verbatim,ragged-right]
3716 \score {
3717   \relative c'' {
3718     % Indicazione di tempo visibile
3719     \tempo 4=120
3720     a4 a a
3721     \once \omit Score.MetronomeMark
3722     % Indicazione di tempo invisibile per allungare la fermata nel MIDI
3723     \tempo 4=80
3724     a4\fermata |
3725     % Nuovo tempo per la sezione successiva
3726     \tempo 4=100
3727     a4 a a a |
3728   }
3729   \layout { }
3730   \midi { }
3731 }
3732 @end lilypond
3733
3734 @noindent
3735 Entrambi i metodi tolgono dalla partitura l'indicazione metronomica
3736 ed entrambi cambiano il tempo del MIDI come volevamo, ma nel primo esempio l'indicazione
3737 metronomica trasparente sposta troppo in alto
3738 l'indicazione di tempo successiva, mentre nel secondo esempio, dove
3739 viene tolto lo stampo (@emph{stencil}), ciò non accade.
3740
3741 @seealso
3742 Glossario musicale:
3743 @rglosnamed{system,sistema}.
3744
3745 @node Uso delle variabili per le modifiche
3746 @subsection Uso delle variabili per le modifiche
3747 @translationof Using variables for tweaks
3748
3749 @cindex variabili, usarle per le modifiche
3750 @cindex usare le variabili per le modifiche
3751 @cindex modifiche, usare le variabili per le
3752
3753 I comandi di sovrascrittura sono spesso lunghi e tediosi da
3754 scrivere, e devono essere assolutamente corretti.  Se si usa
3755 più volte la stessa sovrascrittura conviene definire una
3756 variabile che la contenga.
3757
3758 Immaginiamo di voler enfatizzare certe parole del testo usando
3759 grassetto e corsivo.  I comandi @code{\italic} (corsivo) e @code{\bold}
3760 (grassetto) funzionano all'interno del testo solo se inclusi,
3761 insieme alla parola o alle parole da modificare, in un blocco
3762 @code{\markup}: dunque sono scomodi da inserire.  Dovendo inserire
3763 le parole stesse non si possono usare variabili semplici.  Come
3764 alternativa possiamo usare i comandi @code{\override} e @code{\revert}?
3765
3766 @example
3767 @code{\override Lyrics.LyricText.font-shape = #'italic}
3768 @code{\override Lyrics.LyricText.font-series = #'bold}
3769
3770 @code{\revert Lyrics.LyricText.font-shape}
3771 @code{\revert Lyrics.LyricText.font-series}
3772 @end example
3773
3774 Anche questi sarebbero molto noiosi da inserire se ci fossero
3775 molte parole che richiedono enfasi.  Ma possiamo inserirli
3776 in due variabili e poi usare queste per le parole da enfatizzare.
3777 Un altro vantaggio dell'uso di variabili per queste sovrascritture
3778 è che gli spazi intorno al punto non sono necessari, perché non
3779 sono interpretati direttamente in @code{\lyricmode}.  Ecco un
3780 esempio, anche se nella pratica comune avremmo scelto dei nomi
3781 più brevi per le variabili in modo da poterle inserire più
3782 rapidamente:
3783
3784 @cindex LyricText, esempio di sovrascrittura
3785 @cindex proprietà font-shape, esempio
3786 @cindex font-shape, esempio
3787 @cindex proprietà font-series, esempio
3788 @cindex font-series, esempio
3789
3790 @lilypond[quote,verbatim]
3791 emphasize = {
3792   \override Lyrics.LyricText.font-shape = #'italic
3793   \override Lyrics.LyricText.font-series = #'bold
3794 }
3795
3796 normal = {
3797   \revert Lyrics.LyricText.font-shape
3798   \revert Lyrics.LyricText.font-series
3799 }
3800
3801 global = { \key c \major \time 4/4 \partial 4 }
3802
3803 SopranoMusic = \relative c' { c4 | e4. e8 g4 g    | a4   a   g  }
3804 AltoMusic    = \relative c' { c4 | c4. c8 e4 e    | f4   f   e  }
3805 TenorMusic   = \relative c  { e4 | g4. g8 c4.  b8 | a8 b c d e4 }
3806 BassMusic    = \relative c  { c4 | c4. c8 c4 c    | f8 g a b c4 }
3807
3808 VerseOne = \lyrics {
3809   E -- | ter -- nal \emphasize Fa -- ther, | \normal strong to save,
3810 }
3811
3812 VerseTwo = \lyricmode {
3813   O | \once \emphasize Christ, whose voice the | wa -- ters heard,
3814 }
3815
3816 VerseThree = \lyricmode {
3817   O | \emphasize Ho -- ly Spi -- rit, | \normal who didst brood
3818 }
3819
3820 VerseFour = \lyricmode {
3821   O | \emphasize Tri -- ni -- ty \normal of | love and pow'r
3822 }
3823
3824 \score {
3825   \new ChoirStaff <<
3826     \new Staff <<
3827       \clef "treble"
3828       \new Voice = "Soprano"  { \voiceOne \global \SopranoMusic }
3829       \new Voice = "Alto" { \voiceTwo \AltoMusic }
3830       \new Lyrics \lyricsto "Soprano" { \VerseOne }
3831       \new Lyrics \lyricsto "Soprano" { \VerseTwo }
3832       \new Lyrics \lyricsto "Soprano" { \VerseThree }
3833       \new Lyrics \lyricsto "Soprano" { \VerseFour }
3834     >>
3835     \new Staff <<
3836       \clef "bass"
3837       \new Voice = "Tenor" { \voiceOne \TenorMusic }
3838       \new Voice = "Bass"  { \voiceTwo \BassMusic }
3839     >>
3840   >>
3841 }
3842 @end lilypond
3843
3844
3845 @node Fogli di stile
3846 @subsection Fogli di stile
3847 @translationof Style sheets
3848
3849 L'output prodotto da LilyPond può essere ampiamente modificato, come
3850 abbiamo visto nel capitolo @ref{Tweaking output}.  Ma se avessi molti
3851 file di input a cui voler applicare delle modifiche?  O se volessi
3852 semplicemente separare le modifiche dalla musica vera e propria?
3853 È molto semplice.
3854
3855 Prendiamo un esempio.  Non ti preoccupare se non capisci le
3856 parti che hanno @code{#()}; verranno spiegate nel capitolo
3857 @ref{Advanced tweaks with Scheme}.
3858
3859 @lilypond[quote,verbatim,ragged-right]
3860 mpdolce =
3861 #(make-dynamic-script
3862   #{ \markup { \hspace #0
3863                \translate #'(5 . 0)
3864                \line { \dynamic "mp"
3865                        \text \italic "dolce" } }
3866   #})
3867
3868 inst =
3869 #(define-music-function
3870      (parser location string)
3871      (string?)
3872    #{ <>^\markup \bold \box #string #})
3873
3874 \relative c'' {
3875   \tempo 4=50
3876   a4.\mpdolce d8 cis4--\glissando a |
3877   b4 bes a2 |
3878   \inst "Clarinet"
3879   cis4.\< d8 e4 fis |
3880   g8(\! fis)-. e( d)-. cis2 |
3881 }
3882 @end lilypond
3883
3884 Facciamo qualcosa a proposito delle definizioni di @code{mpdolce} e
3885 @code{inst}.  Producono l'output che desideriamo, ma potremmo volerle
3886 usare in un altro brano.  Potremmo semplicemente copiarle e incollarle
3887 in cima a ogni file, ma sarebbe una seccatura e lascerebbe queste
3888 definizioni nel file di input; personalmente trovo tutti quei @code{#()}
3889 piuttosto brutti, dunque nascondiamoli in un altro file:
3890
3891 @example
3892 %%% salva queste righe in un file chiamato "definitions.ily"
3893 mpdolce =
3894 #(make-dynamic-script
3895   #@{ \markup @{ \hspace #0
3896                \translate #'(5 . 0)
3897                \line @{ \dynamic "mp"
3898                        \text \italic "dolce" @} @}
3899   #@})
3900
3901 inst =
3902 #(define-music-function
3903      (parser location string)
3904      (string?)
3905    #@{ <>^\markup \bold \box #string #@})
3906 @end example
3907
3908 Ci riferiremo a questo file tramite il comando @code{\include} in cima
3909 al file dove c'è la musica.  Si usa l'estensione @file{.ily} per distinguere
3910 il file da includere, che non intendiamo compilare da solo, dal file principale.
3911 Ora modifichiamo la musica (e salviamo questo file come @file{music.ly}).
3912
3913 @c  We have to do this awkward example/lilypond-non-verbatim
3914 @c  because we can't do the \include stuff in the manual.
3915
3916 @example
3917 \include "definitions.ily"
3918
3919 \relative c'' @{
3920   \tempo 4=50
3921   a4.\mpdolce d8 cis4--\glissando a |
3922   b4 bes a2 |
3923   \inst "Clarinet"
3924   cis4.\< d8 e4 fis |
3925   g8(\! fis)-. e( d)-. cis2 |
3926 @}
3927 @end example
3928
3929 @lilypond[quote,ragged-right]
3930 mpdolce =
3931 #(make-dynamic-script
3932   #{ \markup { \hspace #0
3933                \translate #'(5 . 0)
3934                \line { \dynamic "mp"
3935                        \text \italic "dolce" } }
3936   #})
3937
3938 inst =
3939 #(define-music-function
3940      (parser location string)
3941      (string?)
3942    #{ <>^\markup \bold \box #string #})
3943
3944 \relative c'' {
3945   \tempo 4=50
3946   a4.\mpdolce d8 cis4--\glissando a |
3947   b4 bes a2 |
3948   \inst "Clarinet"
3949   cis4.\< d8 e4 fis |
3950   g8(\! fis)-. e( d)-. cis2 |
3951 }
3952 @end lilypond
3953
3954 L'aspetto è migliore, ma facciamo ancora qualche modifica.  Il glissando si
3955 vede appena, rendiamolo quindi più spesso e più vicino alle teste di nota.
3956 Mettiamo l'indicazione metronomica al di sopra della chiave invece che della prima
3957 nota.  E, infine, dato che il mio professore di composizione odia l'indicazione
3958 di tempo @qq{C}, usiamo @qq{4/4} al suo posto.
3959
3960 Ma non devi cambiare @file{music.ly} bensì @file{definitions.ily}, in
3961 questo modo:
3962
3963 @example
3964 %%%  definitions.ily
3965 mpdolce =
3966 #(make-dynamic-script
3967   #@{ \markup @{ \hspace #0
3968                \translate #'(5 . 0)
3969                \line @{ \dynamic "mp"
3970                        \text \italic "dolce" @} @}
3971   #@})
3972
3973 inst =
3974 #(define-music-function
3975      (parser location string)
3976      (string?)
3977    #@{ <>^\markup \bold \box #string #@})
3978
3979 \layout@{
3980   \context @{
3981     \Score
3982     \override MetronomeMark.extra-offset = #'(-9 . 0)
3983     \override MetronomeMark.padding = #'3
3984   @}
3985   \context @{
3986     \Staff
3987     \override TimeSignature.style = #'numbered
3988   @}
3989   \context @{
3990     \Voice
3991     \override Glissando.thickness = #3
3992     \override Glissando.gap = #0.1
3993   @}
3994 @}
3995 @end example
3996
3997 @lilypond[quote,ragged-right]
3998 mpdolce =
3999 #(make-dynamic-script
4000   #{ \markup { \hspace #0
4001                \translate #'(5 . 0)
4002                \line { \dynamic "mp"
4003                        \text \italic "dolce" } }
4004   #})
4005
4006 inst =
4007 #(define-music-function
4008      (parser location string)
4009      (string?)
4010    #{ <>^\markup \bold \box #string #})
4011
4012 \layout{
4013   \context {
4014     \Score
4015     \override MetronomeMark.extra-offset = #'(-9 . 0)
4016     \override MetronomeMark.padding = #'3
4017   }
4018   \context {
4019     \Staff
4020     \override TimeSignature.style = #'numbered
4021   }
4022   \context {
4023     \Voice
4024     \override Glissando.thickness = #3
4025     \override Glissando.gap = #0.1
4026   }
4027 }
4028
4029 \relative c'' {
4030   \tempo 4=50
4031   a4.\mpdolce d8 cis4--\glissando a |
4032   b4 bes a2 |
4033   \inst "Clarinet"
4034   cis4.\< d8 e4 fis |
4035   g8(\! fis)-. e( d)-. cis2 |
4036 }
4037 @end lilypond
4038
4039 Ora l'aspetto è decisamente migliore!  Supponiamo ora di voler pubblicare
4040 questo brano.  Il mio professore di composizione non ama il segno di
4041 tempo @qq{C}, mentre a me piace.  Copiamo l'attuale file @file{definitions.ily}
4042 in @file{web-publish.ily} e modifichiamolo.  Dato che questa musica
4043 verrà distribuita su un pdf da leggere a schermo, aumenteremo anche
4044 la dimensione complessiva dell'output.
4045
4046 @example
4047 %%%  web-publish.ily
4048 mpdolce =
4049 #(make-dynamic-script
4050   #@{ \markup @{ \hspace #0
4051                \translate #'(5 . 0)
4052                \line @{ \dynamic "mp"
4053                        \text \italic "dolce" @} @}
4054   #@})
4055
4056 inst =
4057 #(define-music-function
4058      (parser location string)
4059      (string?)
4060    #@{ <>^\markup \bold \box #string #@})
4061
4062 #(set-global-staff-size 23)
4063
4064 \layout@{
4065   \context @{
4066     \Score
4067     \override MetronomeMark.extra-offset = #'(-9 . 0)
4068     \override MetronomeMark.padding = #'3
4069   @}
4070   \context @{
4071     \Staff
4072   @}
4073   \context @{
4074     \Voice
4075     \override Glissando.thickness = #3
4076     \override Glissando.gap = #0.1
4077   @}
4078 @}
4079 @end example
4080
4081 @lilypond[quote,ragged-right]
4082 mpdolce =
4083 #(make-dynamic-script
4084   #{ \markup { \hspace #0
4085                \translate #'(5 . 0)
4086                \line { \dynamic "mp"
4087                        \text \italic "dolce" } }
4088   #})
4089
4090 inst =
4091 #(define-music-function
4092      (parser location string)
4093      (string?)
4094    #{ <>^\markup \bold \box #string #})
4095
4096 #(set-global-staff-size 23)
4097
4098 \layout{
4099   \context { \Score
4100     \override MetronomeMark.extra-offset = #'(-9 . 0)
4101     \override MetronomeMark.padding = #'3
4102   }
4103   \context { \Voice
4104     \override Glissando.thickness = #3
4105     \override Glissando.gap = #0.1
4106   }
4107 }
4108
4109 \relative c'' {
4110   \tempo 4=50
4111   a4.\mpdolce d8 cis4--\glissando a |
4112   b4 bes a2 |
4113   \inst "Clarinet"
4114   cis4.\< d8 e4 fis |
4115   g8(\! fis)-. e( d)-. cis2 |
4116 }
4117 @end lilypond
4118
4119 Nel file che contiene la musica non rimane che sostituire
4120 @code{\include "definitions.ily"} con
4121 @code{\include "web-publish.ily"}.  Potremmo usare un sistema
4122 ancora più conveniente: creare un file @file{definitions.ily} che
4123 contenga solo le definizioni di @code{mpdolce} e @code{inst}, un file
4124 @file{web-publish.ily} che contenga solo la sezione @code{\layout}
4125 vista prima, e un file @file{university.ily} che contenga solo le
4126 modifiche necessarie per produrre l'output preferito dal mio
4127 professore.  L'inizio di @file{music.ly} apparirebbe così:
4128
4129 @example
4130 \include "definitions.ily"
4131
4132 %%% Una sola di queste linee deve essere commentata
4133 \include "web-publish.ily"
4134 %\include "university.ily"
4135 @end example
4136
4137 Questo approccio può essere utile anche se si sta creando un
4138 insieme di parti.  Uso una mezza dozzina di diversi
4139 @q{fogli di stile} per i miei progetti.  Faccio iniziare
4140 ogni file musicale con @code{\include "../global.ily"}, che contiene
4141
4142 @example
4143 %%%   global.ily
4144 \version @w{"@version{}"}
4145
4146 #(ly:set-option 'point-and-click #f)
4147
4148 \include "../init/init-defs.ly"
4149 \include "../init/init-layout.ly"
4150 \include "../init/init-headers.ly"
4151 \include "../init/init-paper.ly"
4152 @end example
4153
4154
4155 @node Altre fonti di informazione
4156 @subsection Altre fonti di informazione
4157 @translationof Other sources of information
4158
4159 La guida al Funzionamento interno contiene molte informazioni su
4160 LilyPond, ma si possono trovare ancora più informazioni nei file
4161 interni di LilyPond.  Per studiarli devi prima trovare la giusta
4162 directory nel tuo sistema operativo.  Il percorso di questa
4163 directory dipende da quale sistema operativo si sta usando e da
4164 come si è ottenuto LilyPond, se scaricando un binario precompilato
4165 da lilypond.org oppure installandolo da un gestore di pacchetti
4166 (come nelle distribuzioni GNU/Linux o nelle istallazioni tramite
4167 fink o cygwin) o compilandolo dai sorgenti:
4168
4169 @strong{Scaricato da lilypond.org}
4170
4171 @itemize @bullet
4172 @item GNU/Linux
4173
4174 Vai in
4175 @example
4176 @file{@var{INSTALLDIR}/lilypond/usr/@/share/lilypond/current/}
4177 @end example
4178
4179 @item MacOS X
4180
4181 Vai in
4182 @example
4183 @file{@var{INSTALLDIR}/LilyPond.app/Contents/@/Resources/share/lilypond/current/}
4184 @end example
4185
4186 usando @code{cd} in un terminale per entrare in questa
4187 directory oppure facendo un Ctrl+click sull'applicazione LilyPond e
4188 scegliendo @qq{Mostra i contenuti dei pacchetti}.
4189
4190 @item Windows
4191
4192 Con Windows Explorer vai in
4193 @example
4194 @file{@var{INSTALLDIR}/LilyPond/usr/@/share/lilypond/current/}
4195 @end example
4196
4197 @end itemize
4198
4199 @strong{Istallato da un gestore di pacchetti o compilato da sorgenti}
4200
4201 Vai in
4202 @file{@var{PREFIX}/share/lilypond/@var{X.Y.Z}/}, dove
4203 @var{PREFIX} è definito dal gestore pacchetti o dallo
4204 script @code{configure} e @var{X.Y.Z} è il numero di
4205 versione di LilyPond.
4206
4207 @smallspace
4208
4209 All'interno di questa directory le due sottodirectory interessanti sono
4210
4211 @itemize
4212 @item @file{ly/} - contiene i file nel linguaggio di LilyPond
4213 @item @file{scm/} - contiene i file nel linguaggio Scheme
4214 @end itemize
4215
4216 Iniziamo col vedere alcuni file in @file{ly/}.
4217 Apri @file{ly/property-init.ly} in un editor di testo.  Quello
4218 che usi normalmente per i file @code{.ly} va bene.  Questo file
4219 contiene le definizioni di tutti i comandi predefiniti standard
4220 di LilyPond, come @code{\stemUp} e @code{\slurDotted}.  Vedrai
4221 che questi non sono altro che definizioni di variabili che
4222 contengono uno o più comandi @code{\override}.  Ad esempio,
4223 @code{/tieDotted} è definito così:
4224
4225 @example
4226 tieDotted = @{
4227   \override Tie.dash-period = #0.75
4228   \override Tie.dash-fraction = #0.1
4229 @}
4230 @end example
4231
4232 Se non ti piacciono i valori predefiniti, puoi facilmente
4233 definire nuovamente questi comandi, proprio come qualsiasi
4234 altra variabile, all'inizio del file di input.
4235
4236 Ecco i file più utili che si trovano in @file{ly/}:
4237
4238 @multitable @columnfractions .4 .6
4239 @headitem Nome del file
4240   @tab Contenuti
4241 @item @file{ly/engraver-init.ly}
4242   @tab Definizioni dei contesti degli incisori (@emph{engraver})
4243 @item @file{ly/paper-defaults-init.ly}
4244   @tab Specifiche dei valori predefiniti relativi al foglio
4245 @item @file{ly/performer-init.ly}
4246   @tab Definizioni dei contesti dei @emph{performer}
4247 @item @file{ly/property-init.ly}
4248   @tab Definizioni di tutti i comandi predefiniti più comuni
4249 @item @file{ly/spanner-init.ly}
4250   @tab Definizioni dei comandi predefiniti relativi agli estensori (@emph{spanner})
4251 @end multitable
4252
4253 Altre impostazioni (come le definizioni dei comandi di markup) sono
4254 salvate come file @file{.scm} (Scheme).  Il linguaggio di programmazione
4255 Scheme serve a fornire un'interfaccia di programmazione per modificare
4256 il funzionamento interno di LilyPond.  Una spiegazione dettagliata di
4257 questi file non rientra nell'obiettivo di questo manuale, dal momento che
4258 è necessario conoscere il linguaggio Scheme.  Avvisiamo gli utenti che
4259 è richiesta una notevole quantità di abilità tecnica o di tempo per
4260 comprendere Scheme e questi file (vedi @rextend{Scheme tutorial}).
4261
4262 Nel caso tu conosca Scheme, i file che potrebbero essere di interesse sono:
4263
4264 @multitable @columnfractions .4 .6
4265 @headitem Nome del file
4266   @tab Contenuti
4267 @item @file{scm/auto-beam.scm}
4268   @tab Valori predefiniti della disposizione delle travature
4269 @item @file{scm/define-grobs.scm}
4270   @tab Impostazioni predefinite delle proprietà dei grob
4271 @item @file{scm/define-markup-commands.scm}
4272   @tab Definizione di tutti i comandi di markup
4273 @item @file{scm/midi.scm}
4274   @tab Impostazioni predefinite dell'output MIDI
4275 @item @file{scm/output-lib.scm}
4276   @tab Impostazioni che modificano l'aspetto di tasti, colori,
4277        alterazioni, stanghette, etc.
4278 @item @file{scm/parser-clef.scm}
4279   @tab Definizioni delle chiavi supportate
4280 @item @file{scm/script.scm}
4281   @tab Impostazioni predefinite delle articolazioni
4282 @end multitable
4283
4284
4285 @node Modifiche avanzate con Scheme
4286 @subsection Modifiche avanzate con Scheme
4287 @translationof Advanced tweaks with Scheme
4288
4289 Anche se molte cose sono possibili con i comandi @code{\override} e
4290 @code{\tweak}, un modo ancor più potente di modificare l'azione
4291 di LilyPond è resa possibile da un interfaccia programmabile al
4292 funzionamento interno di LilyPond.  Il codice scritto nel linguaggio
4293 di programmazione Scheme può essere incorporato direttamente nel
4294 funzionamento interno di LilyPond.  Ovviamente, per farlo è necessaria
4295 almeno una conoscenza di base della programmazione in Scheme;
4296 abbiamo scritto un'introduzione in @rextend{Scheme tutorial}.
4297
4298 Come esempio di una delle tante possibilità, invece di impostare
4299 una proprietà su un valore costante, si può impostare su una
4300 procedura Scheme che viene poi chiamata ogni volta che LilyPond
4301 accede a quella proprietà.  La proprietà può essere poi impostata
4302 dinamicamente su un valore determinato dalla procedura nel momento
4303 in cui viene chiamata.  In questo esempio coloriamo le teste delle
4304 note in base alla loro posizione sul rigo.
4305
4306 @cindex funzione x11-color, esempio d'uso
4307 @cindex x11-color, esempio d'uso
4308 @cindex NoteHead, esempio di sovrascrittura
4309 @cindex proprietà color, impostare su procedura Scheme
4310 @cindex color, impostare su procedura Scheme
4311
4312 @lilypond[quote,verbatim,ragged-right]
4313 #(define (color-notehead grob)
4314    "Colora le teste di nota in base alla loro posizione sul rigo."
4315    (let ((mod-position (modulo (ly:grob-property grob 'staff-position)
4316                                7)))
4317      (case mod-position
4318        ;;   Return rainbow colors
4319        ((1) (x11-color 'red    ))  ; for C
4320        ((2) (x11-color 'orange ))  ; for D
4321        ((3) (x11-color 'yellow ))  ; for E
4322        ((4) (x11-color 'green  ))  ; for F
4323        ((5) (x11-color 'blue   ))  ; for G
4324        ((6) (x11-color 'purple ))  ; for A
4325        ((0) (x11-color 'violet ))  ; for B
4326        )))
4327
4328 \relative c' {
4329   % Fa sì che il colore sia preso dalla procedura color-notehead
4330   \override NoteHead.color = #color-notehead
4331   a2 b | c2 d | e2 f | g2 a |
4332 }
4333 @end lilypond
4334
4335 Altri esempi che mostrano l'uso di queste interfacce programmabili
4336 si trovano in @rextend{Callback functions}.
4337