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