[ << Concetti fondamentali ] | [Top][Contents][Index] | [ Modifica dell’output >> ] |
[ < Gli incisori ] | [ Up : Contesti e incisori ] | [ Aggiungere e togliere gli incisori > ] |
4.3.4 Modificare le proprietà di contesto
I contesti si occupano di tenere i valori di un certo numero di
proprietà del contesto. Molte di queste possono essere cambiate
per influenzare l’interpretazione dell’input e quindi modificare
l’aspetto dell’output. Per cambiarle si usa il comando
\set
. Questo assume la seguente forma
\set NomeContesto.nomeProprietà = #valore
Dove il NomeContesto è di solito Score
,
Staff
o Voice
. Può essere omesso, e in questo
caso viene considerato il contesto attuale (solitamente Voice
).
I nomi delle proprietà di contesto consistono in parole unite insieme e senza lineette o trattini bassi, e tutte le parole tranne la prima iniziano con una lettera maiuscola. Ecco alcuni esempi di quelle più usate comunemente. Ma ne esistono molte altre.
nomeProprietà | Tipo | Funzione | Valore di esempio |
---|---|---|---|
extraNatural | Booleano | Se è vero, mette i segni di bequadro prima degli accidenti | #t , #f |
currentBarNumber | Intero | Imposta il numero della battuta corrente | 50 |
doubleSlurs | Booleano | Se è vero, stampa le legature di portamento sia sopra che sotto le note | #t , #f |
instrumentName | Testo | Imposta il nome da inserire all’inizio del rigo | "Cello I" |
fontSize | Reale | Aumenta o riduce la dimensione del carattere | 2.4 |
stanza | Testo | Imposta il testo da stampare prima dell’inizio di una strofa | "2" |
mentre un Booleano è o Vero (#t
) o Falso (#f
),
un Intero è un numero intero positivo, un Reale è un numero
decimale positivo o negativo, e il testo è racchiuso tra
virgolette. Si noti la presenza del segno cancelletto,
(#
), in due punti diversi – come parte del valore Booleano
prima di t
o f
, e prima del valore
nell’affermazione \set
. Dunque quando si inserisce un valore
Booleano bisogna scrivere due cancelletti, ad esempio ##t
.
Prima di poter impostare una qualsiasi di queste proprietà dobbiamo sapere
in quale contesto esse operino. Talvolta questo è ovvio,
ma talvolta può risultare complicato. Se viene specificato il
contesto sbagliato, non viene generato alcun messaggio di errore, ma l’azione
desiderata non avrà luogo. Ad esempio, la proprietà
clefGlyph
risiede ovviamente nel contesto Staff
, poiché
è il glifo della chiave a dover essere cambiato.
Nell’esempio seguente viene stampata correttamente la prima chiave del
pentagramma, ma non la seconda (che appare come la chiave predefinita di
violino, invece della chiave di basso o Fa che ci aspetteremmo) perché
abbiamo omesso il nome del contesto.
<< \new Staff \relative { \set Staff.clefGlyph = "clefs.C" c''2 c } \new Staff \relative { \set clefGlyph = "clefs.F" % Sbagliato! d'2 d } >>
Ricorda che il nome di contesto predefinito è Voice
, dunque il
secondo comando \set
imposta la proprietà clefGlyph
nel
contesto Voice
col valore “clefs.F”, ma dato che LilyPond non trova
tale proprietà nel contesto Voice
, non ha avuto luogo
alcuna altra azione. Questo non è un errore, e nessun messaggio di
errore viene riportato nel file di log.
La proprietà clefGlyph
funzionerà soltanto se inserita nel contesto
Staff
, ma alcune proprietà possono essere collocate in più di un contesto.
Ad esempio, la proprietà extraNatural
è impostata di default sul
valore ##t (vero) su tutti i righi. Se viene impostata su ##f (falso) in uno
specifico contesto Staff
si applica solo alle alterazioni presenti su
quel rigo. Se impostata su falso nel contesto Score
si applica a tutti
i righi.
Quindi in questo modo si disattiva il bequadro su un rigo:
<< \new Staff \relative { aeses'2 aes } \new Staff \relative { \set Staff.extraNatural = ##f aeses'2 aes } >>
e in questo modo si disattiva in tutti i righi:
<< \new Staff \relative { aeses'2 aes } \new Staff \relative { \set Score.extraNatural = ##f aeses'2 aes } >>
Un altro esempio: se la proprietà clefTransposition
viene posta
nel contesto Score
, cambia immediatamente il valore
della trasposizione in tutti i righi presenti e imposta un nuovo
valore predefinito che sarà applicato a tutti i righi.
Il comando opposto, \unset
, di fatto rimuove la proprietà
dal contesto, e questo fa sì che molte proprietà
tornino al valore predefinito. Solitamente \unset
non è
necessario dal momento che un nuovo comando \set
permetterà
di ottenere quanto si desidera.
I comandi \set
e \unset
possono trovarsi in qualsiasi
punto del file di input e avranno effetto dal momento in cui si
incontrano fino alla fine della partitura o finché la proprietà non
viene attivata (\set
) o disattivata (\unset
) di nuovo.
Proviamo a cambiare varie volte la dimensione del font, che influisce (tra
le altre cose) sulla dimensione delle teste delle note. La modifica è relativa
al valore predefinito, non all’ultimo valore impostato.
\relative { c'4 d % rimpicciolisce le teste di nota \set fontSize = #-4 e4 f | % ingrandisce le teste di nota \set fontSize = #2.5 g4 a % ripristina la dimensione predefinita \unset fontSize b4 c | }
Abbiamo visto come impostare i valori di diversi tipi di
proprietà. Si note che gli interi e i numeri sono sempre preceduti
da un segno di cancelletto, #
, mentre un valore vero o falso è
specificato con ##t
e ##f
, ovvero con due cancelletti.
Una proprietà testuale dovrebbe essere racchiusa tra virgolette, come
abbiamo visto prima, sebbene vedremo in seguito che in realtà il testo
può essere specificato in un modo molto più generale usando il potente
comando \markup
.
Impostare le proprietà di contesto con \with
Il valore predefinito delle proprietà di contesto possono essere impostate
anche nel momento in cui il contesto viene creato. Talvolta questo è un
modo più chiaro per specificare il valore della proprietà se questa deve
rimanere fissa per la durata del contesto. Un contesto creato col comando \new
può essere immediatamente seguito da un blocco \with { … }
dove
vengono impostati i valori predefiniti della proprietà. Ad esempio, se vogliamo
eliminare la stampa del bequadro per l’estensione di un rigo possiamo scrivere:
\new Staff \with { extraNatural = ##f }
così:
<< \new Staff { \relative { gisis'4 gis aeses aes } } \new Staff \with { extraNatural = ##f } { \relative { gisis'4 gis aeses aes } } >>
Si possono ancora cambiare dinamicamente le proprietà impostate in questo modo
usando \set
, mentre con \unset
si possono riportare al valore
predefinito impostato nel blocco \with
.
Quindi se la proprietà fontSize
viene inserita in una
proposizione \with
, imposta il valore predefinito
della dimensione del font. Se viene in seguito modificato con \set
,
questo nuovo valore predefinito può essere recuperato col comando
\unset fontSize
.
Impostare le proprietà di contesto con \context
I valori delle proprietà di un contesto possono essere impostate in tutti
i contesti di un particolare tipo, così come in tutti i contesti Staff
, con un
solo comando. Il tipo di contesto viene identificato attraverso il
suo nome, come Staff
, preceduto da una barra inversa (backslash): \Staff
.
La dichiarazione che imposta il valore della proprietà è la stessa che
abbiamo visto nel blocco \with
, introdotto prima. Viene posta in
un blocco \context
all’interno di un blocco \layout
. Ogni
blocco \context
avrà effetto su tutti i contesti del tipo specificato
nel blocco \score
o \book
nel quale il blocco
\layout
si trova. Ecco un esempio per mostrare la struttura:
\score { \new Staff { \relative { cisis''4 e d cis } } \layout { \context { \Staff extraNatural = ##t } } }
Se si vuole che la modifica della proprietà venga applicata a tutti i righi della partitura:
\score { << \new Staff { \relative { gisis'4 gis aeses aes } } \new Staff { \relative { gisis'4 gis aeses aes } } >> \layout { \context { \Score extraNatural = ##f } } }
Le proprietà di contesto impostate in questo modo possono essere sovrascritte per
alcuni particolari contesti attraverso asserzioni in un blocco \with
, e tramite
comandi \set
incorporati nelle asserzioni musicali.
Vedi anche
Guida alla notazione: Modifica delle impostazioni predefinite di un contesto, Il comando set.
Guida al funzionamento interno: Contexts, Tunable context properties.
[ << Concetti fondamentali ] | [Top][Contents][Index] | [ Modifica dell’output >> ] |
[ < Gli incisori ] | [ Up : Contesti e incisori ] | [ Aggiungere e togliere gli incisori > ] |