// This file is part of the Coriolis Project. // Copyright (C) Laboratoire LIP6 - Departement ASIM // Universite Pierre et Marie Curie // // Main contributors : // Christophe Alexandre // Sophie Belloeil // Hugo Clément // Jean-Paul Chaput // Damien Dupuis // Christian Masson // Marek Sroka // // The Coriolis Project 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 2 of the // License, or (at your option) any later version. // // The Coriolis Project 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 the Coriolis Project; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // // License-Tag // // Date : 19/07/2006 // Author : Christophe Alexandre // // Authors-Tag #include "MaukaBox.h" namespace MAUKA { Box& Update(Box& box, const Point& src, const Point& dst) { Unit minX = box.GetXMin(); Unit maxX = box.GetXMax(); Unit minY = box.GetYMin(); Unit maxY = box.GetYMax(); if (dst.GetX() > src.GetX()) { if (src.GetX() == minX) { box = Box(); return box; } else if (dst.GetX() > maxX) { maxX = dst.GetX(); } } else if (dst.GetX() < src.GetX()) { if (src.GetX() == maxX) { box = Box(); return box; } else if (dst.GetX() < minX) { minX = dst.GetX(); } } if (dst.GetY() > src.GetY()) { if (src.GetY() == minY) { box = Box(); return box; } else if (dst.GetY() > maxY) { maxY = dst.GetY(); } } else if (dst.GetY() < src.GetY()) { if (src.GetY() == maxY) { box = Box(); return box; } else if (dst.GetY() < minY) { minY = dst.GetY(); } } box = Box(Point(minX, minY), Point(maxX, maxY)); return box; } }