描述
基于面索引图层将地图中的各图层的标注转换为注记。
该工具将地图划分为多个分块并依次为每一块创建注记。 这非常适合于将大量标注转换为注记。 面索引图层可以使用地图服务器缓存切片方案转换为面或格网索引要素工具生成,也可以是覆盖了要创建注记的区域的任何其他面要素类。
使用方法
标注分类比例范围将被考虑。 当该工具生成指定参考比例的注记时,它将仅转换该比例下呈启用状态并且可见的标注分类。
如果在运行该工具之前选择分块,则只会为所选分块创建注记。
若只需为面索引图层中的某些分块更新注记,可先选择带有该特定 TileID 值的注记要素并删除它们。 然后选择面要素并重新运行该工具。
该工具的输出是一系列图层组。 在每个图层组中,需要创建注记的每个参考比例均将对应一个组中图层。
在 ArcCatalog 或 模型构建器 工作环境下,可使用保存至图层文件工具将输出图层组写入图层文件中。 使用 ArcMap 时,如果在地理处理选项中选中相关选项,该工具可将图层组添加到视图区域。 所创建的图层组是临时性的,如果不保存文档,该图层组将在会话结束后消失。
除非使用保存至图层文件工具将在 ArcCatalog 中创建的图层保存为图层文件,否则无法在 ArcMap 中使用这些图层。
如果指定的图层名称相同并且已明确声明允许覆盖输出,则现有图层组将被覆盖。
如果数据框中存在重复的要素类名称,则注记中的要素类名之后将添加一个数字(例如,Cities01Anno10000、Cities02Anno10000 等)。
如果指定了现有后缀,则不会覆盖注记要素类。 在这种情况下,注记要素类后缀中将添加一个数字(例如 CitiesAnno10000、CitiesAnno10000_1 等)。
注记要素类的参考比例可通过以下两种方式之一进行指定:
- 第一种是,通过面索引图层中的某个字段来确定输出注记要素类的参考比例。 如果要为各个比例级别创建注记,则可以选用这种方式。
- 第二种就是明确声明一个参考比例值。 所有的注记要素类都将使用这个参考比例。 如果在地图文档中设置了参考比例,则该参考比例将作为默认值输入到工具中。 使用 ArcMap 时,如果尚未设置参考比例,则当前比例将作为默认值。
如果使用的是通过地图服务器缓存切片方案转面工具创建的面索引图层,请使用参考比例字段参数的 Tile_Scale 字段。 将会为每个图层-Tile_Scale 组合创建注记要素类。
如果正在生成多个参考比例下的注记,请在每种比例下分别设计地图并避免设置参考比例。
如果面索引图层中提供坐标系字段,则各分块的注记将投影到该坐标系中,以便进行绘制和放置。
与要素关联的注记与地理数据库中另一个要素类中的特定要素相关联。 如果创建关联要素的注记,则将自动生成关系类。
创建关联要素的注记时,输出工作空间必须与所关联要素类的输出工作空间相同。
某些标注目前可能未显示在地图上,原因是没有供它们显示的空间。 要转换这些标注,请选中生成未放置的注记复选框。 这样便可将未放置的标注保存到注记要素类中,以便今后在编辑会话中可以找到它们。
语法
arcpy.cartography.TiledLabelsToAnnotation(map_document, data_frame, polygon_index_layer, out_geodatabase, out_layer, anno_suffix, {reference_scale_value}, {reference_scale_field}, {tile_id_field}, {coordinate_sys_field}, {map_rotation_field}, {feature_linked}, {generate_unplaced_annotation})
参数 | 说明 | 数据类型 |
map_document | 包含要转换为注记的标注的源地图文档。 | ArcMap Document |
data_frame | 地图文档中包含要转换为注记的标注的数据框。 | String |
polygon_index_layer | 包含分块要素的面图层。 | Table View |
out_geodatabase | 用来保存输出要素类的工作空间。 此工作空间可以是现有地理数据库或现有要素数据集。 | Workspace; Feature Dataset |
out_layer | 包含所生成注记的图层组。 在 ArcCatalog 工作环境下,可使用保存至图层文件工具将输出图层组写入图层文件中。 使用 ArcMap 时,如果在地理处理选项中选中相关选项,该工具可将图层组添加到视图区域。 所创建的图层组是临时性的,如果不保存文档,该图层组将在会话结束后消失。 | Group Layer |
anno_suffix | 为每个新注记要素类添加的后缀。 该后缀将追加到各新注记要素类的源要素类名称之后。 注记的参考比例遵照该后缀。 | String |
reference_scale_value (可选) | 将用作注记参考的比例值。 注记中的所有符号及文本的大小都会参照此比例。 | Double |
reference_scale_field (可选) | 面索引图层中用于确定注记参考比例的字段。 注记中的所有符号及文本的大小都会参照此比例。 | Field |
tile_id_field (可选) | 面索引图层中用于唯一标识分块区域的字段。 这些值将填充到注记要素类属性表中的 TileID 字段。 | Field |
coordinate_sys_field (可选) | 面索引图层中包含各分块坐标系信息的字段。 考虑到存储坐标系信息时所需的字段长度,包含坐标系字段的面索引图层必须为地理数据库要素类。 | Field |
map_rotation_field (可选) | 面索引图层中包含数据框将旋转角度值的字段。 | Field |
feature_linked (可选) | 用于指定是否将输出注记要素类关联到其他要素类中的要素。
| Boolean |
generate_unplaced_annotation (可选) | 指定是否将基于未放置标注创建未放置注记。
| Boolean |
派生输出
名称 | 说明 | 数据类型 |
out_workspace | 用来保存输出要素类的工作空间。 | Workspace; Feature Dataset |
代码示例
TiledLabelsToAnnotation 示例(Python 窗口)
TiledLabelsToAnnotation 函数的 Python 示例,可基于面索引图层将地图文档中各图层的标注转换为注记。
import arcpy
arcpy.env.workspace = "C:/data/data.gdb"
arcpy.TiledLabelsToAnnotation_cartography("Annotation.mxd", "Layers",
"data.gdb", "GroupAnno", "Anno", "",
"Tile_Scale", "OID", "", "",
"FEATURE_LINKED",
"GENERATE_UNPLACED_ANNOTATION")
TiledLabelsToAnnotation 示例 2(工作流脚本)
以下脚本演示了使用 MapServerCacheTilingSchemeToPolygons 函数和 TiledLabelsToAnnotation 函数的工作流。
# Name: TiledLabelsToAnnotation_Example2.py
# Description: Create a tile feature class and use those tiles to create annotation.
# Requirements: ArcGIS Desktop Advanced license
# Import system modules
import arcpy
import os
# Set environment settings
arcpy.env.workspace = "C:/data/data.gdb"
# Set local variables
inMapDocument = "C:/data/Annotation.mxd"
inDataFrame = "Layers"
inTilingScheme = os.path.join(
arcpy.GetInstallInfo()['InstallDir'],
"TilingSchemes\\ArcGIS_Online_Bing_Maps_Google_Maps.xml")
outFeatureClass = "C:/data/data.gdb/Tiles"
inTileExtent = "USE_MAP_EXTENT"
inClipping = "CLIP_TO_HORIZON"
inAntialiasing = "NONE"
inScales = ""
# Execute MapServerCacheTilingSchemeToPolygons
arcpy.MapServerCacheTilingSchemeToPolygons_cartography(
inMapDocument, inDataFrame, inTilingScheme, outFeatureClass, inTileExtent,
inClipping, inAntialiasing, inScales)
# Set local variables
inMapDocument = "C:/data/Annotation.mxd"
inDataFrame = "Layers"
inPolygonIndexLayer = "Tiles"
inOutGeodatabase = "C:/data/data.gdb"
outOutLayer = "GroupAnno"
inAnnoSuffix = "Anno"
inRefScaleValue = ""
inRefScaleField = "Tile_Scale"
inTileIDField = "OID"
inCoordSysField = ""
inMapRotationField = ""
inFeatureLinked = "STANDARD"
inGenerateUnplaced = "GENERATE_UNPLACED_ANNOTATION"
# Execute TiledLabelsToAnnotation
arcpy.TiledLabelsToAnnotation_cartography(
inMapDocument, inDataFrame, inPolygonIndexLayer, inOutGeodatabase,
outOutLayer, inAnnoSuffix, inRefScaleValue, inRefScaleField, inTileIDField,
inCoordSysField, inMapRotationField,inFeatureLinked, inGenerateUnplaced)
环境
许可信息
- Basic: 是
- Standard: 是
- Advanced: 是