<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <!-- header_tag --> <html lang="en"> <head> <title>Defining new contexts - GNU LilyPond Notation Reference</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta name="description" content="GNU LilyPond Notation Reference"> <meta name="generator" content="makeinfo 4.11"> <link title="Top" rel="start" href="index.de.html#Top"> <link rel="up" href="Interpretation-contexts.de.html#Interpretation-contexts" title="Interpretation contexts"> <link rel="prev" href="Changing-context-default-settings.de.html#Changing-context-default-settings" title="Changing context default settings"> <link rel="next" href="Aligning-contexts.de.html#Aligning-contexts" title="Aligning contexts"> <link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"> <!-- Copyright (C) 1999--2007 by the authors Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.1 or any later version published by the Free Software Foundation; with no Invariant Sections. A copy of the license is included in the section entitled ``GNU Free Documentation License''. --> <meta http-equiv="Content-Style-Type" content="text/css"> <style type="text/css"><!-- pre.display { font-family:inherit } pre.format { font-family:inherit } pre.smalldisplay { font-family:inherit; font-size:smaller } pre.smallformat { font-family:inherit; font-size:smaller } pre.smallexample { font-size:smaller } pre.smalllisp { font-size:smaller } span.sc { font-variant:small-caps } span.roman { font-family:serif; font-weight:normal; } span.sansserif { font-family:sans-serif; font-weight:normal; } hr { border:0; height:1; color: #000000; background-color: #000000; } /* hr { border: none; height: 1px; color: #666666; background-color: #666666; } body { border-left: 1px solid #666666; border-right: 1px solid #666666; color: #332d28; margin-right: auto; margin-left: auto; width: 60em; list-style-type: square; font-family: Arial,Helvetica,sans-serif; padding-right: 1em; padding-left: 1em; } a { border-bottom: 1px dashed #344242; text-decoration: none; color: #344242; } a:link { text-decoration: none; } a:visited { border-bottom: 1px dashed #666666; color: #666666; } a:active { border-bottom: 1px solid #00cccc; color: #00cccc; } a:hover { border-bottom: 1px solid #1d7b85; color: #1d7b85; } blockquote { border: 1px solid #cccccc; padding: 3px; width: 40em; } .node { border-left: 1px solid #666666; margin: -0.5em 0px 1em; padding: 2px 1px 0px; font-style: italic; } .node a { border: none; text-decoration: underline; font-style: normal; font-weight: bold; } .verbatim { font-family: "Courier New",Courier,monospace; } .unnumberedsubsubsec { font-size: large; color: #1d7b85; } .subsubheading { font-size: large; color: #3b220d; } .contents { border: 1px dashed #339999; margin: 3px 2em; list-style-type: square; padding-right: 1em; width: 40em; background-color: #fcfff9; } .contents a { border-bottom: 1px dashed #423d34; text-decoration: none; color: #423d34; } .contents a:visited { border-bottom: 1px dashed #666666; color: #666666; } .contents a:active { border-bottom: 1px solid #f0d86d; color: #f0d86d; } .contents a:hover { border-bottom: 1px solid #3b220d; color: #3b220d; } .menu { border-left: 1px dashed #339999; margin: 3px 2em 1em; list-style-type: square; padding-left: 1.4em; width: 40em; } .unnumbered { } h2 { font-size: x-large; color: #1d7b85; } */ --></style> </head> <BODY BGCOLOR=WHITE TEXT=BLACK> <div class="node"> <p> <a name="Defining-new-contexts"></a> Next: <a rel="next" accesskey="n" href="Aligning-contexts.de.html#Aligning-contexts">Aligning contexts</a>, Previous: <a rel="previous" accesskey="p" href="Changing-context-default-settings.de.html#Changing-context-default-settings">Changing context default settings</a>, Up: <a rel="up" accesskey="u" href="Interpretation-contexts.de.html#Interpretation-contexts">Interpretation contexts</a> <hr> </div> <h4 class="subsection">5.1.5 Defining new contexts</h4> <p>Specific contexts, like <code>Staff</code> and <code>Voice</code>, are made of simple building blocks. It is possible to create new types of contexts with different combinations of engraver plug-ins. <p>The next example shows how to build a different type of <code>Voice</code> context from scratch. It will be similar to <code>Voice</code>, but only prints centered slash note heads. It can be used to indicate improvisation in jazz pieces, <blockquote> <p> <a href="../1c/lily-19988917.ly"> <img align="middle" border="0" src="../1c/lily-19988917.png" alt="[image of music]"> </a> </p> </blockquote> <p>These settings are defined within a <code>\context</code> block inside a <code>\layout</code> block, <pre class="example">\layout { \context { ... } } </pre> <p>In the following discussion, the example input shown should go in place of the <small class="dots">...</small> in the previous fragment. <p>First it is necessary to define a name for the new context: <pre class="example">\name ImproVoice </pre> <p>Since it is similar to the <code>Voice</code>, we want commands that work on (existing) <code>Voice</code>s to remain working. This is achieved by giving the new context an alias <code>Voice</code>, <pre class="example">\alias Voice </pre> <p>The context will print notes and instructive texts, so we need to add the engravers which provide this functionality, <pre class="example">\consists Note_heads_engraver \consists Text_engraver </pre> <p>but we only need this on the center line, <pre class="example">\consists Pitch_squash_engraver squashedPosition = #0 </pre> <p>The <a name="index-Pitch_005fsquash_005fengraver-2636"></a><a href="../lilypond-internals/Pitch_005fsquash_005fengraver.de.html#Pitch_005fsquash_005fengraver">Pitch_squash_engraver</a> modifies note heads (created by <a name="index-Note_005fheads_005fengraver-2637"></a><a href="../lilypond-internals/Note_005fheads_005fengraver.de.html#Note_005fheads_005fengraver">Note_heads_engraver</a>) and sets their vertical position to the value of <code>squashedPosition</code>, in this case <code>0</code>, the center line. <p>The notes look like a slash, and have no stem, <pre class="example">\override NoteHead #'style = #'slash \override Stem #'transparent = ##t </pre> <p>All these plug-ins have to cooperate, and this is achieved with a special plug-in, which must be marked with the keyword <code>\type</code>. This should always be <code>Engraver_group</code>. <pre class="example">\type "Engraver_group" </pre> <p>Put together, we get <pre class="example">\context { \name ImproVoice \type "Engraver_group" \consists "Note_heads_engraver" \consists "Text_engraver" \consists Pitch_squash_engraver squashedPosition = #0 \override NoteHead #'style = #'slash \override Stem #'transparent = ##t \alias Voice } </pre> <p><a name="index-g_t_005caccepts-2638"></a><a name="index-g_t_005caccepts-2639"></a> Contexts form hierarchies. We want to hang the <code>ImproVoice</code> under <code>Staff</code>, just like normal <code>Voice</code>s. Therefore, we modify the <code>Staff</code> definition with the <code>\accepts</code> command, <pre class="example">\context { \Staff \accepts ImproVoice } </pre> <p><a name="index-g_t_005cdenies-2640"></a><a name="index-g_t_005cdenies-2641"></a> The opposite of <code>\accepts</code> is <code>\denies</code>, which is sometimes needed when reusing existing context definitions. <p>Putting both into a <code>\layout</code> block, like <pre class="example">\layout { \context { \name ImproVoice ... } \context { \Staff \accepts "ImproVoice" } } </pre> <p>Then the output at the start of this subsection can be entered as <pre class="example">\relative c'' { a4 d8 bes8 \new ImproVoice { c4^"ad lib" c c4 c^"undress" c c_"while playing :)" } a1 } </pre> <!-- footer_tag --><br><hr> <div class="node"> <p> Next: <a rel="next" accesskey="n" href="Aligning-contexts.de.html#Aligning-contexts">Aligning contexts</a>, Previous: <a rel="previous" accesskey="p" href="Changing-context-default-settings.de.html#Changing-context-default-settings">Changing context default settings</a>, Up: <a rel="up" accesskey="u" href="Interpretation-contexts.de.html#Interpretation-contexts">Interpretation contexts</a> </div> <div style="background-color: #e8ffe8; padding: 2; border: #c0ffc0 1px solid;"> <p> <font size="-1"> Diese Seite ist für LilyPond-2.11.57 (Entwicklungszweig). <br> <address> Fehler bitte an <a href="http://post.gmane.org/post.php?group=gmane.comp.gnu.lilypond.bugs">http://post.gmane.org/post.php?group=gmane.comp.gnu.lilypond.bugs</a> melden. </address> <br> Ihre <a href="http://lilypond.org/web/devel/participating/documentation-adding">Vorschläge für die Dokumentation</a> sind willkommen. </font> </p> </div> <P> Andere Sprachen: <a href="Defining-new-contexts.fr.html">français</a>, <a href="Defining-new-contexts.es.html">español</a>. <BR> </P> </BODY></html>