]> git.donarmstrong.com Git - lilypond.git/blob - lily/extender-spanner.cc
patch::: 1.1.5.jcn2: extender
[lilypond.git] / lily / extender-spanner.cc
1 /*
2   extender-spanner.cc -- implement Extender_spanner
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1998 Jan Nieuwenhuizen <janneke@gnu.org>
7 */
8
9 #include "atom.hh"
10 #include "box.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 "extender-spanner.hh"
17 #include "text-item.hh"
18 #include "text-def.hh"
19
20 IMPLEMENT_IS_TYPE_B1 (Extender_spanner, Directional_spanner);
21   
22 Extender_spanner::Extender_spanner ()
23   : Directional_spanner ()
24 {
25   textitem_l_drul_[LEFT] = textitem_l_drul_[RIGHT] = 0;
26   dy_f_drul_[LEFT] = dy_f_drul_[RIGHT] = 0.0;
27   dx_f_drul_[LEFT] = dx_f_drul_[RIGHT] = 0.0;
28 }
29
30 Extender_spanner::Extender_spanner (Extender_spanner const& c)
31   : Directional_spanner (c)
32 {
33   textitem_l_drul_ = c.textitem_l_drul_;
34   dy_f_drul_ = c.dy_f_drul_;
35   dx_f_drul_ = c.dx_f_drul_;
36 }
37
38 Extender_spanner::~Extender_spanner ()
39 {
40 }
41
42 Offset
43 Extender_spanner::center () const
44 {
45   Real dx = width ().length ();
46
47   return Offset (dx / 2, 0);
48 }
49
50 Molecule*
51 Extender_spanner::brew_molecule_p () const
52 {
53   Molecule* mol_p = new Molecule;
54
55   Real w = width ().length ();
56   
57   w += (dx_f_drul_[RIGHT] - dx_f_drul_[LEFT]);
58   
59   Atom a = lookup_l ()->extender (w);
60
61   a.translate (Offset (dx_f_drul_[LEFT], dy_f_drul_[LEFT]));
62
63   mol_p->add_atom (a);
64
65   return mol_p;
66 }
67
68 void
69 Extender_spanner::do_add_processing ()
70 {
71   Direction d = LEFT;
72   Drul_array<Text_item *> new_textitem_drul = textitem_l_drul_;
73   do {
74     if (!textitem_l_drul_[d])
75       new_textitem_drul[d] = textitem_l_drul_[(Direction)-d];
76   } while (flip(&d) != LEFT);
77   textitem_l_drul_ = new_textitem_drul;
78 }
79
80 Interval
81 Extender_spanner::do_height () const
82 {
83   return Interval (0,0);
84 }
85
86 void
87 Extender_spanner::do_post_processing ()
88 {
89   assert (textitem_l_drul_[LEFT] || textitem_l_drul_[RIGHT]);
90
91   // UGH
92   Real nw_f = paper ()->note_width () * 0.8;
93
94   Direction d = LEFT;
95   do
96     {
97       Text_item* t = textitem_l_drul_[d] ? textitem_l_drul_[d] : textitem_l_drul_[(Direction)-d];
98
99       dy_f_drul_[d] += t->height ().length () / 2;
100       if (d == LEFT)
101         dx_f_drul_[d] += t->width ().length ();
102       else
103         dx_f_drul_[d] -= d * nw_f / 2;
104
105 //      dx_f_drul_[d] -= d * nw_f / 4;
106     }
107   while (flip(&d) != LEFT);
108 }
109
110 void
111 Extender_spanner::do_substitute_dependency (Score_element* o, Score_element* n)
112 {
113   Text_item* new_l = n ? dynamic_cast<Text_item *> (n) : 0;
114   if (dynamic_cast <Item *> (o) == textitem_l_drul_[LEFT])
115     textitem_l_drul_[LEFT] = new_l;
116   else if (dynamic_cast <Item *> (o) == textitem_l_drul_[RIGHT])
117     textitem_l_drul_[RIGHT] = new_l;
118 }
119   
120 void
121 Extender_spanner::set_textitem (Direction d, Text_item* textitem_l)
122 {
123   assert (!textitem_l_drul_[d]);
124   textitem_l_drul_[d] = textitem_l;
125   set_bounds (d, textitem_l);
126
127   add_dependency (textitem_l);
128 }
129