2 stem-info.cc -- implement Stem_info
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--1998 Jan Nieuwenhuizen <jan@digicash.com>
16 #include "paper-def.hh"
18 #include "stem-info.hh"
20 Stem_info::Stem_info ()
24 Stem_info::Stem_info (Stem const *s)
28 beam_dir_ = s->beam_dir_;
36 miny_f_ = interline + #beams * interbeam
37 ideal8 = 2 * interline + interbeam
38 ideal16,32,64,128 = 1.5 * interline + #beams * interbeam
41 miny_f_ = interline + #beams * interbeam
42 ideal8,16 = 2 interline + #beams * interbeam
43 ideal32,64,128 = 1.5 interline + #beams * interbeam
47 Real internote_f = s->paper ()->internote_f ();
48 Real interbeam_f = s->paper ()->interbeam_f (mult_i_);
49 Real beam_f = s->paper ()->beam_thickness_f ();
54 DOUT << "******" << i++ << "******\n"
55 << "begin_f: " << s->stem_begin_f () * dir_
56 << "\nchord_f/i: " << s->chord_start_f () * dir_ / internote_f << '\n';
60 For simplicity, we'll assume dir = UP and correct if
61 dir = DOWN afterwards.
63 idealy_f_ = s->chord_start_f () * beam_dir_ / internote_f;
64 idealy_f_ *= internote_f;
66 Real break_i = (int)rint (s->paper ()->get_var ("beam_multiple_break"));
67 Real min_stem1_f = s->paper ()->get_var ("beam_minimum_stem1");
68 Real min_stem2_f = s->paper ()->get_var ("beam_minimum_stem2");
69 Real ideal_stem1_f = s->paper ()->get_var ("beam_ideal_stem1");
70 Real ideal_stem2_f = s->paper ()->get_var ("beam_ideal_stem2");
72 if (!beam_dir_ || (beam_dir_ == dir_))
74 idealy_f_ += interbeam_f * mult_i_;
78 if (mult_i_ < break_i)
80 idealy_f_ += ideal_stem1_f;
81 miny_f_ += min_stem1_f;
85 idealy_f_ += ideal_stem2_f;
86 miny_f_ += min_stem2_f;
89 // lowest beam of (UP) beam must never be lower than second staffline
90 miny_f_ = miny_f_ >? (- 2 * internote_f - beam_f
91 + (mult_i_ > 0) * beam_f + interbeam_f * (mult_i_ - 1));
100 if (mult_i_ < break_i)
102 idealy_f_ -= ideal_stem1_f;
103 maxy_f_ -= min_stem1_f;
107 idealy_f_ -= ideal_stem2_f;
108 maxy_f_ -= min_stem2_f;
112 idealy_f_ /= internote_f;
113 miny_f_ /= internote_f;
114 maxy_f_ /= internote_f;
116 DOUT << "dir_: " << dir_ << '\n';
117 DOUT << "mult_i_: " << mult_i_ << '\n';
118 DOUT << "idealy_f_: " << idealy_f_ << '\n';
119 DOUT << "miny_f_: " << miny_f_ << '\n';
120 DOUT << "maxy_f_: " << maxy_f_ << '\n';
122 idealy_f_ = maxy_f_ <? idealy_f_;
123 idealy_f_ = miny_f_ >? idealy_f_;