36 #include <Inventor/SbVec2d.h>
45 SbBox2d(
double xmin,
double ymin,
double xmax,
double ymax)
46 : minpt(xmin, ymin), maxpt(xmax, ymax) { }
48 : minpt(minpoint), maxpt(maxpoint) { }
51 explicit SbBox2d(
const SbBox2i32 & box) { setBounds(box); }
54 { minpt.setValue(xmin, ymin); maxpt.setValue(xmax, ymax);
return *
this; }
56 { minpt = minpoint; maxpt = maxpoint;
return *
this; }
59 SbBox2d & setBounds(
const SbBox2i32 & box);
61 void getBounds(
double & xmin,
double & ymin,
double & xmax,
double & ymax)
const
62 { minpt.getValue(xmin, ymin); maxpt.getValue(xmax, ymax); }
64 { minpoint = minpt; maxpoint = maxpt; }
71 void extendBy(
const SbVec2d & point);
72 void extendBy(
const SbBox2d & box);
74 SbBool
isEmpty(
void)
const {
return (maxpt[0] < minpt[0]); }
75 SbBool
hasArea(
void)
const {
return ((maxpt[0] > minpt[0]) && (maxpt[1] > minpt[1])); }
77 SbBool intersect(
const SbVec2d & point)
const;
78 SbBool intersect(
const SbBox2d & box)
const;
83 void getOrigin(
double & originX,
double & originY)
const
84 { minpt.getValue(originX, originY); }
85 void getSize(
double & sizeX,
double & sizeY)
const
86 {
if (isEmpty()) { sizeX = sizeY = 0.0; }
87 else { sizeX = maxpt[0] - minpt[0]; sizeY = maxpt[1] - minpt[1]; } }
90 this->getSize(v[0], v[1]);
94 { SbDividerChk(
"SbBox2d::getAspectRatio()", maxpt[1] - minpt[1]);
95 return (maxpt[0] - minpt[0]) / (maxpt[1] - minpt[1]); }
110 #endif // !COIN_SBBOX2D_H