Вычисление длины траектории, описываемой градусными точками.
#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 );
surfacemanager
Функция вычисляет расстояние длины траектории, описываемой градусными точками, на текущем эллипсоиде проекции отображения.
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 картографического фреймворка