From dfff5d3d1a1001f65d1f7183837f56ccd64fb15a Mon Sep 17 00:00:00 2001 From: Keith OHara Date: Sat, 6 Apr 2013 22:31:45 -0700 Subject: [PATCH] Remove dots that overflow chords; issue 3179 --- input/regression/chord-dots.ly | 17 +++++++++++++++ lily/dot-column.cc | 39 ++++++++++++++++++++++++++++++---- scm/define-grob-properties.scm | 3 +++ scm/define-grobs.scm | 1 + 4 files changed, 56 insertions(+), 4 deletions(-) create mode 100644 input/regression/chord-dots.ly diff --git a/input/regression/chord-dots.ly b/input/regression/chord-dots.ly new file mode 100644 index 0000000000..957788d4bc --- /dev/null +++ b/input/regression/chord-dots.ly @@ -0,0 +1,17 @@ +\version "2.17.16" + +\header { + texidoc = +"The column of dots on a chord is limited to the height +of the chord plus @code{chord-dots-limit} staff-positions." +} + +\layout{ ragged-right = ##t } + +\new Staff \transpose c c' { + \override Staff.DotColumn.chord-dots-limit = #1 + << + { 4. r8 4. r8 } \\ + { f4.. r16 4.. r16} + >> +} diff --git a/lily/dot-column.cc b/lily/dot-column.cc index 6cba432639..9b4a3831b0 100644 --- a/lily/dot-column.cc +++ b/lily/dot-column.cc @@ -59,7 +59,7 @@ Dot_column::calc_positioning_done (SCM smob) vector dots = extract_grob_array (me, "dots"); - vector main_heads; + vector parent_stems; Real ss = 0; Grob *commonx = me; @@ -73,7 +73,7 @@ Dot_column::calc_positioning_done (SCM smob) commonx = stem->common_refpoint (commonx, X_AXIS); if (Stem::first_head (stem) == n) - main_heads.push_back (n); + parent_stems.push_back (stem); } } @@ -83,8 +83,8 @@ Dot_column::calc_positioning_done (SCM smob) extract_grob_set (me, "side-support-elements", support); Interval base_x; - for (vsize i = 0; i < main_heads.size (); i++) - base_x.unite (main_heads[i]->extent (commonx, X_AXIS)); + for (vsize i = 0; i < parent_stems.size (); i++) + base_x.unite (Stem::first_head (parent_stems[i])->extent (commonx, X_AXIS)); for (vsize i = 0; i < support.size (); i++) { @@ -152,6 +152,36 @@ Dot_column::calc_positioning_done (SCM smob) we instead must use their pure Y positions. */ vector_sort (dots, pure_position_less); + + SCM chord_dots_limit = me->get_property ("chord-dots-limit"); + if (scm_is_number (chord_dots_limit)) + { + // Sort dots by stem, then check for dots above the limit for each stem + vector > dots_each_stem (parent_stems.size ()); + for (vsize i = 0; i < dots.size (); i++) + if (Grob *stem = unsmob_grob (dots[i]->get_parent (Y_AXIS) + -> get_object ("stem"))) + for (vsize j = 0; j < parent_stems.size (); j++) + if (stem == parent_stems[j]) + { + dots_each_stem[j].push_back (dots[i]); + break; + } + for (vsize j = 0; j < parent_stems.size (); j++) + { + Interval chord = Stem::head_positions (parent_stems[j]); + int total_room = ((int) chord.length () + 2 + + scm_to_int (chord_dots_limit)) / 2; + int total_dots = dots_each_stem[j].size (); + // remove excessive dots from the ends of the stem + for (int first_dot = 0; total_dots > total_room; total_dots--) + if (0 == (total_dots - total_room) % 2) + dots_each_stem[j][first_dot++]->suicide (); + else + dots_each_stem[j][first_dot + total_dots - 1]->suicide (); + } + } + for (vsize i = dots.size (); i--;) { if (!dots[i]->is_live ()) @@ -236,6 +266,7 @@ ADD_INTERFACE (Dot_column, " dots so they do not clash with staff lines.", /* properties */ + "chord-dots-limit " "dots " "positioning-done " "direction " diff --git a/scm/define-grob-properties.scm b/scm/define-grob-properties.scm index a5b0895c9b..8fae43bcd1 100644 --- a/scm/define-grob-properties.scm +++ b/scm/define-grob-properties.scm @@ -170,6 +170,9 @@ when a spanner is broken at a line break.") ;;; ;;; c ;;; + (chord-dots-limit ,integer? "Limits the column of dots +on each chord to the height of the chord plus +@code{chord-dots-limit} staff-positions.") (circled-tip ,boolean? "Put a circle at start/@/end of hairpins (al/@/del niente).") (clip-edges ,boolean? "Allow outward pointing beamlets at the diff --git a/scm/define-grobs.scm b/scm/define-grobs.scm index a4e0d52a76..de27efca1e 100644 --- a/scm/define-grobs.scm +++ b/scm/define-grobs.scm @@ -727,6 +727,7 @@ (DotColumn . ( (axes . (,X)) + (chord-dots-limit . 3) (direction . ,RIGHT) (positioning-done . ,ly:dot-column::calc-positioning-done) (X-extent . ,ly:axis-group-interface::width) -- 2.39.5