![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
differenceBoost , Chapter 1. Geometry , Algorithms
|
Тип |
Концепция |
Имя |
Описание |
---|---|---|---|
Любой тип, выполняющий концепцию геометрии | геометрия1 | ||
Geometry2 const & | Любой тип, выполняющий концепцию геометрии | геометрия2 | |
Сбор и | выход_сбор |
Или
#include <boost/geometry.hpp>
Или
#include <boost/geometry/algorithms/difference.hpp>
Отличие функции от OGC Simple Feature Specification.
Дело |
Поведение |
---|---|
areal (например, многоугольник) | Все комбинации: коробка, кольцо, полигон, мульти_полигон |
линейные (например, линии) / канал (например, полигон) | |
Все комбинации: линии, мульти_линии; результаты в наборе строк | |
pointlike (например, point) | Все комбинации: точка, multi_point; результаты в набор точек |
Еще не поддерживается в этой версии | |
Еще не поддерживается в этой версии | |
Три измерения | Еще не поддерживается в этой версии |
![]() | Note |
---|---|
Проверьте Полигонную концепцию для правил, которые многоугольный ввод для этого алгоритма должен выполнять |
Показывает, как вычесть один полигон из другого полигона
#include <iostream> #include <list> #include <boost/geometry.hpp> #include <boost/geometry/geometries/point_xy.hpp> #include <boost/geometry/geometries/polygon.hpp> #include <boost/foreach.hpp> int main() { typedef boost::geometry::model::polygon<boost::geometry::model::d2::point_xy<double> > polygon; polygon green, blue; boost::geometry::read_wkt( "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 3,5.3 2.6,5.4 1.2,4.9 0.8,2.9 0.7,2 1.3)" "(4.0 2.0, 4.2 1.4, 4.8 1.9, 4.4 2.2, 4.0 2.0))", green); boost::geometry::read_wkt( "POLYGON((4.0 -0.5 , 3.5 1.0 , 2.0 1.5 , 3.5 2.0 , 4.0 3.5 , 4.5 2.0 , 6.0 1.5 , 4.5 1.0 , 4.0 -0.5))", blue); std::list<polygon> output; boost::geometry::difference(green, blue, output); int i = 0; std::cout << "green - blue:" << std::endl; BOOST_FOREACH(polygon const& p, output) { std::cout << i++ << ": " << boost::geometry::area(p) << std::endl; } output.clear(); boost::geometry::difference(blue, green, output); i = 0; std::cout << "blue - green:" << std::endl; BOOST_FOREACH(polygon const& p, output) { std::cout << i++ << ": " << boost::geometry::area(p) << std::endl; } return 0; }
Результат:
green - blue: 0: 0.02375 1: 0.542951 2: 0.0149697 3: 0.226855 4: 0.839424blue - green: 0: 0.525154 1: 0.015 2: 0.181136 3: 0.128798 4: 0.340083 5: 0.307778
![]()
Статья difference раздела Chapter 1. Geometry Algorithms может быть полезна для разработчиков на c++ и boost.
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
:: Главная :: Algorithms ::
реклама |