COIN-OR::LEMON - Graph Library

Changeset 244:0e02be2ca43c in lemon-0.x for src/work/athos


Ignore:
Timestamp:
03/25/04 18:38:45 (21 years ago)
Author:
athos
Branch:
default
Phase:
public
Convert:
svn:c9d7d8f5-90d6-0310-b91f-818b3a526b0e/lemon/trunk@344
Message:

Betettem 1 file-ba a boundingbox-ot és az xy-t + egyéb apró módosítások.

Location:
src/work/athos/xy
Files:
1 deleted
2 edited

Legend:

Unmodified
Added
Removed
  • src/work/athos/xy/boundingbox.cc

    r240 r244  
    1 #include <boundingbox.h>
     1#include <xy.h>
    22
    33#include <iostream>
  • src/work/athos/xy/xy.h

    r242 r244  
    118118  }
    119119
     120
     121  /** \brief
     122     Implementation of a bounding box of plainvectors.
     123     
     124  */
     125  template<typename T>
     126    class BoundingBox {
     127      xy<T> bottom_left, top_right;
     128      bool _empty;
     129    public:
     130     
     131      ///Default constructor: an empty bounding box
     132      BoundingBox() { _empty = true; }
     133
     134      ///Constructing the instance from one point
     135      BoundingBox(xy<T> a) { bottom_left=top_right=a; _empty = false; }
     136
     137      ///Is there any point added
     138      bool empty() const {
     139        return _empty;
     140      }
     141
     142      ///Gives back the bottom left corner (if the bounding box is empty, then the return value is not defined)
     143      xy<T> bottomLeft() const {
     144        return bottom_left;
     145      };
     146
     147      ///Gives back the top right corner (if the bounding box is empty, then the return value is not defined)
     148      xy<T> topRight() const {
     149        return top_right;
     150      };
     151
     152      ///Checks whether a point is inside a bounding box
     153      bool inside(const xy<T>& u){
     154        if (_empty)
     155          return false;
     156        else{
     157          return ((u.x-bottom_left.x)*(top_right.x-u.x) >= 0 &&
     158                  (u.y-bottom_left.y)*(top_right.y-u.y) >= 0 );
     159        }
     160      }
     161 
     162      ///Increments a bounding box with a point
     163      BoundingBox& operator +=(const xy<T>& u){
     164        if (_empty){
     165          bottom_left=top_right=u;
     166          _empty = false;
     167        }
     168        else{
     169          if (bottom_left.x > u.x) bottom_left.x = u.x;
     170          if (bottom_left.y > u.y) bottom_left.y = u.y;
     171          if (top_right.x < u.x) top_right.x = u.x;
     172          if (top_right.y < u.y) top_right.y = u.y;
     173        }
     174        return *this;
     175      };
     176 
     177      ///Sums a bounding box and a point
     178      BoundingBox operator +(const xy<T>& u){
     179        BoundingBox b = *this;
     180        return b += u;
     181      };
     182
     183      ///Increments a bounding box with an other bounding box
     184      BoundingBox& operator +=(const BoundingBox &u){
     185        if ( !u.empty() ){
     186          *this += u.bottomLeft();
     187          *this += u.topRight();
     188        }
     189        return *this;
     190      };
     191 
     192      ///Sums two bounding boxes
     193      BoundingBox operator +(const BoundingBox& u){
     194        BoundingBox b = *this;
     195        return b += u;
     196      };
     197
     198    };//class Boundingbox
     199
     200
     201
     202
    120203} //namespace hugo
    121204
Note: See TracChangeset for help on using the changeset viewer.