回答:
直接ではありませんが、Pythonとarcpy.mappingモジュールでこれを行うことができます。各ブックマークの範囲を取得するには、arcpy.mapping.ListBookmarksを使用します。次に、各エクステントのフィーチャを作成します。これで、この機能クラスをデータドリブンページのインデックスレイヤーとして使用できるようになります。
すぐに使える機能としてこれを望んでいるのは、あなただけではありません。少なくとも3つのArcGISアイデアがあり、次の名前を追加することをお勧めします。
それまでの間、誰かがBookMarks To Feature Classツールを書くように促された場合、その出力はデータドリブンページのインデックスフィーチャクラスとして適切に使用されると思います。
私はこれを、ListBookmarksのArcGISオンラインヘルプ(arcpy.mapping)のサンプルコードに大きく基づいたトレーニング演習として行うことにしました。
import arcpy
# The map with the bookmarks
mxd = arcpy.mapping.MapDocument(r"C:\polygeo\Maps\Bookmarks.mxd")
# Make sure that Training.gdb exists
fileGDBFolder = (r"C:\polygeo")
fileGDBName = ("Training.gdb")
fileGDB = fileGDBFolder + "\\" + fileGDBName
if not arcpy.Exists(fileGDB):
arcpy.CreateFileGDB_management(fileGDBFolder, fileGDBName)
# The output feature class to be created -
# This feature class will store the bookmarks as features
fcName = "Bookmarks"
outFC = fileGDB + "\\" + fcName
# Create new feature class and add a "Name" field to store the
# bookmark name. Provide it with the same Spatial reference as
# the data frame in which the bookmarks of the map are stored
if arcpy.Exists(outFC):
arcpy.Delete_management(outFC)
arcpy.CreateFeatureclass_management(fileGDB,
fcName,
"POLYGON",
spatial_reference=arcpy.SpatialReference(
"Geocentric Datum of Australia 1994"))
arcpy.AddField_management(outFC, "Name", "TEXT", "", "", 50)
# Use arcpy.mapping.ListBookmarks to read bookmark corners and names,
# then arcpy.da.InsertCursor to write arrays of Point geometries from
# that can be written as Polygon geometries to the Shape field of the
# new feature class (with their names).
cur = arcpy.da.InsertCursor(outFC, ["SHAPE@", "Name"])
array = arcpy.Array()
for bkmk in arcpy.mapping.ListBookmarks(mxd):
array.add(arcpy.Point(bkmk.extent.XMin, bkmk.extent.YMin))
array.add(arcpy.Point(bkmk.extent.XMin, bkmk.extent.YMax))
array.add(arcpy.Point(bkmk.extent.XMax, bkmk.extent.YMax))
array.add(arcpy.Point(bkmk.extent.XMax, bkmk.extent.YMin))
# To close the polygon, add the first point again
array.add(arcpy.Point(bkmk.extent.XMin, bkmk.extent.YMin))
cur.insertRow([arcpy.Polygon(array), bkmk.name])
array.removeAll()
del bkmk,array,cur,mxd
print "Bookmarks feature class has been created in " + fileGDB
私たちは、に、そのファイルをロードし、その後.datファイルとしてブックマークを保存することで、フィーチャクラスを作成することができました[お気に入り ]をクリックし、[お気に入り]ダイアログボックス内でそれらを選択し、ツールに追加するボタンをクリックし、選択した地図などのグラフィックをしたらグラフィックを作成してから、マップ内のすべてのグラフィックを選択し、[ グラフィックをフィーチャに変換]を使用して、データドリブンページのフィーチャクラスを使用できます。注:グラフィックはポリゴンとして取得されました。すべてのクレジットはセネカフランシスに寄付されます。