]> git.donarmstrong.com Git - lilypond.git/blob - lily/collision-engraver.cc
release: 1.5.13
[lilypond.git] / lily / collision-engraver.cc
1 /*
2   collision-reg.cc -- implement Collision_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "note-column.hh"
10 #include "collision.hh"
11
12 #include "engraver.hh"
13 #include "axis-group-interface.hh"
14
15 /*
16   collect Note_column, and as soon as there are 2 or more, put them in
17   a collision object.  */
18 class Collision_engraver : public Engraver {
19   Item * col_p_;
20   Link_array<Grob> note_column_l_arr_;
21
22 protected:
23   virtual void acknowledge_grob (Grob_info);
24   virtual void create_grobs ();
25   virtual void stop_translation_timestep ();
26 public:
27   TRANSLATOR_DECLARATIONS(Collision_engraver);
28 };
29
30
31 void
32 Collision_engraver::create_grobs ()
33 {
34   if (col_p_ || note_column_l_arr_.size () < 2)
35     return ;
36   if (!col_p_) 
37     {
38       col_p_ = new Item (get_property ("NoteCollision"));
39       Axis_group_interface::set_interface (col_p_);
40       Axis_group_interface::set_axes (col_p_, X_AXIS, Y_AXIS);
41
42       announce_grob (col_p_,0);
43     }
44   
45   for (int i=0; i< note_column_l_arr_.size (); i++)
46     Collision::add_column (col_p_,note_column_l_arr_[i]);
47 }
48
49 void
50 Collision_engraver::acknowledge_grob (Grob_info i)
51 {
52   if (Note_column::has_interface (i.grob_l_))
53     {
54       /*should check Y axis? */
55       if (Note_column::rest_b (i.grob_l_) || i.grob_l_->parent_l (X_AXIS))
56         return ;
57
58       note_column_l_arr_.push (i.grob_l_);
59     }
60 }
61
62 void
63 Collision_engraver::stop_translation_timestep ()
64 {
65   if (col_p_) 
66     {
67       typeset_grob (col_p_);
68       col_p_ =0;
69     }
70   note_column_l_arr_.clear ();
71 }
72
73 Collision_engraver::Collision_engraver ()
74 {
75   col_p_ =0;
76 }
77
78
79
80
81 ENTER_DESCRIPTION(Collision_engraver,
82 /* descr */       "",
83 /* creats*/       "NoteCollision",
84 /* acks  */       "note-column-interface",
85 /* reads */       "",
86 /* write */       "");