ee.Geometry.MultiPolygon.symmetricDifference

Zwraca różnicę symetryczną między dwiema geometriami.

WykorzystanieZwroty
MultiPolygon.symmetricDifference(right, maxError, proj)Geometria
ArgumentTypSzczegóły
to: leftGeometriaGeometria używana jako lewy operand operacji.
rightGeometriaGeometria używana jako prawy operand operacji.
maxErrorErrorMargin, domyślnie: nullMaksymalna dopuszczalna wartość błędu podczas wykonywania niezbędnej reprojekcji.
projPrognoza, domyślnie: nullProjekcja, w której ma zostać wykonana operacja. Jeśli nie zostanie podana, operacja zostanie wykonana w sferycznym układzie współrzędnych, a odległości liniowe będą podawane w metrach na sferze.

Przykłady

Edytor kodu (JavaScript)

// Define a MultiPolygon object.
var multiPolygon = ee.Geometry.MultiPolygon(
    [[[[-122.092, 37.424],
       [-122.086, 37.418],
       [-122.079, 37.425],
       [-122.085, 37.423]]],
     [[[-122.081, 37.417],
       [-122.086, 37.421],
       [-122.089, 37.416]]]]);

// Define other inputs.
var inputGeom = ee.Geometry.BBox(-122.085, 37.415, -122.075, 37.425);

// Apply the symmetricDifference method to the MultiPolygon object.
var multiPolygonSymmetricDifference = multiPolygon.symmetricDifference({'right': inputGeom, 'maxError': 1});

// Print the result to the console.
print('multiPolygon.symmetricDifference(...) =', multiPolygonSymmetricDifference);

// Display relevant geometries on the map.
Map.setCenter(-122.085, 37.422, 15);
Map.addLayer(multiPolygon,
             {'color': 'black'},
             'Geometry [black]: multiPolygon');
Map.addLayer(inputGeom,
             {'color': 'blue'},
             'Parameter [blue]: inputGeom');
Map.addLayer(multiPolygonSymmetricDifference,
             {'color': 'red'},
             'Result [red]: multiPolygon.symmetricDifference');

Konfiguracja Pythona

Informacje o interfejsie Python API i używaniu geemap do interaktywnego programowania znajdziesz na stronie Środowisko Python.

import ee
import geemap.core as geemap

Colab (Python)

# Define a MultiPolygon object.
multipolygon = ee.Geometry.MultiPolygon([
    [[
        [-122.092, 37.424],
        [-122.086, 37.418],
        [-122.079, 37.425],
        [-122.085, 37.423],
    ]],
    [[[-122.081, 37.417], [-122.086, 37.421], [-122.089, 37.416]]],
])

# Define other inputs.
input_geom = ee.Geometry.BBox(-122.085, 37.415, -122.075, 37.425)

# Apply the symmetricDifference method to the MultiPolygon object.
multipolygon_symmetric_difference = multipolygon.symmetricDifference(
    right=input_geom, maxError=1
)

# Print the result.
display(
    'multipolygon.symmetricDifference(...) =', multipolygon_symmetric_difference
)

# Display relevant geometries on the map.
m = geemap.Map()
m.set_center(-122.085, 37.422, 15)
m.add_layer(
    multipolygon, {'color': 'black'}, 'Geometry [black]: multipolygon'
)
m.add_layer(input_geom, {'color': 'blue'}, 'Parameter [blue]: input_geom')
m.add_layer(
    multipolygon_symmetric_difference,
    {'color': 'red'},
    'Result [red]: multipolygon.symmetricDifference',
)
m