]> git.donarmstrong.com Git - lilypond.git/blob - lily/plet-spanner.cc
release: 0.1.58
[lilypond.git] / lily / plet-spanner.cc
1 /*
2   plet-spanner.cc -- implement Plet_spanner
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997 Jan Nieuwenhuizen <jan@digicash.com>
7 */
8
9 #include "atom.hh"
10 #include "boxes.hh"
11 #include "debug.hh"
12 #include "lookup.hh"
13 #include "molecule.hh"
14 #include "p-col.hh"
15 #include "paper-def.hh"
16 #include "plet-spanner.hh"
17 #include "stem.hh"
18 #include "text-def.hh"
19
20 IMPLEMENT_IS_TYPE_B1 (Plet_spanner,Bow);
21   
22 Plet_spanner::Plet_spanner ()
23   : Bow ()
24 {
25   stem_l_drul_[RIGHT] =0;
26   stem_l_drul_[LEFT] =0;
27   visibility_i_ = 3;
28
29   tdef_p_ = new Text_def;
30   tdef_p_->align_i_ = CENTER;
31   tdef_p_->style_str_ = "italic";
32 }
33
34 Plet_spanner::Plet_spanner (Plet_spanner const& c)
35   : Bow (c)
36 {
37   tdef_p_ = new Text_def (*c.tdef_p_);
38   stem_l_drul_ = c.stem_l_drul_;
39   visibility_i_ = c.visibility_i_;
40 }
41
42 Plet_spanner::~Plet_spanner ()
43 {
44   delete tdef_p_;
45 }
46
47 Molecule*
48 Plet_spanner::brew_molecule_p () const
49 {
50   Molecule* mol_p = new Molecule;
51
52   Real w = width ().length ();
53   
54   Real dy_f = dy_f_drul_[RIGHT] - dy_f_drul_[LEFT];
55   
56   w += (dx_f_drul_[RIGHT] - dx_f_drul_[LEFT]);
57   
58   Atom a = paper ()->lookup_l ()->plet (dy_f, w, dir_);
59
60   a.translate (Offset (dx_f_drul_[LEFT], dy_f_drul_[LEFT]));
61
62   if (visibility_i_ >= 2)
63       mol_p->add (a);
64
65   Real interline_f = paper ()->interline_f ();
66   Real numy_f = (dir_ > 0 ? 0 : -interline_f) + dir_ * interline_f / 2;
67   Atom num (tdef_p_->get_atom (paper (), CENTER));
68   num.translate (Offset (width ().length () / 1.8 + dx_f_drul_[LEFT], 
69     dy_f_drul_[LEFT] + dy_f / 2 + numy_f));
70
71   if (visibility_i_ >= 1)
72     mol_p->add (num);
73
74   return mol_p;
75 }
76   
77 void
78 Plet_spanner::do_add_processing ()
79 {
80   if (! (stem_l_drul_[LEFT] && stem_l_drul_[RIGHT]))
81     warning (_ ("Lonely plet.. "));
82
83   Direction d = LEFT;
84   Drul_array<Stem *> new_stem_drul = stem_l_drul_;
85   do {
86     if (!stem_l_drul_[d])
87       new_stem_drul[d] = stem_l_drul_[(Direction)-d];
88   } while (flip(&d) != LEFT);
89   stem_l_drul_ = new_stem_drul;
90 }
91   
92 void
93 Plet_spanner::do_post_processing ()
94 {
95   Real interline_f = paper ()->interline_f ();
96   Real nh_f = interline_f / 2;
97   assert (stem_l_drul_[LEFT] || stem_l_drul_[RIGHT]);
98
99   // ugh
100   Real nw_f = paper ()->note_width () * 0.8;
101
102   Direction d = LEFT;
103   do
104     {
105       Stem* s = stem_l_drul_[d] ? stem_l_drul_[d] : stem_l_drul_[(Direction)-d];
106       dy_f_drul_[d] = dir_ == s->get_dir () ? s->stem_end_f ()
107         : s->stem_begin_f () + dir_ * nh_f / 2;
108       dy_f_drul_[d] *= .5 * interline_f;
109       dy_f_drul_[d] += dir_ * interline_f;
110       if (d == RIGHT)
111         dx_f_drul_[d] = nw_f;
112     }
113   while (flip(&d) != LEFT);
114 }
115
116 void
117 Plet_spanner::do_substitute_dependency (Score_elem* o, Score_elem* n)
118 {
119   Stem* new_l = n ? (Stem*)n->item () : 0;
120   if (o->item () == stem_l_drul_[LEFT])
121     stem_l_drul_[LEFT] = new_l;
122   else if (o->item () == stem_l_drul_[RIGHT])
123     stem_l_drul_[RIGHT] = new_l;
124 }
125   
126 void
127 Plet_spanner::set_default_dir ()
128 {
129   Real m = (stem_l_drul_[LEFT]->stem_end_f () 
130             + stem_l_drul_[RIGHT]->stem_end_f ()) / 2;
131   dir_ =  (m < 0) ? DOWN : UP;
132 }
133
134 void
135 Plet_spanner::set_stem (Direction d, Stem* stem_l)
136 {
137   assert (!stem_l_drul_[d]);
138   stem_l_drul_[d] = stem_l;
139   set_bounds (d, stem_l);
140
141   add_dependency (stem_l);
142 }
143