2 This file is part of LilyPond, the GNU music typesetter.
4 Copyright (C) 2006--2012 Joe Neeman <joeneeman@gmail.com>
6 LilyPond is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
11 LilyPond is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with LilyPond. If not, see <http://www.gnu.org/licenses/>.
23 #include "lily-proto.hh"
26 #include "interval.hh"
27 #include "direction.hh"
28 #include "std-vector.hh"
40 void precompute (Real start, Real start_height, Real end_height, Real end);
41 Building (Real start, Real start_height, Real end_height, Real end);
42 Building (Box const &b, Axis a, Direction d);
45 Real height (Real x) const;
46 Real intersection_x (Building const &other) const;
47 void leading_part (Real chop);
48 bool conceals (Building const &other, Real x) const;
49 Real shift_to_intersect (Real x, Real y) const;
55 list<Building> buildings_;
58 void internal_merge_skyline (list<Building> *, list<Building> *,
59 list<Building> *result) const;
60 list<Building> internal_build_skyline (list<Building> *) const;
61 Real internal_distance (Skyline const &, Real horizon_padding, Real *touch_point) const;
62 Real internal_distance (Skyline const &, Real *touch_point) const;
65 DECLARE_SIMPLE_SMOBS (Skyline);
69 Skyline (Skyline const &src);
70 Skyline (Direction sky);
71 Skyline (vector<Box> const &bldgs, Axis a, Direction sky);
72 Skyline (vector<Drul_array<Offset> > const &bldgs, Axis a, Direction sky);
73 Skyline (vector<Skyline_pair> const &skypairs, Direction sky);
74 Skyline (Box const &b, Axis a, Direction sky);
76 vector<Offset> to_points (Axis) const;
78 void merge (Skyline const &);
79 void insert (Box const &, Axis);
81 void print_points () const;
84 Real distance (Skyline const &, Real horizon_padding = 0) const;
85 Real touching_point (Skyline const &, Real horizon_padding = 0) const;
86 Real shift_to_avoid (Skyline const &other, Real, Direction d, Real horizon_padding = 0);
87 Real raise_to_avoid (Skyline const &other, Real, Direction d, Real horizon_padding = 0);
88 Drul_array<Real> shifts_to_avoid_intersection (Skyline const &, Real horizon_padding = 0) const;
89 Interval raises_to_avoid_intersection (Skyline const &, Real horizon_padding = 0) const;
90 Real height (Real airplane) const;
91 Real max_height () const;
92 Real max_height_position () const;
95 void set_minimum_height (Real height);
97 bool is_empty () const;
98 Skyline padded (Real horizon_padding) const;
100 DECLARE_SCHEME_CALLBACK (get_touching_point, (SCM, SCM, SCM));
101 DECLARE_SCHEME_CALLBACK (get_distance, (SCM, SCM, SCM));
102 DECLARE_SCHEME_CALLBACK (get_max_height, (SCM));
103 DECLARE_SCHEME_CALLBACK (get_max_height_position, (SCM));
104 DECLARE_SCHEME_CALLBACK (get_height, (SCM, SCM));
107 extern bool debug_skylines;
109 #endif /* SKYLINE_HH */