![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
union_Boost , Chapter 1. Geometry , Algorithms
|
Тип |
Концепция |
Имя |
Описание |
---|---|---|---|
Геометрия1 const & | Любой тип, выполняющий концепцию геометрии | Геометрия1 | Модель указанного понятия |
Геометрия2 const & | Любой тип, выполняющий концепцию геометрии | Геометрия2 | Модель указанного понятия |
Коллекция & | выходная коллекция, либо многогеометрия, либо std::vector | output_collection | Сбор данных |
Либо
#include <boost/geometry.hpp>
Либо
#include <boost/geometry/algorithms/union.hpp>
Функциональный союз реализует функцию Union изOGC Simple Feature Specification.
![]() | Note |
---|---|
Повышаю. Геометрия добавляет подчеркивание, чтобы избежать использования ключевого слова< |
Дело |
поведение |
---|---|
Геометрия Это точка | Вычисляет линейные значения входных (многоточечных) точек |
Геометрия Внешне это линейная линия | Вычисляет союзные строки входных (многолинейных) строк |
Геометрия Это полигон . | Вычисляет союзные многоугольники входных (много) многоугольников и/или коробок |
![]() | Note |
---|---|
ПроверьтеPolygon Conceptна правила, которые должен выполнять многоугольный вход для этого алгоритма. |
Показывает, как получить единую геометрию двух многоугольников
#include <iostream> #include <vector> #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::vector<polygon> output; boost::geometry::union_(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; } return 0; }
Результат:
green || blue: 0: 5.64795![]()
Статья union_ раздела Chapter 1. Geometry Algorithms может быть полезна для разработчиков на c++ и boost.
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.
:: Главная :: Algorithms ::
реклама |