Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Диплом_(Маша_Зайцева).doc
Скачиваний:
1
Добавлен:
01.05.2025
Размер:
1.57 Mб
Скачать

Приложение б

(справочное)

Обзор технологии доступа к произвольным форматам fdo

  1. Общее описание

Feature Data Objects (далее FDO) – это комплекс решений от компании Autodesk, разработанный на основе библиотек GDAL и OGR, предоставляющий возможность создания прикладных программ для географических информационных систем с эффективными инструментами для преобразования, хранения и изменения пространственных данных.

FDO – создан для разработчиков приложений ГИС в виде продуманного API (Application Programming Interface), функционал которого может быть расширен при помощи таких языков программирования как Microsoft C#.NET, Microsoft Visual Basic.NET и, конечно же, Microsoft Visual C++.NET. Все структуры данных соответствуют стандартам Open Geospatial Consortium (OGC).

Доступ к пространственным данным при помощи FDO осуществляется при помощи основных объектов класса Provider. Так, например, объект класса MySQL Provider создает соединение с источником данных MySQL Server, который содержит в себе географическую информацию. После того как соединение установлено, средствами FDO можно выбрать часть или все данные необходимые для визуализации или анализа. Выбор данных происходит аналогично команде Select, которая так часто используется в запросах SQL.

Можно сразу заметить, что отсутствует основная операция «конвертации» данных. Благодаря библиотеке абстракций GDAL, работающей с большинством форматов пространственных данных напрямую, FDO способен создавать множество соединений с источниками данных, без какого-либо преобразования информации. Кроме «чтения-на-лету» FDO также способен изменять или добавлять новые пространственные объекты [13-14].

Геометрическая структура пространственного объекта в представленной координатной системе, может быть выражена в двух (2D), в трех (3D), а иногда даже и в четырех измерениях (4D). Представление геометрической информации в FDO основано на OpenGIS Simple Features Implementation Specification for SQL (version 1.1, document 99-049).

Структура географических данных FDO может быть сохранена в формате XML. FDO XML формат базируется на стандарте OpenGIS Consortium Geography Markup Language (version 2.1.1, document 02-009), который можно найти на сайте www.opengeospatial.org/standards/gml. Структурой географических данных FDO является всего лишь информация о схематическом представлении данных, которая не зависит от местоположения источника данных.

  1. Основные операции

Создание соединения и доступа к пространственным данным

Создание соединения выполняется следующим образом:

  1. создать или выбрать из реестра провайдер данных;

  2. создать менеджер соединений;

  3. создать соединение;

  4. определить тип источника данных;

  5. получить список файлов источника данных;

  6. получить состояние соединения;

  7. получить свойства соединения;

  8. получить значения свойств соединения;

  9. установить свойства соединения;

  10. открыть соединение;

  11. открыть продолжительное соединение;

  12. получить список файлов источника данных, если они существуют.

Создание в реестре провайдера данных

Метод GetProviders класса FdoProviderRegistry возвращает содержимое файла providers.xml, который расположен в папке <install>\bin для Windows, или в папке \usr\local\fdo-<version>\lib для Linux, что, по своей сути является реестром провайдеров данных.

Когда создается соединение, можно использовать одно из имен провайдеров данных, возвращенных данным методом в виде массива строк.

Создание менеджера соединений

Менеджер соединений создает новые соединения.

Метод GetConnectionManager класса FdoFeatureAccessManager управляет созданными или уже имеющимися соединениями.

Создание соединения

Метод CreateConnection класса FdoConnectionManager создает новое соединение.

Определение типа источника данных

Источник данных может быть представлен в виде файлов, баз данных или ресурса на веб-сайте. Провайдеры могут определять тип соответствующего источника данных, для которого в данный момент создано соединение.

Получение списка файлов источника данных

Если открыто соединение с источником данных, тип которого определен как «File», можно получить список файлов, которые содержатся данным источником. Для соединения с источником данных через провайдер SDF, список будет представлен только *.sdf файлами. Для соединения с источником данных через провайдер SHP, список будет представлен файлами *.shp, а также дополнительными файлами *.shx, *.dbf, *.prj. Провайдер SHP может создавать соединение и с папками, содержащими файлы *.shp, *.shx, *dbf и *.prj. Для соединения с источником данных через растровый провайдер, список будет представлен файлами растровых форматов, например *.jpg, и соответствующими файлами *.jgw и *.xml.

Метод GetDependentFileNames класса FdoIConnectionInfo возвращает массив строк в виде имен файлов источника данных.

Получение свойств соединения

Первое, что можно сделать, это получить информацию о соединении при помощи метода GetConnectionInfo класса FdoIConnection. Затем можно получить свойства соединения при помощи метода GetConnectionProperties класса FdoIConnectionInfo, этот метод возвращает упорядоченный массив значений свойств соединения.

Упорядоченный массив свойств соединения представлен классом FdoIPropertyDictionary. Все методы этого класса обеспечивают получение значений свойств соединения по имени свойства, а также значений по умолчанию или определенных перечислением значений.

Получение значений свойств соединения

Свойства соединения могут быть представлены определенными значениями:

  1. user names;

  2. passwords;

  3. file path names;

  4. URLs;

  5. symbolic host names;

  6. service identifiers;

  7. data store names.

Каждый провайдер данных снабжен уникальным списком наименований свойств.

Установка значений свойств соединения

Установка значений свойств соединения осуществляется при помощи методов класса FdoIPropertyDictionary.

Открытие соединения

Открытие соединения осуществляется при помощи метода Open для класса FdoIConnection. Прежде чем обращаться к методам соединения, убедитесь, что соединение открыто при помощи метода GetConnectionState.

Открытие продолжительного соединения

Каждый провайдер данных, основанный на технологии RDBMS, в настройках соединения имеет свойство, определяющее имя источника данных. При создании соединения имя источника данных можно не указывать, и тогда соединение можно называть «продолжительным». Во время инициализации соединения необходимо указать имя источника данных, хотя смысл продолжительных соединений в том, что они могут быть установлены для различных источников данных с различными именами. Необходимо только изменить значение соответствующего свойства в настройках соединения.

Если создается продолжительное соединение с источником данных, используя провайдер данных ArcSDE, то можно убедиться в том, что возвращаемый специальным методом список имен источников данных всегда содержит только одно наименование.

Получение списка файлов источника данных, если они существуют

Список файлов источника данных можно получить и после соединения с ним. Соответствующий метод определит список имен файлов, если провайдер данных имеет соответствующий тип.