X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrob.cc;h=e43c71186c14f591251bc06907bdbfebfd9dc708;hb=23838d1d1ae8a457ad59adc81bf2f9fcbb531b44;hp=2377a5d963f92d794916185c6518b395fcf29aca;hpb=958e95822083954cad00e0a598eb9f12ceba67b9;p=lilypond.git diff --git a/lily/grob.cc b/lily/grob.cc index 2377a5d963..e43c71186c 100644 --- a/lily/grob.cc +++ b/lily/grob.cc @@ -38,6 +38,7 @@ #include "system.hh" #include "unpure-pure-container.hh" #include "warn.hh" +#include "lily-imports.hh" Grob * @@ -141,15 +142,36 @@ Grob::get_print_stencil () const retval = *m; bool transparent = to_boolean (get_property ("transparent")); + /* Process whiteout before color and grob-cause to prevent colored */ + /* whiteout background and larger file sizes with \pointAndClickOn. */ + /* A grob has to be visible, otherwise the whiteout property has no effect. */ + /* Calls the scheme procedure stencil-whiteout in scm/stencils.scm */ + if (!transparent && (scm_is_number (get_property("whiteout")) + || to_boolean (get_property ("whiteout")))) + { + Real thickness = robust_scm2double (get_property("whiteout"), 3.0) + * layout ()->get_dimension (ly_symbol2scm ("line-thickness")); + retval = *unsmob + (Lily::stencil_whiteout (retval.smobbed_copy (), + scm_from_double (thickness))); + } + + /* Calls the scheme procedure stencil-whiteout-box in scm/stencils.scm */ + if (!transparent && to_boolean (get_property ("whiteout-box"))) + { + retval = *unsmob + (Lily::stencil_whiteout_box (retval.smobbed_copy ())); + } + if (transparent) retval = Stencil (m->extent_box (), SCM_EOL); else { - SCM expr = m->expr (); - expr = scm_list_3 (ly_symbol2scm ("grob-cause"), - self_scm (), expr); + SCM expr = scm_list_3 (ly_symbol2scm ("grob-cause"), + self_scm (), + retval.expr ()); - retval = Stencil (m->extent_box (), expr); + retval = Stencil (retval.extent_box (), expr); } SCM rot = get_property ("rotation"); @@ -173,17 +195,6 @@ Grob::get_print_stencil () const retval = Stencil (retval.extent_box (), expr); } - /* process whiteout */ - /* a grob has to be visible, otherwise the whiteout property has no effect */ - if (!transparent && to_boolean (get_property ("whiteout"))) - { - /* Call the scheme procedure stencil-whiteout in scm/stencils.scm */ - /* to add a round-filled-box stencil to the stencil list */ - retval - = *unsmob (scm_call_1 (ly_lily_module_constant ("stencil-whiteout"), - retval.smobbed_copy ())); - } - SCM id = get_property ("id"); if (scm_is_string (id)) { @@ -828,6 +839,7 @@ ADD_INTERFACE (Grob, "transparent " "vertical-skylines " "whiteout " + "whiteout-box " ); /****************************************************************