// Canny 边缘检测器示例。
// 加载图像并从中计算 NDVI。
var image = ee.Image('LANDSAT/LT05/C01/T1_TOA/LT05_031034_20110619');  

//用内置函数波段计算NDVI

var ndvi = image.normalizedDifference(['B4','B3']);  

// 检测合成中的边缘,这里面设置的数值为0.7
   var canny = ee.Algorithms.CannyEdgeDetector(ndvi, 0.7);  

// 用自身屏蔽图像以去除没有边缘的区域。
canny = canny.updateMask(canny);  

Map.setCenter(-101.05259, 37.93418, 13);  

Map.addLayer(ndvi, {min: 0, max: 1}, 'Landsat NDVI');  

Map.addLayer(canny, {min: 0, max: 1, Palette: 'FF0000'}, 'Canny Edges');

具体代码如下(ndvi>0.7):

// Canny Edge Detector example.

// Load an image and compute NDVI from it.
var image = ee.Image('LANDSAT/LT05/C01/T1_TOA/LT05_031034_20110619');
var ndvi = image.normalizedDifference(['B4','B3']);

// Detect edges in the composite.
var canny = ee.Algorithms.CannyEdgeDetector(ndvi, 0.7);

// Mask the image with itself to get rid of areas with no edges.
canny = canny.updateMask(canny);

Map.setCenter(-101.05259, 37.93418, 13);
Map.addLayer(ndvi, {min: 0, max: 1}, 'Landsat NDVI');
Map.addLayer(canny, {min: 0, max: 1, palette: 'FF0000'}, 'Canny Edges');

最后识别结果图:NDVI>0.7

NDVI> 0.5

整体根据canny识别植被边界的效果还是不错的,如果自己感兴趣可以换EVI之类的指数试一试!

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐