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