X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fpercent-repeat-item.cc;h=af527a87946a07a81fe17b342748425c8cb96b28;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=68d3bd6c1fb078a65d0ec7326aaba53589d7e140;hpb=d9b43b93f2c885409bafdb157138158f65cc49aa;p=lilypond.git diff --git a/lily/percent-repeat-item.cc b/lily/percent-repeat-item.cc index 68d3bd6c1f..af527a8794 100644 --- a/lily/percent-repeat-item.cc +++ b/lily/percent-repeat-item.cc @@ -1,85 +1,82 @@ -/* - percent-repeat-item.cc -- implement Percent_repeat_item_interface - +/* + percent-repeat-item.cc -- implement Percent_repeat_item_interface + source file of the GNU LilyPond music typesetter - - (c) 2001--2002 Han-Wen Nienhuys - - */ -#include -#include "grob.hh" + (c) 2001--2008 Han-Wen Nienhuys +*/ + +#include "percent-repeat-item.hh" +#include "item.hh" #include "lookup.hh" -#include "molecule.hh" #include "font-interface.hh" -#include "font-metric.hh" -#include "percent-repeat-item.hh" - -Molecule -Percent_repeat_item_interface::brew_slash ( Grob *me) +Stencil +Percent_repeat_item_interface::brew_slash (Grob *me) { - Real slope = gh_scm2double (me->get_grob_property ("slope")); + Real slope = robust_scm2double (me->get_property ("slope"), 1); Real wid = 2.0 / slope; /* todo: check out if in staff-rule thickness normally. - */ - Real thick = gh_scm2double (me->get_grob_property ("thickness")); - Molecule m = Lookup::repeat_slash (wid, slope, thick); + */ + Real thick = robust_scm2double (me->get_property ("thickness"), 1); + Stencil m = Lookup::repeat_slash (wid, slope, thick); m.translate_axis (-m.extent (Y_AXIS).center (), Y_AXIS); return m; } -/* - todo: use grob props for dot_neg_kern, slash_neg_kern? - */ -Molecule -Percent_repeat_item_interface::x_percent (Grob *me, int count, - Real dot_neg_kern, - Real slash_neg_kern) +Stencil +Percent_repeat_item_interface::x_percent (Grob *me, int count) { - Molecule m ; - Molecule s = brew_slash (me); - - for (int i = count; i--;) - { - m.add_at_edge (X_AXIS, RIGHT, s, -slash_neg_kern); - } - Molecule d1 = Font_interface::get_default_font (me)->find_by_name ("dots-dot"); - Molecule d2 = d1; - d1.translate_axis (0.5, Y_AXIS ); + Stencil m; + Stencil s = brew_slash (me); + + Real dot_neg_kern = + robust_scm2double (me->get_property ("dot-negative-kern"), 0.75); + Real slash_neg_kern = + robust_scm2double (me->get_property ("slash-negative-kern"), 1.6); + + for (int i = count; i--;) + m.add_at_edge (X_AXIS, RIGHT, s, -slash_neg_kern); + Stencil d1 = Font_interface::get_default_font (me)->find_by_name ("dots.dot"); + Stencil d2 = d1; + d1.translate_axis (0.5, Y_AXIS); d2.translate_axis (-0.5, Y_AXIS); - + m.add_at_edge (X_AXIS, LEFT, d1, -dot_neg_kern); m.add_at_edge (X_AXIS, RIGHT, d2, -dot_neg_kern); + m.translate_axis (- m.extent (X_AXIS).center (), X_AXIS); return m; } -MAKE_SCHEME_CALLBACK(Percent_repeat_item_interface,double_percent,1); +MAKE_SCHEME_CALLBACK (Percent_repeat_item_interface, double_percent, 1); SCM Percent_repeat_item_interface::double_percent (SCM grob) { Grob *me = unsmob_grob (grob); - Molecule m = x_percent (me, 2, 0.75, 1.6); - m.translate_axis (- m.extent (X_AXIS).center (), X_AXIS); + Stencil m = x_percent (me, 2); return m.smobbed_copy (); } -MAKE_SCHEME_CALLBACK(Percent_repeat_item_interface,beat_slash,1); +MAKE_SCHEME_CALLBACK (Percent_repeat_item_interface, beat_slash, 1); SCM Percent_repeat_item_interface::beat_slash (SCM grob) { Grob *me = unsmob_grob (grob); - Molecule m = brew_slash (me); + Stencil m = brew_slash (me); return m.smobbed_copy (); } - - - - - +ADD_INTERFACE (Percent_repeat_item_interface, + "Repeats that look like percent signs.", + + /* properties */ + "dot-negative-kern " + "slash-negative-kern " + "slope " + "thickness " + );