ee.Geometry.MultiPolygon.centroid

Zwraca punkt w środku komponentów geometrii o największym wymiarze. Komponenty o mniejszej liczbie wymiarów są ignorowane, więc środek ciężkości geometrii zawierającej 2 wielokąty, 3 linie i 1 punkt jest równoważny środkowi ciężkości geometrii zawierającej tylko 2 wielokąty.

WykorzystanieZwroty
MultiPolygon.centroid(maxError, proj)Geometria
ArgumentTypSzczegóły
to: geometryGeometriaOblicza środek masy tej geometrii.
maxErrorErrorMargin, domyślnie: nullMaksymalna dopuszczalna wartość błędu podczas wykonywania niezbędnej reprojekcji.
projPrognoza, domyślnie: nullJeśli zostanie określony, wynik będzie w tej projekcji. W przeciwnym razie będzie to EPSG:4326.

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]]]]);

// Apply the centroid method to the MultiPolygon object.
var multiPolygonCentroid = multiPolygon.centroid({'maxError': 1});

// Print the result to the console.
print('multiPolygon.centroid(...) =', multiPolygonCentroid);

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

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]]],
])

# Apply the centroid method to the MultiPolygon object.
multipolygon_centroid = multipolygon.centroid(maxError=1)

# Print the result.
display('multipolygon.centroid(...) =', multipolygon_centroid)

# 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(
    multipolygon_centroid,
    {'color': 'red'},
    'Result [red]: multipolygon.centroid',
)
m