X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fskyline.hh;h=b84a5de953bcdafe0b9fb7c0c6500717ec901faa;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=bccac37238d1fbb7948027d92829732aeb87676b;hpb=875b287f353888564d12882449447afcaabf097a;p=lilypond.git diff --git a/lily/include/skyline.hh b/lily/include/skyline.hh index bccac37238..b84a5de953 100644 --- a/lily/include/skyline.hh +++ b/lily/include/skyline.hh @@ -3,14 +3,13 @@ source file of the GNU LilyPond music typesetter - (c) 2006--2007 Joe Neeman + (c) 2006--2008 Joe Neeman */ #ifndef SKYLINE_HH #define SKYLINE_HH -#include - +#include "lily-proto.hh" #include "axis.hh" #include "box.hh" #include "interval.hh" @@ -18,15 +17,15 @@ #include "std-vector.hh" #include "smobs.hh" +#include + struct Building { - Interval iv_; - Drul_array height_; - + Real end_; Real y_intercept_; Real slope_; - void precompute (); + void precompute (Real start, Real start_height, Real end_height, Real end); Building (Real start, Real start_height, Real end_height, Real end); Building (Box const &b, Real horizon_padding, Axis a, Direction d); void print () const; @@ -34,15 +33,8 @@ struct Building Real height (Real x) const; Real intersection_x (Building const &other) const; void leading_part (Real chop); - bool conceals_beginning (Building const &other) const; - bool conceals (Building const &other) const; - bool sane () const; - Building sloped_neighbour (Real horizon_padding, Direction d) const; - - bool operator< (Building const &other) - { - return iv_[LEFT] < other.iv_[LEFT]; - } + bool conceals (Building const &other, Real x) const; + Building sloped_neighbour (Real start, Real horizon_padding, Direction d) const; }; class Skyline @@ -53,19 +45,22 @@ private: void internal_merge_skyline (list*, list*, list *const result); - list internal_build_skyline (list*); + list internal_build_skyline (list*, Real, Axis, Direction); DECLARE_SIMPLE_SMOBS(Skyline); + public: Skyline (); Skyline (Skyline const &src); Skyline (Direction sky); Skyline (vector const &bldgs, Real horizon_padding, Axis a, Direction sky); Skyline (Box const &b, Real horizon_padding, Axis a, Direction sky); - vector to_points () const; + + vector to_points (Axis) const; void merge (Skyline const &); void insert (Box const &, Real horizon_padding, Axis); void print () const; + void print_points () const; void raise (Real); void shift (Real); Real distance (Skyline const &) const; @@ -75,24 +70,7 @@ public: bool is_empty () const; }; -class Skyline_pair -{ -private: - Drul_array skylines_; - - DECLARE_SIMPLE_SMOBS(Skyline_pair); -public: - Skyline_pair (); - Skyline_pair (vector const &boxes, Real horizon_padding, Axis a); - Skyline_pair (Box const &, Real horizon_padding, Axis a); - void raise (Real); - void shift (Real); - void insert (Box const &, Real horizon_padding, Axis); - void merge (Skyline_pair const &other); - Skyline &operator [] (Direction d); - Skyline const &operator [] (Direction d) const; - bool is_empty () const; -}; +extern bool debug_skylines; #endif /* SKYLINE_HH */