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)
35 miny_f_ = interline + #beams * interbeam
36 ideal8 = 2 * interline + interbeam
37 ideal16,32,64,128 = 1.5 * interline + #beams * interbeam
40 miny_f_ = interline + #beams * interbeam
41 ideal8,16 = 2 interline + #beams * interbeam
42 ideal32,64,128 = 1.5 interline + #beams * interbeam
46 Real internote_f = s->paper ()->internote_f ();
47 Real interline_f = 2.0 * 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 () * dir_ / internote_f;
64 idealy_f_ *= internote_f;
66 idealy_f_ += interbeam_f * mult_i_;
72 idealy_f_ += 2.0 * interline_f;
74 idealy_f_ += 1.5 * interline_f;
76 miny_f_ += 1.0 * interline_f;
78 // lowest beam of (UP) beam must never be lower than second staffline
79 miny_f_ = miny_f_ >? (- 2 * internote_f - beam_f
80 + (mult_i_ > 0) * beam_f + interbeam_f * (mult_i_ - 1));
82 idealy_f_ /= internote_f;
83 miny_f_ /= internote_f;
86 DOUT << "dir_: " << dir_ << '\n';
87 DOUT << "mult_i_: " << mult_i_ << '\n';
88 DOUT << "idealy_f_: " << idealy_f_ << '\n';
89 DOUT << "miny_f_: " << miny_f_ << '\n';
92 idealy_f_ = miny_f_ >? idealy_f_;