Sophie

Sophie

distrib > Mandriva > 2009.0 > i586 > by-pkgid > 3a7b4dfc766af1222d90c7f03a0844e6 > files > 7122

lilypond-doc-2.11.57-1mdv2009.0.i586.rpm

<!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:&nbsp;<a rel="next" accesskey="n" href="Aligning-contexts.de.html#Aligning-contexts">Aligning contexts</a>,
Previous:&nbsp;<a rel="previous" accesskey="p" href="Changing-context-default-settings.de.html#Changing-context-default-settings">Changing context default settings</a>,
Up:&nbsp;<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&nbsp;<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:&nbsp;<a rel="next" accesskey="n" href="Aligning-contexts.de.html#Aligning-contexts">Aligning contexts</a>,
Previous:&nbsp;<a rel="previous" accesskey="p" href="Changing-context-default-settings.de.html#Changing-context-default-settings">Changing context default settings</a>,
Up:&nbsp;<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>