Coin Logo http://www.sim.no/
http://www.coin3d.org/

SbBox2d.h
1#ifndef COIN_SBBOX2D_H
2#define COIN_SBBOX2D_H
3
4/**************************************************************************\
5 *
6 * This file is part of the Coin 3D visualization library.
7 * Copyright (C) by Kongsberg Oil & Gas Technologies.
8 *
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * ("GPL") version 2 as published by the Free Software Foundation.
12 * See the file LICENSE.GPL at the root directory of this source
13 * distribution for additional information about the GNU GPL.
14 *
15 * For using Coin with software that can not be combined with the GNU
16 * GPL, and for taking advantage of the additional benefits of our
17 * support services, please contact Kongsberg Oil & Gas Technologies
18 * about acquiring a Coin Professional Edition License.
19 *
20 * See http://www.coin3d.org/ for more information.
21 *
22 * Kongsberg Oil & Gas Technologies, Bygdoy Alle 5, 0257 Oslo, NORWAY.
23 * http://www.sim.no/ sales@sim.no coin-support@coin3d.org
24 *
25\**************************************************************************/
26
27#include <Inventor/SbVec2d.h>
28
29class SbBox2f;
30class SbBox2s;
31class SbBox2i32;
32
33class COIN_DLL_API SbBox2d {
34public:
35 SbBox2d(void) { makeEmpty(); }
36 SbBox2d(double xmin, double ymin, double xmax, double ymax)
37 : minpt(xmin, ymin), maxpt(xmax, ymax) { }
38 SbBox2d(const SbVec2d & minpoint, const SbVec2d & maxpoint)
39 : minpt(minpoint), maxpt(maxpoint) { }
40 explicit SbBox2d(const SbBox2f & box) { setBounds(box); }
41 explicit SbBox2d(const SbBox2s & box) { setBounds(box); }
42 explicit SbBox2d(const SbBox2i32 & box) { setBounds(box); }
43
44 SbBox2d & setBounds(double xmin, double ymin, double xmax, double ymax)
45 { minpt.setValue(xmin, ymin); maxpt.setValue(xmax, ymax); return *this; }
46 SbBox2d & setBounds(const SbVec2d & minpoint, const SbVec2d & maxpoint)
47 { minpt = minpoint; maxpt = maxpoint; return *this; }
48 SbBox2d & setBounds(const SbBox2f & box);
49 SbBox2d & setBounds(const SbBox2s & box);
50 SbBox2d & setBounds(const SbBox2i32 & box);
51
52 void getBounds(double & xmin, double & ymin, double & xmax, double & ymax) const
53 { minpt.getValue(xmin, ymin); maxpt.getValue(xmax, ymax); }
54 void getBounds(SbVec2d & minpoint, SbVec2d & maxpoint) const
55 { minpoint = minpt; maxpoint = maxpt; }
56
57 const SbVec2d & getMin(void) const { return minpt; }
58 SbVec2d & getMin(void) { return minpt; }
59 const SbVec2d & getMax(void) const { return maxpt; }
60 SbVec2d & getMax(void) { return maxpt; }
61
62 void extendBy(const SbVec2d & point);
63 void extendBy(const SbBox2d & box);
64 void makeEmpty(void);
65 SbBool isEmpty(void) const { return (maxpt[0] < minpt[0]); }
66 SbBool hasArea(void) const { return ((maxpt[0] > minpt[0]) && (maxpt[1] > minpt[1])); }
67
68 SbBool intersect(const SbVec2d & point) const;
69 SbBool intersect(const SbBox2d & box) const;
70 SbVec2d getClosestPoint(const SbVec2d & p) const;
71 SbBool findIntersection(const SbVec2d & a, const SbVec2d & b, SbVec2d & ia, SbVec2d & ib) const;
72
73 SbVec2d getCenter(void) const { return (minpt + maxpt) * 0.5; }
74 void getOrigin(double & originX, double & originY) const
75 { minpt.getValue(originX, originY); }
76 void getSize(double & sizeX, double & sizeY) const
77 { if (isEmpty()) { sizeX = sizeY = 0.0; }
78 else { sizeX = maxpt[0] - minpt[0]; sizeY = maxpt[1] - minpt[1]; } }
79 double getAspectRatio(void) const
80 { SbDividerChk("SbBox2d::getAspectRatio()", maxpt[1] - minpt[1]);
81 return (maxpt[0] - minpt[0]) / (maxpt[1] - minpt[1]); }
82
83private:
84 SbVec2d minpt, maxpt;
85
86}; // SbBox2d
87
88COIN_DLL_API inline int operator == (const SbBox2d & b1, const SbBox2d & b2) {
89 return ((b1.getMin() == b2.getMin()) && (b1.getMax() == b2.getMax()));
90}
91
92COIN_DLL_API inline int operator != (const SbBox2d & b1, const SbBox2d & b2) {
93 return !(b1 == b2);
94}
95
96#endif // !COIN_SBBOX2D_H
The SbBox2d class is a 2 dimensional box with double precision corner coordinates.
Definition SbBox2d.h:33
SbBool isEmpty(void) const
Definition SbBox2d.h:65
SbVec2d & getMax(void)
Definition SbBox2d.h:60
SbBox2d & setBounds(const SbVec2d &minpoint, const SbVec2d &maxpoint)
Definition SbBox2d.h:46
void getBounds(SbVec2d &minpoint, SbVec2d &maxpoint) const
Definition SbBox2d.h:54
SbBox2d(const SbVec2d &minpoint, const SbVec2d &maxpoint)
Definition SbBox2d.h:38
void getSize(double &sizeX, double &sizeY) const
Definition SbBox2d.h:76
double getAspectRatio(void) const
Definition SbBox2d.h:79
SbVec2d & getMin(void)
Definition SbBox2d.h:58
void getBounds(double &xmin, double &ymin, double &xmax, double &ymax) const
Definition SbBox2d.h:52
void getOrigin(double &originX, double &originY) const
Definition SbBox2d.h:74
const SbVec2d & getMax(void) const
Definition SbBox2d.h:59
const SbVec2d & getMin(void) const
Definition SbBox2d.h:57
SbVec2d getCenter(void) const
Definition SbBox2d.h:73
SbBox2d(double xmin, double ymin, double xmax, double ymax)
Definition SbBox2d.h:36
SbBox2d(void)
Definition SbBox2d.h:35
SbBox2d & setBounds(double xmin, double ymin, double xmax, double ymax)
Definition SbBox2d.h:44
SbBool hasArea(void) const
Definition SbBox2d.h:66
The SbBox2f class is a 2 dimensional box with floating point corner coordinates.
Definition SbBox2f.h:33
The SbBox2s class is a 2 dimensional box with short integer coordinates.
Definition SbBox2s.h:34
The SbVec2d class is a 2 dimensional vector with double precision floating point coordinates.
Definition SbVec2d.h:39

Copyright © 1998-2010 by Kongsberg Oil & Gas Technologies. All rights reserved.

Generated on Wed Jul 17 2024 for Coin by Doxygen 1.12.0.