#include <vgl_box_2d.h>
Inheritance diagram for vgl_box_2d< Type >:

A 2d box with sides aligned with the x and y axes. Also supports operations required of a bounding box for geometric region tests.
A box can be empty; this is what the default constructor creates, or what is left after applying the empty() method. Use the add() methods to enlarge a box, and use the contains() methods to check for inclusion of a point or an other box.
To make the convex union of two boxes, use box1.add(box2).
MaxPosition
O-------------O
| |
| |
| Centroid |
| o |
| |
Y | |
| | |
| O-------------O
| MinPosition
O------X
O------X
| MinPosition
| O-------------O
| | |
Y | |
| Centroid |
| o |
| |
| |
| |
O-------------O
MaxPosition
Definition at line 78 of file vgl_box_2d.h.
Public Types | |
| enum | point_type { centre = 0, min_pos, max_pos } |
Public Member Functions | |
| vgl_box_2d () | |
| Default constructor (creates empty box). | |
| vgl_box_2d (Type const corner1[2], Type const corner2[2]) | |
| Construct using two corner points. | |
| vgl_box_2d (vgl_point_2d< Type > const &corner1, vgl_point_2d< Type > const &corner2) | |
| Construct using two corner points. | |
| vgl_box_2d (Type xmin, Type xmax, Type ymin, Type ymax) | |
| Construct using ranges in x (first two args) and y (last two). | |
| vgl_box_2d (Type const ref_point[2], Type width, Type height, point_type) | |
| Construct a box sized width x height at a given reference point. | |
| vgl_box_2d (vgl_point_2d< Type > const &ref_point, Type width, Type height, point_type) | |
| Construct a box sized width x height at a given reference point. | |
| bool | operator== (vgl_box_2d< Type > const &b) const |
| Equality test. | |
| Type | width () const |
| Get width of this box (= x dimension). | |
| Type | height () const |
| Get height of this box (= y dimension). | |
| Type | area () const |
| Get "volume" (=area) of this box. | |
| Type | volume () const |
| Get "volume" (=area) of this box. | |
| Type | min_x () const |
| Get min x. | |
| Type | min_y () const |
| Get min y. | |
| Type | max_x () const |
| Get max x. | |
| Type | max_y () const |
| Get max y. | |
| vgl_point_2d< Type > | centroid () const |
| Get the centroid point. | |
| Type | centroid_x () const |
| Get x component of centroid. | |
| Type | centroid_y () const |
| Get y component of centroid. | |
| vgl_point_2d< Type > | min_point () const |
| Return lower left corner of box. | |
| vgl_point_2d< Type > | max_point () const |
| Return upper right corner of box. | |
| bool | is_empty () const |
| Return true if this box is empty. | |
| void | add (vgl_point_2d< Type > const &p) |
| Add a point to this box. | |
| void | add (vgl_box_2d< Type > const &b) |
| Make the convex union of two boxes. | |
| bool | contains (vgl_point_2d< Type > const &p) const |
| Return true iff the point p is inside this box. | |
| bool | contains (vgl_box_2d< Type > const &b) const |
| Return true iff the corner points of b are inside this box. | |
| bool | contains (Type const &x, Type const &y) const |
| Return true if (x,y) inside box, ie x_min <= x <= x_max etc. | |
| void | empty () |
| Make the box empty. | |
| void | set_min_x (Type m) |
| Set left side of box (other side ordinates unchanged). | |
| void | set_min_y (Type m) |
| Set bottom of box (other side ordinates unchanged). | |
| void | set_max_x (Type m) |
| Set right side (other side ordinates unchanged). | |
| void | set_max_y (Type m) |
| Set top (other side ordinates unchanged). | |
| void | set_centroid_x (Type cx) |
| Move box so centroid lies at cx (width and height unchanged). | |
| void | set_centroid_y (Type cy) |
| Move box so centroid lies at cy (width and height unchanged). | |
| void | set_width (Type width) |
| Modify width, retaining centroid at current position. | |
| void | set_height (Type height) |
| Modify height, retaining centroid at current position. | |
| void | expand_about_centroid (Type expand) |
| Add to width and height, centroid unchanged. | |
| void | scale_about_centroid (double s) |
| Scale width and height, centroid unchanged. | |
| void | scale_about_origin (double s) |
| Scale width and height, keeping scaled position of origin unchanged. | |
| void | setmin_position (Type const min_position[2]) |
| Modify bottom left. Top right only changed if necessary to avoid empty box. | |
| void | setmax_position (Type const max_position[2]) |
| Modify top right. Bottom left only changed if necessary to avoid empty box. | |
| void | set_min_point (vgl_point_2d< Type > const &min_pt) |
| Modify bottom left. Top right only changed if necessary to avoid empty box. | |
| void | set_max_point (vgl_point_2d< Type > const &max_pt) |
| Modify top right. Bottom left only changed if necessary to avoid empty box. | |
| void | set_centroid (Type const c[2]) |
| Move box so centroid lies at c (width, height unchanged). | |
| void | set_centroid (vgl_point_2d< Type > const &c) |
| Move box so centroid lies at c (width, height unchanged). | |
| vcl_ostream & | print (vcl_ostream &) const |
| Write "<vgl_box_2d x0,y0 to x1,y1>" to stream. | |
| vcl_ostream & | write (vcl_ostream &) const |
| Write "x0 y0 x1 y1(endl)" to stream. | |
| vcl_istream & | read (vcl_istream &) |
| Read x0,y0,x1,y1 from stream. | |
Protected Attributes | |
| Type | min_pos_ [2] |
| Type | max_pos_ [2] |
Related Functions | |
| (Note that these are not member functions.) | |
| vcl_ostream & | operator<< (vcl_ostream &s, vgl_box_2d< Type > const &p) |
| Write box to stream. | |
| vcl_istream & | operator>> (vcl_istream &is, vgl_box_2d< Type > &p) |
| Read box from stream. | |
| vgl_line_segment_2d< T > | vgl_clip_line_to_box (vgl_line_2d< T > const &l, vgl_box_2d< T > const &b) |
| clip given line to given box, and return resulting line segment. | |
| bool | vgl_intersection (vgl_box_2d< T > const &b, vgl_point_2d< T > const &p) |
| Return true if the point lies inside the box. | |
| bool | vgl_intersection (vgl_point_2d< T > const &p, vgl_box_2d< T > const &b) |
| Return true if the point lies inside the box. | |
| vgl_box_2d< T > | vgl_intersection (vgl_box_2d< T > const &, vgl_box_2d< T > const &) |
| Return the intersection of two boxes (which is itself either a box, or empty). | |
| bool | vgl_intersection (vgl_box_2d< T > const &b, vgl_polygon< T > const &poly) |
| Return true if the box and polygon regions intersect, regions include boundaries. | |
| vcl_vector< vgl_point_2d< T > > | vgl_intersection (vgl_box_2d< T > const &b, vcl_vector< vgl_point_2d< T > > const &p) |
| Return the points from the list that lie inside the box. | |
| vcl_vector< vgl_point_2d< T > > | vgl_intersection (vcl_vector< vgl_point_2d< T > > const &p, vgl_box_2d< T > const &b) |
| Return the points from the list that lie inside the box. | |
| enum vgl_box_2d::point_type |
| vgl_box_2d< Type >::vgl_box_2d | ( | ) |
| vgl_box_2d< Type >::vgl_box_2d | ( | Type const | corner1[2], | |
| Type const | corner2[2] | |||
| ) |
| vgl_box_2d< Type >::vgl_box_2d | ( | vgl_point_2d< Type > const & | corner1, | |
| vgl_point_2d< Type > const & | corner2 | |||
| ) |
| vgl_box_2d< Type >::vgl_box_2d | ( | Type | xmin, | |
| Type | xmax, | |||
| Type | ymin, | |||
| Type | ymax | |||
| ) |
Construct using ranges in x (first two args) and y (last two).
Definition at line 42 of file vgl_box_2d.txx.
| vgl_box_2d< Type >::vgl_box_2d | ( | Type const | ref_point[2], | |
| Type | width, | |||
| Type | height, | |||
| point_type | ||||
| ) |
Construct a box sized width x height at a given reference point.
The box will either be centered at ref_point or will have ref_point as its min-position or max-position, as specified by the 4th argument.
| vgl_box_2d< Type >::vgl_box_2d | ( | vgl_point_2d< Type > const & | ref_point, | |
| Type | width, | |||
| Type | height, | |||
| point_type | ||||
| ) |
Construct a box sized width x height at a given reference point.
The box will either be centered at ref_point or will have ref_point as its min-position or max-position, as specified by the 4th argument.
| bool vgl_box_2d< Type >::operator== | ( | vgl_box_2d< Type > const & | b | ) | const [inline] |
| Type vgl_box_2d< Type >::width | ( | ) | const |
| Type vgl_box_2d< Type >::height | ( | ) | const |
| Type vgl_box_2d< Type >::area | ( | ) | const [inline] |
| Type vgl_box_2d< Type >::volume | ( | ) | const [inline] |
| Type vgl_box_2d< Type >::min_x | ( | ) | const [inline] |
| Type vgl_box_2d< Type >::min_y | ( | ) | const [inline] |
| Type vgl_box_2d< Type >::max_x | ( | ) | const [inline] |
| Type vgl_box_2d< Type >::max_y | ( | ) | const [inline] |
| vgl_point_2d< Type > vgl_box_2d< Type >::centroid | ( | ) | const |
| Type vgl_box_2d< Type >::centroid_x | ( | ) | const |
| Type vgl_box_2d< Type >::centroid_y | ( | ) | const |
| vgl_point_2d< Type > vgl_box_2d< Type >::min_point | ( | ) | const |
| vgl_point_2d< Type > vgl_box_2d< Type >::max_point | ( | ) | const |
| bool vgl_box_2d< Type >::is_empty | ( | ) | const [inline] |
| void vgl_box_2d< Type >::add | ( | vgl_point_2d< Type > const & | p | ) |
Add a point to this box.
Do this by possibly enlarging the box so that the point just falls within the box. Adding a point to an empty box makes it a size zero box only containing p.
Definition at line 314 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::add | ( | vgl_box_2d< Type > const & | b | ) |
Make the convex union of two boxes.
Do this by possibly enlarging this box so that the corner points of the given box just fall within the box. Adding an empty box does not change the current box.
Definition at line 335 of file vgl_box_2d.txx.
| bool vgl_box_2d< Type >::contains | ( | vgl_point_2d< Type > const & | p | ) | const |
| bool vgl_box_2d< Type >::contains | ( | vgl_box_2d< Type > const & | b | ) | const |
Return true iff the corner points of b are inside this box.
Definition at line 351 of file vgl_box_2d.txx.
| bool vgl_box_2d< Type >::contains | ( | Type const & | x, | |
| Type const & | y | |||
| ) | const [inline] |
Return true if (x,y) inside box, ie x_min <= x <= x_max etc.
Definition at line 179 of file vgl_box_2d.h.
| void vgl_box_2d< Type >::empty | ( | ) |
| void vgl_box_2d< Type >::set_min_x | ( | Type | m | ) | [inline] |
| void vgl_box_2d< Type >::set_min_y | ( | Type | m | ) | [inline] |
| void vgl_box_2d< Type >::set_max_x | ( | Type | m | ) | [inline] |
| void vgl_box_2d< Type >::set_max_y | ( | Type | m | ) | [inline] |
| void vgl_box_2d< Type >::set_centroid_x | ( | Type | cx | ) |
Move box so centroid lies at cx (width and height unchanged).
Definition at line 158 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_centroid_y | ( | Type | cy | ) |
Move box so centroid lies at cy (width and height unchanged).
Definition at line 167 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_width | ( | Type | w | ) |
Modify width, retaining centroid at current position.
For integer types, centroid might change slightly, but repeat calls to set_height will not cause centroid drift.
Definition at line 200 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_height | ( | Type | h | ) |
Modify height, retaining centroid at current position.
For integer types, centroid might change slightly, but repeat calls to set_height will not cause centroid drift.
Definition at line 210 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::expand_about_centroid | ( | Type | expand | ) |
Add to width and height, centroid unchanged.
Will move each side by expand / 2.
Definition at line 220 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::scale_about_centroid | ( | double | s | ) |
| void vgl_box_2d< Type >::scale_about_origin | ( | double | s | ) |
Scale width and height, keeping scaled position of origin unchanged.
Definition at line 239 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::setmin_position | ( | Type const | min_position[2] | ) |
Modify bottom left. Top right only changed if necessary to avoid empty box.
Definition at line 248 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::setmax_position | ( | Type const | max_position[2] | ) |
Modify top right. Bottom left only changed if necessary to avoid empty box.
Definition at line 261 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_min_point | ( | vgl_point_2d< Type > const & | min_pt | ) |
Modify bottom left. Top right only changed if necessary to avoid empty box.
Definition at line 272 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_max_point | ( | vgl_point_2d< Type > const & | max_pt | ) |
Modify top right. Bottom left only changed if necessary to avoid empty box.
Definition at line 279 of file vgl_box_2d.txx.
| void vgl_box_2d< Type >::set_centroid | ( | Type const | c[2] | ) | [inline] |
Move box so centroid lies at c (width, height unchanged).
Definition at line 223 of file vgl_box_2d.h.
| void vgl_box_2d< Type >::set_centroid | ( | vgl_point_2d< Type > const & | c | ) | [inline] |
Move box so centroid lies at c (width, height unchanged).
Definition at line 225 of file vgl_box_2d.h.
| vcl_ostream & vgl_box_2d< Type >::print | ( | vcl_ostream & | ) | const |
| vcl_ostream & vgl_box_2d< Type >::write | ( | vcl_ostream & | ) | const |
| vcl_istream & vgl_box_2d< Type >::read | ( | vcl_istream & | ) |
| vcl_ostream & operator<< | ( | vcl_ostream & | s, | |
| vgl_box_2d< Type > const & | p | |||
| ) | [related] |
Write box to stream.
| vcl_istream & operator>> | ( | vcl_istream & | is, | |
| vgl_box_2d< Type > & | p | |||
| ) | [related] |
Read box from stream.
| vgl_line_segment_2d< T > vgl_clip_line_to_box | ( | vgl_line_2d< T > const & | l, | |
| vgl_box_2d< T > const & | b | |||
| ) | [related] |
clip given line to given box, and return resulting line segment.
Definition at line 53 of file vgl_clip.h.
| bool vgl_intersection | ( | vgl_box_2d< T > const & | b, | |
| vgl_point_2d< T > const & | p | |||
| ) | [related] |
| bool vgl_intersection | ( | vgl_point_2d< T > const & | p, | |
| vgl_box_2d< T > const & | b | |||
| ) | [related] |
| vgl_box_2d< T > vgl_intersection | ( | vgl_box_2d< T > const & | , | |
| vgl_box_2d< T > const & | ||||
| ) | [related] |
Return the intersection of two boxes (which is itself either a box, or empty).
Definition at line 35 of file vgl_intersection.txx.
| bool vgl_intersection | ( | vgl_box_2d< T > const & | b, | |
| vgl_polygon< T > const & | poly | |||
| ) | [related] |
Return true if the box and polygon regions intersect, regions include boundaries.
| vcl_vector< vgl_point_2d< T > > vgl_intersection | ( | vgl_box_2d< T > const & | b, | |
| vcl_vector< vgl_point_2d< T > > const & | p | |||
| ) | [related] |
Return the points from the list that lie inside the box.
Definition at line 873 of file vgl_intersection.txx.
| vcl_vector< vgl_point_2d< T > > vgl_intersection | ( | vcl_vector< vgl_point_2d< T > > const & | p, | |
| vgl_box_2d< T > const & | b | |||
| ) | [related] |
Return the points from the list that lie inside the box.
Definition at line 887 of file vgl_intersection.txx.
Type vgl_box_2d< Type >::min_pos_[2] [protected] |
Definition at line 241 of file vgl_box_2d.h.
Type vgl_box_2d< Type >::max_pos_[2] [protected] |
Definition at line 242 of file vgl_box_2d.h.
1.5.1