X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fbox.cc;h=bc0a975ed0d3d91b0be837f5810af3fb8b991795;hb=9dd88ce33b9caf1ff6746c92f3b5080727dde946;hp=722e08278cbc2351a0a0171183bc0c846faafe6b;hpb=51e7345f199657c7b868d5653f209703e897fca8;p=lilypond.git diff --git a/lily/box.cc b/lily/box.cc index 722e08278c..bc0a975ed0 100644 --- a/lily/box.cc +++ b/lily/box.cc @@ -1,56 +1,143 @@ /* - box.cc -- implement Box + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 1996--2012 Han-Wen Nienhuys - (c) 1996--2000 Han-Wen Nienhuys + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #include "box.hh" -#include "array.hh" void Box::translate (Offset o) { - for (Axis i=X_AXIS; i < NO_AXES; incr(i)) + for (Axis i = X_AXIS; i < NO_AXES; incr (i)) interval_a_[i] += o[i]; } void Box::unite (Box b) { - for (Axis i=X_AXIS; i < NO_AXES; incr(i)) + for (Axis i = X_AXIS; i < NO_AXES; incr (i)) interval_a_[i].unite (b[i]); } -/** - Initialize to empty. - */ -Box::Box() -{ +Real +Box::area () const +{ + return interval_a_[X_AXIS].length () + * interval_a_[Y_AXIS].length (); +} + +Box::Box () +{ } void Box::set_empty () { interval_a_[X_AXIS].set_empty (); - interval_a_[Y_AXIS].set_empty (); + interval_a_[Y_AXIS].set_empty (); +} + +bool +Box::is_empty () const +{ + return interval_a_[X_AXIS].is_empty () + || interval_a_[Y_AXIS].is_empty (); } Box::Box (Interval ix, Interval iy) { - x() = ix; - y() = iy; + x () = ix; + y () = iy; } Interval & -Box::operator[] (Axis a) +Box::operator [] (Axis a) { return interval_a_[a]; } Interval -Box::operator[] (Axis a)const +Box::operator [] (Axis a) const { return interval_a_[a]; } + +void +Box::scale (Real s) +{ + interval_a_[X_AXIS] *= s; + interval_a_[Y_AXIS] *= s; +} + +void +Box::add_point (Offset o) +{ + interval_a_[X_AXIS].add_point (o[X_AXIS]); + interval_a_[Y_AXIS].add_point (o[Y_AXIS]); +} + +Offset +Box::center () const +{ + return Offset (interval_a_[X_AXIS].center (), + interval_a_[Y_AXIS].center ()); +} + +void +Box::widen (Real x, Real y) +{ + interval_a_[X_AXIS].widen (x); + interval_a_[Y_AXIS].widen (y); +} + +void +Box::intersect (Box b) +{ + interval_a_[X_AXIS].intersect (b[X_AXIS]); + interval_a_[Y_AXIS].intersect (b[Y_AXIS]); +} + +// for debugging + +void +Box::print () +{ + printf ("X left %4.4f right %4.4f Y down %4.4f up %4.4f\n", + interval_a_[X_AXIS][LEFT], interval_a_[X_AXIS][RIGHT], + interval_a_[Y_AXIS][DOWN], interval_a_[Y_AXIS][UP]); +} + +/****************************************************************/ + +#include "ly-smobs.icc" + +IMPLEMENT_SIMPLE_SMOBS (Box); +IMPLEMENT_TYPE_P (Box, "ly:box?"); +IMPLEMENT_DEFAULT_EQUAL_P (Box); + +SCM +Box::mark_smob (SCM /* x */) +{ + return SCM_EOL; +} + +int +Box::print_smob (SCM /* x */, SCM p, scm_print_state *) +{ + scm_puts ("#", p); + return 1; +}