Rubbersheet für Features durchführen (Editieren)

Lizenzstufe:BasicStandardAdvanced

Zusammenfassung

Ändert Eingabe-Linien-Features durch eine räumliche Anpassung durch Rubbersheeting mithilfe der angegebenen Rubbersheet-Links, um eine bessere Ausrichtung an den gewünschten Ziel-Features zu erreichen.

Bild

Rubbersheet für Features durchführen

Verwendung

Syntax

RubbersheetFeatures_edit (in_features, in_link_features, {in_identity_links}, {method})
ParameterErläuterungDatentyp
in_features

Eingabe-Linien-Features, die angepasst werden sollen.

Feature Layer
in_link_features

Eingabe-Linien-Features, die reguläre Links für das Rubbersheeting darstellen.

Feature Layer
in_identity_links
(optional)

Eingabe-Punkt-Features, die Identity-Links für Rubbersheeting darstellen.

Feature Layer
method
(optional)

Rubbersheeting-Methode, die zum Anpassen von Features verwendet wird.

  • LINEARDiese Methode nimmt weniger Zeit in Anspruch und eignet sich, wenn Sie über viele Links verfügen, die gleichmäßig über die anzupassenden Daten verteilt sind. Dies ist die Standardeinstellung.
  • NATURAL_NEIGHBORVerwenden Sie diese Methode, wenn Sie über wenige Links verfügen, die weit voneinander entfernt liegen.
String

Codebeispiel

RubbersheetFeatures – Beispiel 1 (Python-Fenster)

Das folgende Skript im Python-Fenster veranschaulicht, wie Sie die Funktion "RubbersheetFeatures" im unmittelbaren Modus verwenden.

import arcpy
arcpy.env.workspace = "C:/data"
arcpy.RubbersheetFeatures_edit("source_Roads.shp","rubbersheet_Links.shp",
                               "rubbersheet_Links_pnt.shp", "LINEAR")
RubbersheetFeatures – Beispiel 2 (eigenständiges Python-Skript)

Das folgende eigenständige Skript ist ein Beispiel für die Anwendung der Funktion "RubbersheetFeatures" in einer Skriptumgebung.

# Name:        RubbersheetFeatures_example_script2.py
# Description: Performs rubbersheeting spatial adjustment using links produced by
#              GenerateRubbersheetLinks, assuming newly updated roads are more
#              accurate than existing base roads. The links go from base road data
#              to corresponding newly updated road data. The links are then
#              analyzed for potential errors; they are finally used to adjust the
#              base roads (a copy is made) to better align with the updated roads.
# Author:      Esri
# -----------------------------------------------------------------------

# Import system modules
import arcpy
from arcpy import env

# Set environment settings
env.overwriteOutput = True
env.workspace = r"D:\conflationTools\ScriptExamples\data.gdb"

# Set local variables
sourceFeatures = "baseRoads"
targetFeatures = "updateRoads"
grlOutput = "grlinks_out"
grlOutputPts = "grlinks_out_pnt"

search_distance = "300 Feet"
match_fields = "FULLNAME RD_NAME"

qaLocations = "qa_locations"

# Generate rubbersheet links
arcpy.GenerateRubbersheetLinks_edit(sourceFeatures, targetFeatures, grlOutput, search_distance, match_fields)

# ====================================================================================
# Note 1:  The result of GenerateRubbersheetLinks may contain errors; see tool reference.
#          Inspection and editing may be necessary to ensure correct links before using
#          them for rubbersheeting.
#
#          One of the common errors are intersecting or touching links. Their locations 
#          can be found by the process below.
# ====================================================================================

# Find locations where links intersect or touch; the result contains coincident points
arcpy.Intersect_analysis(grlOutput, qaLocations, "", "", "POINT")

# Delete coincident points
arcpy.DeleteIdentical_management(qaLocations, "Shape")

# ====================================================================================
# Note 2:  At this point you can manually inspect locations in qaLocations; delete or
#          modify links as needed.
# ====================================================================================

# Make a copy of the sourceFeatures for rubbersheeting
arcpy.CopyFeatures_management(sourceFeatures, "sourceFeatures_Copy")

# Use the links for rubbersheeting
arcpy.RubbersheetFeatures_edit("sourceFeatures_Copy", grlOutput, grlOutputPts, "LINEAR")

Umgebung

Verwandte Themen

Lizenzierungsinformationen

ArcGIS for Desktop Basic: Nein
ArcGIS for Desktop Standard: Nein
ArcGIS for Desktop Advanced: Ja
5/12/2014