Сводка
Создает многомасштабную сетку полигонов, подходящих для индексных полигонов, используемых при создании пакетов векторных листов.
Иллюстрация
Использование
Полученная сетка из полигонов является мультимасштабной, отображающей разные уровни детальности, как задано во входной карте. Полигоны с наивысшем уровнем детализации сокращаются так, чтобы в них содержалось не большее число вершин, чем задано объектами входной карты, что определяется их плотностью, распределением и общей генерализацией, которая выполняется при создании векторных листов. Максимальный уровень детальности итоговых полигонов не превышает 16.
Значение поля PTS в каждом полигоне показывает число вершин каждого полигона, полученных из исходных данных. Изучите наивысшие значения в этом поле, по сравнению с индексными полигонами, чтобы найти области с большим числом вершин, которые могут вызвать снижение производительности.
Значение поля LOD в каждом полигоне определяет уровень детальности (LOD). Отсортируйте значения поля, чтобы найти максимальное значение LOD для вашей карты. Максимальное значение LOD, представленное индексными полигонами, может не совпадать с максимальным LOD, указанным в схеме листов. Поскольку слои векторных листов поддерживают легкое и эффективное решение для листов, LOD должно быть достаточным. Слои векторных листов используют метод передискретизации для просмотра деталей за пределами максимального LOD.
Значение поля LEAF в каждом полигоне показывает, будет ли лист чрезмерно увеличиваться при рендеринге слоя векторных листов. Возможные значения поля LEAF приведены ниже:
- LEAF = 0 говорит о том, что лист не может быть чрезмерно увеличен
- LEAF = 1 говорит о том, что лист будет чрезмерно увеличен при превышении значения LOD
Выходной класс объектов подходит для его использования в инструменте Создать пакет векторных листов в качестве входных индексных полигонов – при использовании индексированной структуры листов. Инструмент Создать пакет векторных листов использует эти полигоны для создания листов, оптимизированных для плотности объектов на создаваемых масштабных уровнях.
Подробнее о создании векторных листов см. в разделе Составление карты для создания векторных листов.
Синтаксис
arcpy.management.CreateVectorTileIndex(in_map, out_featureclass, service_type, {tiling_scheme}, {vertex_count})
Parameter | Объяснение | Тип данных |
in_map | Входная карта, от рассредоточения и плотности объектов на которой зависят размер и расположение выходных полигонов. Входная карта – это карта, которую вы будете последовательно использовать для создания векторных листов с помощью инструментаСоздать пакет векторных листов. | Map |
out_featureclass | Выходной класс полигональных объектов индексированных листов на каждом уровне детальности. Каждый лист содержит управляемое число входных вершин, не превышающее число, заданное в параметре vertex_count. | Feature Class |
service_type | Определяет, будет ли схема разбиения на листы создаваться из существующего картографического сервиса или для ArcGIS Online, Bing Maps и Google Maps.
| Boolean |
tiling_scheme (Дополнительный) | Используемый сервис векторных листов или файл схемы листов при значении EXISTING параметра service_type. Размер листа в схеме листов должен быть 512 на 512, а последовательность масштабов должна быть с коэффициентом отношения 2. | MapServer; File |
vertex_count (Дополнительный) | Идеальное число вершин – для всех видимых слоев – для каждого полигона выходного класса объектов. По умолчанию используется рекомендуемое значение – 10000 вершин. | Long |
Пример кода
Пример скрипта Python для использования инструмента CreateVectorTileIndex в режиме прямого запуска.
import arcpy
arcpy.env.workspace = "C:/data/cartography.gdb/transportation"
arcpy.CreateVectorTileIndex_management("CURRENT", "tiles", "ONLINE", "", 10000)
В этом автономном скрипте показан пример использования инструмента CreateVectorTileIndex.
# Name: CreateVectorTileIndex.py
# Description: Find all the maps in the project and
# create vector tile index polygon feature class for each map
# import system modules
import os
import arcpy
#set environment settings
arcpy.env.overwriteOutput = True
outputPath = "C://Tilepackages//"
# Loop through the project, find all the maps, and
# creates vector tile index polygon for each map,
# using the same name as the map
p = arcpy.mp.ArcGISProject("c:\\temp\\myproject.aprx")for m in p.listMaps():
print("Creating Vector Tile Index for: " + m.name)
arcpy.CreateVectorTileIndex_management(m, outputPath + m.name + '.shp', "ONLINE", "", 10000)
Environments
Информация о лицензиях
- Basic: Да
- Standard: Да
- Advanced: Да