ArcGIS fournit tous les outils nécessaires pour créer des atlas imprimés ou au format PDF d'Adobe. Un atlas est un ensemble de pages imprimées ou exportées ensemble. La plupart des pages contiennent des cartes, mais d'autres pages peuvent présenter du texte, des informations tabulaires, des tables des matières ou des titres et tout autre contenu.
Pour être plus complet, un atlas comprend une page de titre et une page d'index de carte (ou une carte globale). Vous pouvez créer ce type d'atlas en utilisant les pages dynamiques d'ArcMap et un script Python arcpy.mapping. Utilisez les pages dynamiques pour un document ArcMap unique (mise en page unique) afin de créer des pages de carte pour l'atlas, et utilisez un autre document ArcMap pour créer une page de carte-index. Vous pourriez encore utiliser un troisième document ArcMap pour créer la page de titre ou un autre logiciel pour créer un document PDF pour la page de titre. Utilisez arcpy.mapping pour combiner tous ces éléments dans un atlas unique.
L'exemple ci-dessus montre un atlas topographique d'Arenac County, dans le Michigan. Cette carte comprend une page de titre et une page de carte globale. Vous pouvez créer ce document à l'aide des pages dynamiques et d'un script Python arcpy.mapping.
Pour plus d'informations, reportez-vous à la rubrique Création de pages dynamiques
Cet exemple repose sur les conditions suivantes :
- Vous disposez d'une carte existante dont l'option Pages dynamiques est activée.
Cet exemple de code utilise l'exemple d'atlas de référence simple figurant dans la rubrique Création d'atlas avec ArcGIS.
Vous pouvez recréer cet atlas en suivant les étapes décrites dans les rubriques d'aide suivantes : - Vous disposez d'un fichier PDF existant pour la page de titre de l'atlas.
- Vous disposez d'un fichier PDF existant qui contient la page de carte globale.
Puisque l'atlas affiche des numéros de page, vous devez vous assurer que le numéro de la première page dynamique prend en compte toutes les pages de l'atlas final qui la précède. Dans cet exemple, il y a deux pages qui précèdent les pages de carte. Par conséquent, les pages de carte démarrent avec "page 3". Assurez-vous que "3" est la valeur attribuée pour l'option Numéro de la page de début dans la boîte de dialogue Configurer les pages dynamiques.
Assurez-vous également que vous utilisez les éléments de texte corrects si vous affichez le numéro de page. Vous ne devez pas utiliser Page dynamique avec numéro, car le total correspond uniquement au nombre total de pages dynamiques. Il ne comprend pas les autres pages, telles que les pages de titre ou de rapport, que vous incorporerez à l'atlas final. A la place utilisez, Numéro de la page dynamique et combinez ce texte dynamique avec le texte statique qui affiche le nombre total de pages, par exemple, Page <dyn type="page" property="number"/> of 26.
Une fois que votre carte et vos fichiers PDF sont prêts, vous pouvez exécuter le code ci-dessous pour créer votre atlas final au format PDF. Vous pouvez exécuter le code dans la fenêtre Python ou dans une application Python autonome.
Bien que le code spécifique de cette rubrique s'applique à l'exemple d'atlas ci-dessus, vous pouvez également utiliser les procédures et les conseils présentés ici pour vos propres cartes et atlas.
Ce script exporte un atlas vers un document PDF intégrant les pages de titre et de carte globale.
import arcpy, os
# Create an output directory variable
#
outDir = r"C:\temp\MBExample\final_output"
# Create a new, empty pdf document in the specified output directory
#
finalpdf_filename = outDir + r"\FinalMB.pdf"
if os.path.exists(finalpdf_filename):
os.remove(finalpdf_filename)
finalPdf = arcpy.mapping.PDFDocumentCreate(finalpdf_filename)
# Add the title page to the pdf
#
finalPdf.appendPages(r"C:\temp\MBExample\ancillary_pages\TitlePage.pdf")
# Add the index map to the pdf
#
finalPdf.appendPages(r"C:\temp\MBExample\maps\IndexMap.pdf")
# Export the Data Driven Pages to a temporary pdf and then add it to the
# final pdf. Alternately, if your Data Driven Pages have already been
# exported, simply append that document to the final pdf.
#
mxdPath = r"C:\temp\MBExample\maps\ArenacDDP.mxd"
tempMap = arcpy.mapping.MapDocument(mxdPath)
tempDDP = tempMap.dataDrivenPages
temp_filename = r"C:\temp\MBExample\temp_pdfs\tempDDP.pdf"
if os.path.exists(temp_filename):
os.remove(temp_filename)
tempDDP.exportToPDF(temp_filename, "ALL")
finalPdf.appendPages(temp_filename)
# Update the properties of the final pdf
#
finalPdf.updateDocProperties(pdf_open_view="USE_THUMBS",
pdf_layout="SINGLE_PAGE")
# Save your result
#
finalPdf.saveAndClose()
# Delete variables
#
del finalPdf, tempMap, tempDDP
Les premières lignes de code permettent d'effectuer les opérations suivantes : importer les modules nécessaires ; créer une variable d'emplacement des données en sortie où l'atlas final au format PDF sera enregistré ; créer un nouveau document PDF vide dans le dossier d'emplacement des données de sortie spécifié. Ce PDF est le document de sortie final pour ce script.
Pour plus d'informations, reportez-vous à la rubrique Classe PDFDocument d'arcpy.mapping.
Les lignes de code suivantes ajoutent la page de titre et la page de carte globale au PDF final. Cet exemple suppose que vous disposez de documents PDF existants pouvant être utilisés pour les pages de titre et de carte globale.
L'étape suivante consiste à ajouter les pages de carte. Cela nécessite que vous ayez une carte dont l'option Pages dynamiques est déjà activée. Dans cet exemple, ce document s'appelle ArenacDDP.mxd.
Pour plus d'informations, reportez-vous aux rubriques Classe MapDocument et Classe DataDrivenPages d'arcpy.mapping.
Enfin, le code met à jour les propriétés, puis enregistre et ferme le PDF final.