3 // Copyright (c) 2019 Barend Gehrels, Amsterdam, the Netherlands.
5 // Use, modification and distribution is subject to the Boost Software License,
6 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
7 // http://www.boost.org/LICENSE_1_0.txt)
9 #ifndef BOOST_GEOMETRY_ALGORITHMS_DETAIL_MAKE_MAKE_HPP
10 #define BOOST_GEOMETRY_ALGORITHMS_DETAIL_MAKE_MAKE_HPP
12 #include <boost/geometry/geometries/infinite_line.hpp>
13 #include <boost/geometry/core/access.hpp>
15 namespace boost { namespace geometry
18 #ifndef DOXYGEN_NO_DETAIL
19 namespace detail { namespace make
22 template <typename Type, typename Coordinate>
24 model::infinite_line<Type> make_infinite_line(Coordinate const& x1,
25 Coordinate const& y1, Coordinate const& x2, Coordinate const& y2)
27 model::infinite_line<Type> result;
30 result.c = -result.a * x1 - result.b * y1;
34 template <typename Type, typename Point>
36 model::infinite_line<Type> make_infinite_line(Point const& a, Point const& b)
38 return make_infinite_line<Type>(geometry::get<0>(a), geometry::get<1>(a),
39 geometry::get<0>(b), geometry::get<1>(b));
42 template <typename Type, typename Segment>
44 model::infinite_line<Type> make_infinite_line(Segment const& segment)
46 return make_infinite_line<Type>(geometry::get<0, 0>(segment),
47 geometry::get<0, 1>(segment),
48 geometry::get<1, 0>(segment),
49 geometry::get<1, 1>(segment));
54 }} // namespace detail::make
55 #endif // DOXYGEN_NO_DETAIL
58 }} // namespace boost::geometry
60 #endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_MAKE_MAKE_HPP