ee.Geometry.MultiPolygon.symmetricDifference

返回两个几何图形之间的对称差。

用法返回
MultiPolygon.symmetricDifference(right, maxError, proj)几何图形
参数类型详细信息
此:left几何图形用作运算左操作数的几何图形。
right几何图形用作相应运算的右操作数的几何图形。
maxErrorErrorMargin,默认值:null执行任何必要的重新投影时可容忍的最大误差量。
proj投影,默认值:null执行操作的投影。如果未指定,则操作将在球面坐标系中执行,并且球面上的直线距离将以米为单位。

示例

代码编辑器 (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');

Python 设置

如需了解 Python API 和如何使用 geemap 进行交互式开发,请参阅 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