Polygon Sponsor
|
Point Concept
The point concept tag is
point_concept
To register a user defined type as a model of point concept, specialize the
geometry concept meta-function for that type. In the example below CPoint is registered as a model of
point concept.
template <>
struct geometry_concept<CPoint> { typedef point_concept type; };
The semantic of a point is that it has an x and y
coordinate. A std::pair<int, int>, boost::tuple<int, int> or boost::array<int, 2>
could all be made models of point by simply providing indirect access to their
elements through traits, however, these objects cannot be made a model of both
point and interval in the same compilation unit, for obvious reason that
duplicate specialization of the geometry_concept struct is illegal, but also
because it would make overloading generic function by concept ambiguous if a
type modeled more than one concept.
Below is shown the default point traits.
Specialization of these traits is required for types that don't conform to the
default behavior.
template <typename T>
struct point_traits {
typedef typename T::coordinate_type coordinate_type;
static inline coordinate_type get(const T& point,
orientation_2d orient) {
return point.get(orient);
}
};
template <typename T>
struct point_mutable_traits {
static inline void set(T& point, orientation_2d orient,
typename point_traits<T>::coordinate_type value) {
point.set(orient, value);
}
static inline T construct(typename point_traits<T>::coordinate_type
x_value, typename point_traits<T>::coordinate_type y_value) {
return T(x_value, y_value);
}
};
Example code custom_point.cpp demonstrates
how to map a
user defined point class to the library point_concept Functions
template <typename T>
coordinate_type get(const T& point, orientation_2d) |
Expects a model of point. Returns
the x or y coordinate of the point, depending on the orientation_2d
value.
|
template <typename T, typename
coordinate_type>
void set(T& point, orientation_2d, coordinate_type) |
Expects a model of point.
Sets the x or y coordinate of the point to the coordinate, depending on
the orientation_2d value. |
template <typename T>
T construct(coordinate_type x, coordinate_type y) |
Construct an object that is a model of point given x and y
coordinate values. |
template <typename T1, typename
T2>
T1& assign(T1& left, const T2& right) |
Copies data from right object that models point into left object
that models point. |
template <typename T, typename
T2>
bool equivalence(const T& point1, const T2& point2) |
Given two objects that model point, compares and returns true if
their x and y values are respectively equal to each other. |
template <typename point_type>
coordinate_type x(const point_type& point) |
Returns the x coordinate of an object that models point. |
template <typename point_type>
coordinate_type y(const point_type& point) |
Returns the y coordinate of an object that models point. |
template <typename point_type>
void x(point_type& point, coordinate_type ) |
Sets the x coordinate of the object that models point to the
coordinate value. |
template <typename point_type>
void y(point_type& point, coordinate_type ) |
Sets the y coordinate of the object that models point to the
coordinate value. |
template <typename point_type>
point_type& scale_up(point_type& point,
unsigned_area_type factor) |
Multiplies x and y coordinate of an object that models point by
unsigned factor. |
template <typename point_type>
point_type& scale_down(point_type& point,
unsigned_area_type factor) |
Divides x and y coordinate of an object that models point by
unsigned factor. |
template <typename point_type,
typename scaling_type>
point_type& scale(point_type& point,
const scaling_type& factor) |
Calls the scale member function of scaling type on the x and y value
of an object that models point and sets the point to the scaled values. |
template <typename point_type,
typename transform_type>
point_type& transform(point_type& point,
const transform_type& transform) |
Calls the transform member function of transform type on the x and y
value of an object that models point and sets the point to the
transformed values. |
template <typename point_type>
point_type& move(point_type& point, orientation_2d
coordinate_difference displacement) |
Adds displacement value to the coordinate of an object that models
point indicated by the orientation_2d. |
template <typename T1, typename
T2>
T1& convolve(T1& a, const T2& b) |
Adds x coordinate of b to x coordinate of a and adds y coordinate of
b to y coordinate of a. |
template <typename T1, typename
T2>
T1& deconvolve(T1& a, const T2& b) |
Subtracts x coordinate of b from x coordinate of a and subtracts y
coordinate of b from y coordinate of a. |
template <typename T1, typename
T2>
coordinate_distance euclidean_distance(const T1&,
const T2&) |
Returns the distance from an object that models point to a second
object that models point. |
template <typename T>
coordinate_difference euclidean_distance(const T&,
orientation_2d,
coordinate_type) |
Returns the distance from an object that models point to a
coordinate in the given orientation_2d. |
template <typename T1, typename
T2>
coordinate_difference manhattan_distance(const T1&,
const T2&) |
Returns the distance in x plus the distance in y from an object that
models point to a second object that models point. |
template <typename T1, typename
T2>
coordinate_difference distance_squared(const T1&,
const T2&) |
Returns the square of the distance in x plus the square of the
distance in y from an object that models point to a second object that
models point. |
Point Data
The library provides a model of point concept declared
template<typename T> point_data where T is the coordinate type.
This data type is used internally when a point is needed and is available to
the library user who finds it convenient to use a library point data type
instead of providing their own. The data type is implemented to be
convenient to use with the library traits.
Example code point_usage.cpp demonstrates using the
library provided point data type and functions
Members
geometry_type |
point_concept |
coordinate_type |
T |
point_data() |
Default constructs the two coordinate
values of the point. |
point_data(T x, T y) |
Constructs an interval with two
coordinates. |
point_data(const point_data*
that) |
Copy construct |
point_data& operator=(const
point_data& that) |
Assignment operator. |
template <typename T2>
point_data& operator=(const T2& that) const |
Assign from an object that is a model of point. |
template <typename T2>
bool
operator==(const T2& that) const |
Compare equality to an object that is a model of point. |
template <typename T2>
bool
operator!=(const T2& that) const |
Compare inequality to an object that is a model of point. |
template <typename T2>
bool
operator<(const T2& that) const |
Compares y coordinates then x coordinates to break ties. |
template <typename T2>
bool
operator<=(const T2& that) const |
Compares y coordinates then x coordinates to break ties. |
template <typename T2>
bool
operator>(const T2& that) const |
Compares low coordinates then high coordinates to break ties. |
template <typename T2>
bool
operator>=(const T2& that) const |
Compares low coordinates then high coordinates to break ties. |
T get(orientation_2d
orient) const |
Get the coordinate in the given orientation. |
T x() const |
Get the coordinate in the horizontal orientation. |
T y() const |
Get the coordinate in the vertical orientation. |
void set(orientation_2d
orient, T value) |
Sets the coordinate in the given orientation to the value. |
void x(T value) |
Sets the coordinate in the horizontal orientation to the value. |
void y(T value) |
Sets the coordinate in the vertical orientation to the value. |
|