Libs/Common/Region.h
Namespaces
Name |
---|
shapeworks |
Classes
Name | |
---|---|
class | shapeworks::IndexRegion Indices into a 3d region of memory (can be negative, e.g., for the purpose of padding an image) |
class | shapeworks::PhysicalRegion physical bounds of a 3d region of space |
Source code
#pragma once
#include "Shapeworks.h"
namespace shapeworks
{
// A logical region of an Image or a Mesh
class IndexRegion;
// A physical region of an Image or a Mesh
class PhysicalRegion;
class IndexRegion
{
public:
Coord min{1000000000, 1000000000, 1000000000};
Coord max{-1000000000, -1000000000, -1000000000};
IndexRegion() = default;
IndexRegion(const IndexRegion&) = default;
IndexRegion(const Dims &dims) : min{0, 0, 0} {
if (0 != (dims[0] + dims[1] + dims[2])) {
max = {static_cast<Coord::value_type>(dims[0]) - 1,
static_cast<Coord::value_type>(dims[1]) - 1,
static_cast<Coord::value_type>(dims[2]) - 1};
}
}
IndexRegion(const Coord &_min, const Coord &_max) :
min{_min[0], _min[1], _min[2]}, max{_max[0], _max[1], _max[2]} {}
bool operator==(const IndexRegion &other) const { return min == other.min && max == other.max; }
bool valid() const { return max[0] > min[0] && max[1] > min[1] && max[2] > min[2]; }
Coord origin() const { return Coord({min[0], min[1], min[2]}); }
Dims size() const {
return Dims({static_cast<Dims::value_type>(max[0] - min[0] + 1),
static_cast<Dims::value_type>(max[1] - min[1] + 1),
static_cast<Dims::value_type>(max[2] - min[2] + 1)});
}
IndexRegion& pad(int padding);
};
std::ostream &operator<<(std::ostream &os, const IndexRegion ®ion);
class PhysicalRegion
{
public:
Point min;
Point max;
PhysicalRegion(const PhysicalRegion&) = default;
PhysicalRegion(const Point &_min, const Point &_max) {
min[0] = _min[0];
min[1] = _min[1];
min[2] = _min[2];
max[0] = _max[0];
max[1] = _max[1];
max[2] = _max[2];
}
PhysicalRegion() {
min = Point({1000000000, 1000000000, 1000000000});
max = Point({-1000000000, -1000000000, -1000000000});
}
bool operator==(const PhysicalRegion &other) const {
return min == other.min && max == other.max;
}
bool valid() const {
bool minLessThanMax = max[0] > min[0] && max[1] > min[1] && max[2] > min[2];
return minLessThanMax;
}
Point origin() const { return min; }
Point size() const { return max - min; }
PhysicalRegion& shrink(const PhysicalRegion &other);
PhysicalRegion& expand(const PhysicalRegion &other);
PhysicalRegion& expand(const Point &pt);
PhysicalRegion& pad(double padding);
};
std::ostream &operator<<(std::ostream &os, const PhysicalRegion ®ion);
} // namespace shapeworks
Updated on 2022-03-31 at 09:51:19 -0600