]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/es/user/tweaks.itely
Merge branch 'master' of ssh+git://git.sv.gnu.org/srv/git/lilypond
[lilypond.git] / Documentation / es / user / tweaks.itely
1 @c -*- coding: utf-8; mode: texinfo; -*-
2 @c This file is part of lilypond.tely
3 @ignore
4     Translation of GIT committish: 0204d415337bf74ae8626f396e6ea3cc5669c8f2
5
6     When revising a translation, copy the HEAD committish of the
7     version that you are working on.  See TRANSLATION for details.
8 @end ignore
9
10 @node Tweaking output
11 @chapter Tweaking output
12
13 Este capítulo trata de cómo modificar la salida.  LilyPond es extremadamente
14 configurable; prácticamente todos los fragmentos de la salida se pueden cambiar.
15
16
17 @menu
18 * Moving objects::              
19 * Fixing overlapping notation::  
20 * Common tweaks::               
21 * Default files::               
22 * Fitting music onto fewer pages::  
23 * Advanced tweaks with Scheme::  
24 * Avoiding tweaks with slower processing::  
25 @end menu
26
27
28 @node Moving objects
29 @section Moving objects
30
31 Aunque pueda sorprenderle, LilyPond no es perfecto.  Ciertos
32 elementos de notación se pueden superponer, lo que es una lástima,
33 pero en casi todos los casos se resuelve fácilmente.
34
35 @c  FIXME: find a better example for 5.1 Moving Objects.  -gp
36 @c  yes, I want this TODO to be visible to end-users.  It's better
37 @c  than having nothing at all.
38 HACER: con las nuevas funcionalidades de espaciado en la versión 2.12, estos ejemplos específicos
39 ya no son de relevancia.  Sin embargo siguen demostrando las poderosas funcionalidades de lilypond,
40 así que quedan aquí hasta que alguien elabore unos ejemplos mejores.
41
42 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
43   % temporary code to break this example:
44   \override TextScript #'outside-staff-priority = ##f
45 e4^\markup{ \italic ritenuto } g b e
46 @end lilypond
47
48 @cindex padding
49
50 La solución más fácil es aumentar la distancia entre el objeto
51 (texto en este caso, pero muy bien podrían ser digitaciones o dinámicas)
52 y la nota.  En LilyPond, esto se llama la propiedad
53 @code{padding} (relleno); se mide en espacios de pentagrama.  Para la mayor
54 parte de los objetos, este valor ronda la cantidad de 1.0 o menos (varía dependiendo del
55 objeto). Queremos aumentarlo, así que probaremos el valor 1.5
56
57 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
58   % temporary code to break this example:
59   \override TextScript #'outside-staff-priority = ##f
60 \once \override TextScript #'padding = #1.5
61 e4^\markup{ \italic ritenuto } g b e
62 @end lilypond
63
64 Esto tiene un mejor aspecto, pero no es suficiente.  Después de probar
65 con algunos valores, creemos que 2.3 es el mejor número en este caso. Sin embargo
66 esta cantidad es el mero resultado del ensayo y error y de mi gusto personal
67 acerca de la notación.  Pruebe el ejemplo anterior con 2.3... pero también con otros valores 
68 mayores (y menores).  ¿Cuál cree que queda mejor?
69
70 La propiedad @code{staff-padding} (relleno de pentagrama) está estrechamente relacionada.
71 @code{padding} controla la cantidad de espacio mínima entre un objeto y el objeto más cercano
72 (generalmente la nota o las líneas del pentagrama);
73 @code{staff-padding} controla la cantidad mínima de espacio entre un
74 objeto y el pentagrama.  Ello supone una sutil diferencia, pero podrá 
75 observar el comportamiento a continuación.
76
77 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
78   % temporary code to break this example:
79   \override TextScript #'outside-staff-priority = ##f
80 c4^"piu mosso" b a b
81 \once \override TextScript #'padding = #4.6
82 c4^"piu mosso" d e f
83 \once \override TextScript #'staff-padding = #4.6
84 c4^"piu mosso" fis a g
85 \break
86 c'4^"piu mosso" b a b
87 \once \override TextScript #'padding = #4.6
88 c4^"piu mosso" d e f
89 \once \override TextScript #'staff-padding = #4.6
90 c4^"piu mosso" fis a g
91 @end lilypond
92
93 @cindex desplazamiento adicional
94
95 Otra solución nos proporciona un control absoluto sobre la situación del objeto: podemos
96 moverlo horizontal o verticalmente.  Se hace con la propiedad
97 @code{extra-offset} (desplazamiento adicional).  Es ligeramente más complicado y puede
98 causar otros problemas.  Cuando movemos objetos con @code{extra-offset},
99 el movimiento se hace después de que LilyPond haya colocado todos los demás objetos.
100 Esto significa
101 que el resultado podría entrar en conflicto con otros objetos.
102
103 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
104   % temporary code to break this example:
105   \override TextScript #'outside-staff-priority = ##f
106 \once \override TextScript #'extra-offset = #'( 1.0 . -1.0 )
107 e4^\markup{ \italic ritenuto } g b e
108 @end lilypond
109
110 Con @code{extra-offset}, el primer número controla el movimiento
111 horizontal (negativo hacia la izquierda); el segundo número controla el movimiento
112 vertical (positivo hacia arriba).  Después de algunos ensayos, hemos decidido que los siguientes valores
113 son apropiados
114
115 @lilypond[quote,fragment,ragged-right,verbatim,relative=2]
116   % temporary code to break this example:
117   \override TextScript #'outside-staff-priority = ##f
118 \once \override TextScript #'extra-offset = #'( -1.6 . 1.0 )
119 e4^\markup{ \italic ritenuto } g b e
120 @end lilypond
121
122 @noindent
123 Una vez más, estos números son simplemente el resultado de algunos experimentos y
124 de observar la salida.  Quizá prefiera que el texto se encuentre algo más arriba,
125 o a la izquierda, o en cualquier dirección.  ¡Pruébelo y observe el resultado!
126
127 Una advertencia final: en esta sección hemos usado
128
129 @example
130 \once \override TextScript @dots{}
131 @end example
132
133 Esto altera la presentación del texto para la nota siguiente.  Si la nota no
134 tiene ningún texto, este truco no hace nada (y @strong{no} se queda esperando al
135 siguiente fragmento de texto).  Para cambiar el comportamiento permanentemente a partir
136 del comando, omita el @code{\once}.  Para detener este truco, use
137 @code{\revert} (revertir).  Todo esto se explica en profundidad en
138 @ruser{The \override command}.
139
140 @lilypond[quote,fragment,ragged-right,verbatim,relative=3]
141   % temporary code to break this example:
142   \override TextScript #'outside-staff-priority = ##f
143 c4^"piu mosso" b
144 \once \override TextScript #'padding = #4.6
145   a4 b
146 c4^"piu mosso" d e f
147 \once \override TextScript #'padding = #4.6
148 c4^"piu mosso" d e f
149 c4^"piu mosso" d e f
150 \break
151 \override TextScript #'padding = #4.6
152 c4^"piu mosso" d e f
153 c4^"piu mosso" d e f
154 \revert TextScript #'padding
155 c4^"piu mosso" d e f
156 @end lilypond
157
158 @seealso
159
160 En el presente manual: @ruser{The \override command}, @ruser{Common tweaks}.
161
162
163 @node Fixing overlapping notation
164 @section Fixing overlapping notation
165
166 En @ruser{Moving objects}, pudimos ver cómo mover un objeto @code{TextScript}.
167 El mismo mecanismo se puede usar para mover otros tipos de
168 objetos; simplemente sustituya @code{TextScript} con el nombre de
169 otro objeto.
170
171 Para encontrar el nombre del objeto, consulte la sección @q{@strong{véase también}} al
172 final de la página relevante dentro de la documentación.  Por ejemplo, al
173 final de @ruser{Dynamics}, vemos
174
175 @quotation
176 @seealso
177
178 Referencia del programa: @internalsref{DynamicText}, @internalsref{Hairpin}.
179 La posición vertical de estos símbolos se maneja por medio de
180 @internalsref{DynamicLineSpanner}.
181 @end quotation
182
183 @noindent
184 Así que para mover expresiones dinámicas verticalmente, usamos
185
186 @example
187 \override DynamicLineSpanner #'padding = #2.0
188 @end example
189
190 No podemos listar todos y cada uno de los objetos, pero presentamos a continuación una lista
191 de los objetos más comunes.
192
193 @multitable @columnfractions .33 .66
194 @headitem Tipo de objeto                        @tab Nombre del objeto
195 @item Expresiones dinámicas (verticalmente)     @tab @code{DynamicLineSpanner}
196 @item Expresiones dinámicas (horizontalmente)   @tab @code{DynamicText}
197 @item Ligaduras de unión                        @tab @code{Tie}
198 @item Ligaduras de expresión                    @tab @code{Slur}
199 @item Articulaciones                            @tab @code{Script}
200 @item Digitaciones                              @tab @code{Fingering}
201 @item Texto, p.ej. @code{^"text"}               @tab @code{TextScript}
202 @item Llamadas de ensayo o marcas de texto      @tab @code{RehearsalMark}
203 @end multitable
204
205
206 @node Common tweaks
207 @section Common tweaks
208
209 Algunas sustituciones son tan comunes que se proporcionan comandos preestablecidos
210 como atajos, como @code{\slurUp} (ligadura hacia arriba) y @code{\stemDown} (plica hacia abajo).  Estos
211 comandos se describen dentro de la Referencia de Notación bajo las secciones
212 correspondientes.
213
214 La lista completa de modificaciones disponibles para cada tipo de
215 objeto (como ligaduras o barras de corchea) están documentadas en la Referencia del
216 Programa.  Sin embargo, muchos objetos de la presentación comparten propiedades que se pueden
217 usar para aplicar trucos genéricos.
218
219 @itemize @bullet
220
221 @cindex relleno
222
223 @item
224 La propiedad @code{padding} (relleno) se puede establecer de forma que incremente
225 (o disminuya) la distancia entre símbolos que se imprimen encima
226 o debajo de las notas.  Se aplica a todos los objetos con
227 @code{side-position-interface}.
228
229 @lilypond[quote,fragment,relative=1,verbatim]
230 c2\fermata
231 \override Script #'padding = #3
232 b2\fermata
233 @end lilypond
234
235 @lilypond[quote,fragment,relative=1,verbatim]
236 % This will not work, see below:
237 \override MetronomeMark #'padding = #3
238 \tempo 4=120
239 c1
240 % This works:
241 \override Score.MetronomeMark #'padding = #3
242 \tempo 4=80
243 d1
244 @end lilypond
245
246 Observe en el segundo ejemplo cuán importante es determinar qué contexto
247 maneja un objeto determinado.  Debido a que el objeto @code{MetronomeMark} (indicación metronómica)
248 se maneja en el contexto @code{Score}, los cambios de propiedades dentro del
249 contexto @code{Voice} no se tendrán en cuenta.  Para ver más detalles, consulte
250 @ruser{Constructing a tweak}.
251
252 @cindex extra-offset (desplazamiento adicional)
253
254 @item
255 La propiedad @code{extra-offset} mueve objetos en la salida;
256 requiere una pareja de números.  El primer número
257 controla el movimiento horizontal, un número positivo moverá
258 el objeto hacia la derecha.  El segundo número controla el movimiento
259 vertical; un número positivo lo desplazará hacia arriba.  La
260 propiedad @code{extra-offset} es una funcionalidad de bajo nivel: el motor
261 de formateo es completamente olvidadizo respecto de estos desplazamientos.
262
263 En el ejemplo siguiente, la segunda digitación se desplaza un poco hacia
264 la izquierda y 1.8 espacios de pentagrama hacia abajo:
265
266 @lilypond[quote,fragment,relative=1,verbatim]
267 \stemUp
268 f-5
269 \once \override Fingering
270     #'extra-offset = #'(-0.3 . -1.8)
271 f-5
272 @end lilypond
273
274 @item
275 El establecimiento de la propiedad @code{transparent} provocará que un objeto se imprima
276 con @q{tinta invisible}: el objeto no se imprime, pero se conserva todo el resto
277 de su comportamiento.  El objeto aún ocupa un espacio, toma parte en las colisiones,
278 y se le pueden adjuntar ligaduras de unión o de expresión y barras de corchea.
279
280 @cindex objetos transparentes
281 @cindex quitar objetos
282 @cindex ocultar objetos
283 @cindex objetos invisibles
284 El ejemplo siguiente demuestra cómo conectar distintas voces
285 utilizando ligaduras.  Normalmente las ligaduras sólo unen dos notas de la misma voz.
286 Al introducir una ligadura en una voz distinta,
287
288 @lilypond[quote,fragment,relative=2]
289 << {
290   b8~ b8\noBeam
291 } \\ {
292   b[ g8]
293 } >>
294 @end lilypond
295
296 @noindent
297 y suprimiendo la primera plica hacia arriba en dicha voz, la ligadura parece cruzarse de una
298 voz a otra:
299
300
301 @lilypond[quote,fragment,relative=2,verbatim]
302 << {
303   \once \override Stem #'transparent = ##t
304   b8~ b8\noBeam
305 } \\ {
306   b[ g8]
307 } >>
308 @end lilypond
309
310 Para asegurarse de que la plica que hemos suprimido no aprieta demasiado a la
311 ligadura, también alargamos la plica, estableciendo su @code{length} (longitud) a
312 @code{8},
313
314 @lilypond[quote,fragment,relative=2,verbatim]
315 << {
316   \once \override Stem #'transparent = ##t
317   \once \override Stem #'length = #8
318   b8~ b8\noBeam
319 } \\ {
320   b[ g8]
321 } >>
322 @end lilypond
323
324 @end itemize
325
326 @cindex Trucos, distancias
327 @cindex Distancias
328
329 Las distancias en LilyPond se miden en espacios de pentagrama, mientras que
330 las propiedades de grosor se miden en grosores de líneas de pentagrama.  Algunas
331 propiedades son diferentes; por ejemplo, el grosor de las barras de corchea
332 se mide en espacios de pentagrama.  Para más información, consulte la porción
333 correspondiente de la referencia del programa.
334
335
336 @node Size of objects
337 @subsection Size of objects
338
339 UNTRANSLATED NODE: IGNORE ME
340
341 @node Default files
342 @section Default files
343
344 La documentación de la Referencia del Programa contiene una gran cantidad de información
345 sobre LilyPond, pero más información aún se puede obtener a partir de la observación
346 de los archivos internos de LilyPond.
347
348 Algunos ajustes por omisión como las definiciones de las
349 @code{\header@{@}}s (encabezamientos) están almacenados en archivos @code{.ly}.
350 Otros ajustes como las definiciones de los comandos de marcado se almacenan
351 como archivos @code{.scm} (de Scheme).  Cae fuera del ámbito de presente manual
352 cualquier explicación más profunda; los usuarios están advertidos de que se necesita
353 una considerable cantidad de conocimientos técnicos
354 para comprender estos archivos.
355
356 @itemize @bullet
357
358 @item Linux: @file{@var{directorio_de_instalación}/lilypond/usr/share/lilypond/current/}
359
360 @item OSX:
361 @file{@var{carpeta_de_instalación}/LilyPond.app/Contents/Resources/share/lilypond/current/}.
362 Para llegar aquí, o bien entre con @code{cd} en este directorio desde el
363 Terminal, o haga control-clic sobre la aplicación LilyPond y elija
364 @q{Mostrar el Contenido del Paquete}.
365
366 @item Windows: @file{@var{carpeta_de_instalación}/LilyPond/usr/share/lilypond/current/}
367
368 @end itemize
369
370 Los directorios @file{ly/} y @file{scm/} son de especial interés.
371 Archivos como @file{ly/property-init.ly} y
372 @file{ly/declarations-init.ly} definen todos los trucos comunes.
373
374
375 @node Fitting music onto fewer pages
376 @section Fitting music onto fewer pages
377
378 A veces puede acabar con uno o dos pentagramas en una segunda página
379 (o tercera, o cuarta...).  Es fastidioso sobre todo si observa las
380 páginas anteriores y parece haber
381 espacio suficiente en ellas.
382
383 Al investigar asuntos relacionados con la presentación, la herramienta
384 @code{annotate-spacing} (anotar el espaciado) no tiene precio.
385 Este comando imprime los valores de algunos comandos de espaciado;
386 consulte @ruser{Displaying spacing} para ver más detalles.  A partir de
387 la salida de de @code{annotate-spacing}, podemos ver qué márgenes podríamos desear alterar.
388
389 Aparte de los márgenes, existen otras opciones para ahorrar espacio:
390
391 @itemize
392 @item
393 Puede indicarle a LilyPond que coloque los sistemas tan juntos como sea
394 posible (para que quepan tantos sistemas como sea posible sobre una página),
395 pero luego separar estos sistemas para que no haya ningún espacio vacío
396 al final de la página.
397
398 @example
399 \paper @{
400   between-system-padding = #0.1
401   between-system-space = #0.1
402   ragged-last-bottom = ##f
403   ragged-bottom = ##f
404 @}
405 @end example
406
407 @item
408 Puede forzar el número de sistemas (es decir, si LilyPond quiere
409 tipografiar la música con 11 sistemas, puede forzarlo 
410 para que use 10).
411
412 @example
413 \paper @{
414   system-count = #10
415 @}
416 @end example
417
418 @item
419 Evite (o reduzca) el uso de objetos que aumenten el tamaño
420 vertical de un sistema.  Por ejemplo, las repeticiones con
421 primera y segunda vez necesitan espacio adicional.  Si
422 estas repeticiones abarcan dos sistemas, ocuparán más espacio
423 que un solo sistema con las repeticiones y otro sistema sin ellas.
424
425 Otro ejemplo es desplazar las expresiones dinámicas que se
426 @q{asoman por encima} de un sistema.
427
428 @lilypond[verbatim,quote,fragment]
429 \relative c' {
430   e4 c g\f c
431   \override DynamicLineSpanner #'padding = #-1.8
432   \override DynamicText #'extra-offset = #'( -2.1 . 0)
433   e4 c g\f c
434 }
435 @end lilypond
436
437 @item
438 Altere el espaciado horizontal por medio de @code{SpacingSpanner}.  Consulte
439 @ruser{Changing horizontal spacing} para ver más detalles.
440
441 @lilypond[verbatim,quote]
442 \score {
443   \relative c'' {
444     g4 e e2 | f4 d d2 | c4 d e f | g4 g g2 |
445     g4 e e2 | f4 d d2 | c4 e g g | c,1 |
446     d4 d d d | d4 e f2 | e4 e e e | e4 f g2 |
447     g4 e e2 | f4 d d2 | c4 e g g | c,1 |
448   }
449   \layout {
450     \context {
451       \Score
452       \override SpacingSpanner
453                 #'base-shortest-duration = #(ly:make-moment 1 4)
454     }
455   }
456 }
457 @end lilypond
458
459 @end itemize
460
461
462 @node Advanced tweaks with Scheme
463 @section Advanced tweaks with Scheme
464
465 Hemos visto cómo la salida de LilyPond se puede modificar de manera muy profunda utilizando
466 comandos como
467 @code{\override TextScript #'extra-offset = ( 1 . -1)}.  Pero
468 tenemos un potencial incluso mayor si utilizamos Scheme.  Para ver una explicación completa
469 de esto, consulte el @ruser{Scheme tutorial} e
470 @ruser{Interfaces for programmers}.
471
472 Podemos usar Scheme simplemente para sobreponer (@code{\override}) comandos,
473
474 @lilypond[quote,verbatim,ragged-right]
475 padText = #(define-music-function (parser location padding) (number?)
476 #{
477   \once \override TextScript #'padding = #$padding
478 #})
479
480 \relative c''' {
481   c4^"piu mosso" b a b
482   \padText #1.8
483   c4^"piu mosso" d e f
484   \padText #2.6
485   c4^"piu mosso" fis a g
486 }
487 @end lilypond
488
489 Podemos usarlo para crear comandos nuevos,
490
491 @lilypond[quote,verbatim,ragged-right]
492 tempoMark = #(define-music-function (parser location padding marktext)
493                                     (number? string?)
494 #{
495   \once \override Score . RehearsalMark #'padding = $padding
496   \once \override Score . RehearsalMark #'extra-spacing-width = #'(+inf.0 . -inf.0)
497   \mark \markup { \bold $marktext }
498 #})
499
500 \relative c'' {
501   c2 e
502   \tempoMark #3.0 #"Allegro"
503   g c
504 }
505 @end lilypond
506
507 E incluso se le pueden pasar expresiones musicales.
508
509 @lilypond[quote,verbatim,ragged-right]
510 pattern = #(define-music-function (parser location x y) (ly:music? ly:music?)
511 #{
512   $x e8 a b $y b a e
513 #})
514
515 \relative c''{
516   \pattern c8 c8\f
517   \pattern {d16 dis} { ais16-> b\p }
518 }
519 @end lilypond
520
521
522 @node Avoiding tweaks with slower processing
523 @section Avoiding tweaks with slower processing
524
525 LilyPond puede llevar a cabo comprobaciones adicionales al tiempo que
526 procesa los archivos.  Estos comandos consumen tiempo, pero el
527 resultado puede necesitar menos trucos manuales.
528
529 @example
530 %%  asegura que las marcas de texto y letras de las canciones se encuentran dentro de los márgenes de la página
531 \override Score.PaperColumn #'keep-inside-line = ##t 
532 @end example
533
534
535