]> git.donarmstrong.com Git - lilypond.git/blob - lily/stem-info.cc
patch::: 1.1.19.jcn3: zonder haar
[lilypond.git] / lily / stem-info.cc
1 /*
2   stem-info.cc -- implement Stem_info
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--1998 Jan Nieuwenhuizen <janneke@gnu.org>
7
8 */
9
10 #include "proto.hh"
11 #include "misc.hh"
12 #include "debug.hh"
13 #include "atom.hh"
14 #include "stem.hh"
15 #include "paper-def.hh"
16 #include "lookup.hh"
17 #include "stem-info.hh"
18
19 Stem_info::Stem_info ()
20 {
21 }
22
23 Stem_info::Stem_info (Stem*s)
24 {
25   stem_l_ = s;
26   x_ = stem_l_->hpos_f ();
27   dir_ = stem_l_->dir_;
28   beam_dir_ = stem_l_->beam_dir_;
29   mult_i_ = stem_l_->mult_i_;
30
31   /*
32     [TODO]
33     make this runtime
34
35     Breitkopf + H\"artel:
36     miny_f_ = interline + #beams * interbeam
37     ideal8 = 2 * interline + interbeam
38     ideal16,32,64,128 = 1.5 * interline + #beams * interbeam
39
40     * B\"arenreiter:
41     miny_f_ = interline + #beams * interbeam
42     ideal8,16 = 2 interline + #beams * interbeam
43     ideal32,64,128 = 1.5 interline + #beams * interbeam
44        
45     */
46
47   Real internote_f = stem_l_->paper ()->internote_f ();
48   Real interbeam_f = stem_l_->paper ()->interbeam_f (mult_i_);
49   Real beam_f = stem_l_->paper ()->beam_thickness_f ();
50          
51
52   {
53       static int i = 1;
54       DOUT << "******" << i++ << "******\n" 
55            << "begin_f: " << stem_l_->stem_begin_f () * dir_ 
56            << "\nchord_f/i: " << stem_l_->chord_start_f () * dir_ / internote_f << '\n';
57   }
58
59   /*
60     For simplicity, we'll assume dir = UP and correct if 
61     dir = DOWN afterwards.
62    */
63   idealy_f_ = stem_l_->chord_start_f () * beam_dir_ / internote_f;
64   idealy_f_ *= internote_f;
65
66   Real break_i = (int)rint (stem_l_->paper ()->get_var ("beam_multiple_break"));
67   Real min_stem1_f = stem_l_->paper ()->get_var ("beam_minimum_stem1");
68   Real min_stem2_f = stem_l_->paper ()->get_var ("beam_minimum_stem2");
69   Real ideal_stem1_f = stem_l_->paper ()->get_var ("beam_ideal_stem1");
70   Real ideal_stem2_f = stem_l_->paper ()->get_var ("beam_ideal_stem2");
71   Real shorten_f = stem_l_->paper ()->get_var ("forced_stem_shorten");
72
73   if (!beam_dir_ || (beam_dir_ == dir_))
74     /* normal (beamed) stem */
75     {
76       idealy_f_ += interbeam_f * mult_i_;
77       miny_f_ = idealy_f_;
78       maxy_f_ = INT_MAX;
79
80       if (mult_i_ < break_i)
81         {
82           idealy_f_ += ideal_stem1_f;
83           miny_f_ += min_stem1_f;
84         }
85       else
86         {
87           idealy_f_ += ideal_stem2_f;
88           miny_f_ += min_stem2_f;
89         }
90
91       /*
92         stems in unnatural (forced) direction are shortened but
93         - central line is never 'forced'
94         - beamed stems are shortened only by beam itself
95        */
96       if (!mult_i_ && ((int)stem_l_->chord_start_f ()) && (stem_l_->dir_ != stem_l_->get_default_dir ()))
97         {
98           idealy_f_ -= shorten_f;
99         }
100
101       // lowest beam of (UP) beam must never be lower than second staffline
102       miny_f_ = miny_f_ >? (- 2 * internote_f - beam_f
103         + (mult_i_ > 0) * beam_f + interbeam_f * (mult_i_ - 1));
104     }
105   else
106     /* knee */
107     {
108       idealy_f_ -= beam_f;
109       maxy_f_ = idealy_f_;
110       miny_f_ = -INT_MAX;
111
112       if (mult_i_ < break_i)
113         {
114           idealy_f_ -= ideal_stem1_f;
115           maxy_f_ -= min_stem1_f;
116         }
117       else
118         {
119           idealy_f_ -= ideal_stem2_f;
120           maxy_f_ -= min_stem2_f;
121         }
122     }
123
124
125   idealy_f_ /= internote_f;
126   miny_f_ /= internote_f;
127   maxy_f_ /= internote_f;
128
129   DOUT << "dir_: " << dir_ << '\n';
130   DOUT << "mult_i_: " << mult_i_ << '\n';
131   DOUT << "idealy_f_: " << idealy_f_ << '\n';
132   DOUT << "miny_f_: " << miny_f_ << '\n';
133   DOUT << "maxy_f_: " << maxy_f_ << '\n';
134
135   idealy_f_ = maxy_f_ <? idealy_f_;
136   idealy_f_ = miny_f_ >? idealy_f_;
137 }
138