// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands. // Copyright (c) 2008-2012 Bruno Lalande, Paris, France. // Copyright (c) 2009-2012 Mateusz Loskot, London, UK. // Use, modification and distribution is subject to the Boost Software License, // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // Custom triangle template Example #include #include #include #include #include #include #include #include #include BOOST_GEOMETRY_REGISTER_BOOST_TUPLE_CS(cs::cartesian) template struct triangle : public boost::array { }; // Register triangle

as a ring BOOST_GEOMETRY_REGISTER_RING_TEMPLATED(triangle) namespace boost { namespace geometry { namespace dispatch { // Specializations of area dispatch structure, implement algorithm template struct area, ring_tag> { template static inline double apply(triangle const& t, Strategy const&) { return 0.5 * ((get<0>(t[1]) - get<0>(t[0])) * (get<1>(t[2]) - get<1>(t[0])) - (get<0>(t[2]) - get<0>(t[0])) * (get<1>(t[1]) - get<1>(t[0]))); } }; }}} // namespace boost::geometry::dispatch int main() { //triangle > t; triangle > t; t[0] = boost::make_tuple(0, 0); t[1] = boost::make_tuple(5, 0); t[2] = boost::make_tuple(2.5, 2.5); std::cout << "Triangle: " << boost::geometry::dsv(t) << std::endl; std::cout << "Area: " << boost::geometry::area(t) << std::endl; //boost::geometry::point_xy c; boost::tuple c; boost::geometry::centroid(t, c); std::cout << "Centroid: " << boost::geometry::dsv(c) << std::endl; return 0; }