Extraction par cercle (Spatial Analyst)

Disponible avec une licence Spatial Analyst.

Résumé

Permet d'extraire les cellules d'un raster en fonction d'un cercle en spécifiant le centre et le rayon du cercle.

Illustration

Illustration de l'outil Extraction par cercle
OutRas = ExtractByCircle(InRas1, Point(2.5,2.5), 2, "INSIDE")

Utilisation

  • Les éventuels attributs supplémentaires du raster en entrée seront transférés tels quels dans la table attributaire de raster en sortie. Selon la propriété enregistrée, il est possible que certaines valeurs attributaires doivent être recalculées.

  • Lorsqu’un raster multicanal est spécifié en tant que Input raster (Raster en entrée) (in_raster dans Python), tous les canaux sont utilisés.

    Pour traiter une sélection de canaux d’un raster multicanal, créez tout d’abord un jeu de données raster composé de ces canaux spécifiques à l’aide de l’outil Canaux composites. Utilisez ensuite le résultat en tant que raster en entrée (in_raster dans Python).

    Le format en sortie par défaut est un raster de géodatabase. Si le format en sortie est une pile de grilles Esri, le nom de la pile ne peut pas commencer par un nombre, utiliser des espaces ni comporter plus de neuf caractères.

  • Le centre de la cellule permet de déterminer si une cellule est à l'intérieur ou à l'extérieur d'un cercle. Si le centre se trouve dans l'arc du cercle, on considère que la cellule entière se trouve à l'intérieur, même si ses proportions débordent du cercle.

  • La valeur NoData est attribuée aux emplacements de cellule qui ne sont pas sélectionnés.

  • Si le raster en entrée est un nombre entier, le raster en sortie sera un nombre entier. Si l'entrée est à virgule flottante, la sortie sera également à virgule flottante.

  • Pour plus d’informations sur les environnements de géotraitement qui s’appliquent à cet outil, reportez-vous à la rubrique Environnements d’analyse et Spatial Analyst.

Syntaxe

ExtractByCircle(in_raster, center_point, radius, {extraction_area})
ParamètreExplicationType de données
in_raster

Raster en entrée à partir duquel les cellules seront extraites.

Raster Layer
center_point

La classe Point régit les coordonnées du centre (x,y) du cercle et indique la surface que vous devez extraire.

Cette classe se présente comme suit :

  • Point (x, y)

Les coordonnées sont spécifiées dans les mêmes unités de carte que le raster en entrée.

Point
radius

Le rayon du cercle définissant la zone à extraire.

Le rayon est spécifié en unités de carte et possède les mêmes unités que le raster en entrée.

Double
extraction_area
(Facultatif)

Détermine l'extraction des cellules à l'intérieur ou à l'extérieur du cercle en entrée.

  • INSIDEMot-clé spécifiant que les cellules situées à l'intérieur du cercle en entrée doivent être sélectionnées et enregistrées dans le raster en sortie. Toutes les cellules situées à l'extérieur du cercle adopteront les valeurs NoData sur le raster en sortie.
  • OUTSIDEMot-clé spécifiant que les cellules situées à l'extérieur du cercle en entrée doivent être sélectionnées et enregistrées dans le raster en sortie. Toutes les cellules situées à l'intérieur du cercle adopteront les valeurs NoData sur le raster en sortie.
String

Valeur renvoyée

NomExplicationType de données
out_raster

Raster en sortie contenant les valeurs de cellule extraites du raster en entrée.

Raster

Exemple de code

Premier exemple d'utilisation de l'outil ExtractByCircle (fenêtre Python)

Dans cet exemple, on extrait des cellules dans un rayon de 500 mètres autour d'un emplacement de point.

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outExtCircle = ExtractByCircle("elevation", arcpy.Point(482838.823, 222128.982),
                                500, "INSIDE")
outExtCircle.save("c:/sapyexamples/output/extcircle")
Deuxième exemple d'utilisation de l'outil ExtractByCircle (script autonome)

Dans cet exemple, on extrait des cellules dans un rayon de 1 000 mètres autour d'un emplacement de point.

# Name: ExtractByCircle_Ex_02.py
# Description: Extracts the cells of a raster based on a circle.
# Requirements: Spatial Analyst Extension

# Import system modules
import arcpy
from arcpy import env
from arcpy.sa import *

# Set environment settings
env.workspace = "C:/sapyexamples/data"

# Set local variables
inRaster = ("elevation")
centerPoint = arcpy.Point(482838.823, 222128.982)
circRadius = 1000
extractType = "INSIDE"

# Execute ExtractByCircle
outExtCircle = ExtractByCircle(inRaster, centerPoint, circRadius, 
                               extractType)

# Save the output 
outExtCircle.save("c:/sapyexamples/output/extcircle02")

Informations de licence

  • Basic: Requiert Spatial Analyst
  • Standard: Requiert Spatial Analyst
  • Advanced: Requiert Spatial Analyst

Rubriques connexes