gis_render_sm_calculate_distance()

Вычисление длины траектории, описываемой градусными точками.

Прототип:

#include <gis/gis_surfacemanager.h>
int gis_render_sm_calculate_distance( gis_render_sm_context_t sm_ctx, double_point_t *points, uint32_t n_points, double* distance );

Аргументы:

sm_ctx
Контекст движка рендеринга Surface Manager.
points
Массив точек.
n_points
Количество точек.
distance
Указатель на переменную, хранящюю расстояние.

Библиотека:

surfacemanager

Описание:

Функция вычисляет расстояние длины траектории, описываемой градусными точками, на текущем эллипсоиде проекции отображения.

Возвращаемое значение:

EOK
Успешное завершение
EINVAL
Некорректные параметры функции

Примеры использования:

QApplication app(argc, argv);
gis_core_connection_t connection;
gis_core_request_parameters_t map;
gis_data_engine_context_t data_engine_ctx;
gis_render_sm_context_t sm_ctx;
gis_core_link_init( &connection );
gis_core_link_connect( &connection, 777 );
gis_core_databuffer_attach( &connection );
gis_core_request_parameters_init( &map );
gis_core_databuffer_data_request( &connection, &map, 1 );
gis_data_engine_alloc( 800, 600, GIS_DATA_ENGINE_MODE_SM, GIS_DATA_ENGINE_BPP_32, &connection, &data_engine_ctx );
gis_render_sm_alloc( &sm_ctx, data_engine_ctx, 1000, 0.5, 0 );
vector<double_point_t> degree_vector;
double distance = 0;
double_point_t pnt;
pnt.x = 34;
pnt.y = 36;
degree_vector.push_back( pnt );
pnt.x = 35;
pnt.y = 39;
degree_vector.push_back( pnt );
gis_render_sm_calculate_distance( sm_ctx, degree_vector.data(), degree_vector.size(), &distance );
if ( fabs( distance - 344496 ) < 0.1 )
{
printf( "Incorrect distance: %lf", distance );
return 1;
}
gis_render_sm_free( &sm_ctx );
gis_data_engine_free( &data_engine_ctx );
gis_core_databuffer_detach();
gis_core_link_destroy( &connection, true );

Классификация:

ПК ЦКИ для ЗОСРВ «Нейтрино»

Безопасность использования
Обработчик прерываний
Нет
Обработчик сигналов
Нет
В потоке
Да

Тематические ссылки:

gis_render_sm_context_t, gis_render_sm_calculate_polygon()




Предыдущий раздел: Описание API картографического фреймворка