X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fnote-column.cc;h=76bde1c3d60f632cae6a3c338f2009fef5504632;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=ca85f08e123f47d180da89f445441c4c0ad86d26;hpb=03ce3667568361ee7433032988a4089c64de2ec7;p=lilypond.git diff --git a/lily/note-column.cc b/lily/note-column.cc index ca85f08e12..76bde1c3d6 100644 --- a/lily/note-column.cc +++ b/lily/note-column.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2006 Han-Wen Nienhuys + (c) 1997--2008 Han-Wen Nienhuys */ #include "note-column.hh" @@ -142,12 +142,6 @@ Note_column::translate_rests (Grob *me, int dy) } } -void -Note_column::set_dotcol (Grob *me, Grob *d) -{ - Axis_group_interface::add_element (me, d); -} - Grob * Note_column::first_head (Grob *me) { @@ -181,20 +175,48 @@ Note_column::accidentals (Grob *me) return acc; } +Grob * +Note_column::dot_column (Grob *me) +{ + extract_grob_set (me, "note-heads", heads); + for (vsize i = 0; i < heads.size (); i++) + { + Grob *dots = unsmob_grob (heads[i]->get_object ("dot")); + if (dots) + return dots->get_parent (X_AXIS); + } + + return 0; +} + Grob * Note_column::arpeggio (Grob *me) { return unsmob_grob (me->get_object ("arpeggio")); } +/* If a note-column contains a cross-staff stem then + nc->extent (Y_AXIS, refp) will not consider the extent of the stem. + If you want the extent of the stem to be included (and you are safe + from any cross-staff issues) then call this function instead. */ +Interval +Note_column::cross_staff_extent (Grob *me, Grob *refp) +{ + Interval iv = me->extent (refp, Y_AXIS); + if (Grob *s = get_stem (me)) + iv.unite (s->extent (refp, Y_AXIS)); + + return iv; +} + ADD_INTERFACE (Note_column, - "Stem and noteheads combined", + "Stem and noteheads combined.", /* properties */ - "accidentals " "arpeggio " "force-hshift " "horizontal-shift " + "ignore-collision " "note-heads " "rest " "rest-collision "