添加要素图层

了解如何访问和显示要素图层中的点、线、面要素

要素图层要素服务的数据集。要素图层的每个要素都具有同样的几何类型 (线) 和属性。要素图层可以用来存储、访问和管理大数据量地理数据。通过访问要素服务的 URL 可以获取要素。

在本教程中,将使用 URL 访问和显示三种不同类型的托管要素图层

步骤

创建新 Pen

  1. 在此之前,先了解显示地图教程

添加模块

  1. 通过 require 引入FeatureLayer 模块。

    GeoScene Maps SDK for JavaScript 提供了 AMD 模块ES 模块,本教程中我们是以 AMD 为例。AMD 使用require 函数加载模块 - 例如,您可以指定 "geoscene/Map" 来加载 Map 模块。加载后,它们将作为参数 (例如,Map) 传递给回调函数,以便在应用程序中使用。保持引用模块和回调参数的顺序相同是很重要的。有关不同类型模块的更多信息,请访问工具指南主题。

    展开
    代码块使用深色
                                                                        
    添加行。更改行
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
      <script>
      require([
        "geoscene/config",
        "geoscene/Map",
        "geoscene/views/MapView",
    
        "geoscene/layers/FeatureLayer"
    
      ], function(geosceneConfig, Map, MapView, FeatureLayer) {
    
      });
    </script>
    
    展开

添加点要素图层

要素通常显示其他类型的要素图层上。接下来引用 登山点创建一个FeatureLayer ,然后将其添加到地图中。

  1. 查看 登山点 图层属性。示例中我们使用到 NameTypeDrawing InfoFields 属性。

  2. CodePen 中,创建 FeatureLayer 并设置 url 属性。

    展开
    代码块使用深色
                                                                        
    添加行。添加行。添加行。添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
      const view = new MapView({
        container: "viewDiv",
        map: map,
        center: [-118.80543,34.02700],
        zoom: 13
      });
    
    //登山点 feature layer (points)
      const trailheadsLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Trailheads/FeatureServer/0"
      });
    
    展开
  3. trailheadsLayer 添加到地图。

    展开
    代码块使用深色
                                                                        
    添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    //登山点 feature layer (points)
      const trailheadsLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Trailheads/FeatureServer/0"
      });
    
      map.add(trailheadsLayer);
    
    展开
  4. 运行应用程序,在地图中查看登山点 图层

添加线要素图层

线要素通常需要在点要素图层显示,避免压盖。引用 徒步路线 创建 FeatureLayer 类,然后将要素图层添加到地图中。

  1. 访问 徒步路线 图层属性。示例中我们将使用 NameTypeDrawing InfoFields 字段。

  2. CodePen 中,创建 FeatureLayer 并设置 url 属性。

    展开
    代码块使用深色
                                                                        
    添加行。添加行。添加行。添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
      map.add(trailheadsLayer);
    
    //徒步路线 feature layer (lines)
      const trailsLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Trails/FeatureServer/0"
      });
    
    展开
  3. 添加图层到地图中,设置索引参数为 0 ,这样可以将 trailsLayer 添加到图层数组第一个,并在 trailheadsLayer 之前绘制。

    展开
    代码块使用深色
                                                                        
    添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    //徒步路线 feature layer (lines)
      const trailsLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Trails/FeatureServer/0"
      });
    
      map.add(trailsLayer, 0);
    
    展开
  4. 运行应用程序以在地图中查看徒步路线 图层

添加面要素图层

要素通常在线要素图层之前。引用 公园和广场图层URL 创建 FeatureLayer 类 ,然后将要素图层添加到地图中。

  1. 查看 公园和广场图层 属性。示例中我们使用 NameTypeDrawing InfoFields 字段。

  2. CodePen 中,创建 FeatureLayer 并设置 url 属性。

    展开
    代码块使用深色
                                                                        
    添加行。添加行。添加行。添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
      map.add(trailsLayer, 0);
    
    // 公园和广场 (polygons)
      const parksLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Parks_and_Open_Space/FeatureServer/0"
      });
    
    展开
  3. 添加图层到地图中,设置索引参数为 0parksLayer 添加到地图中。这样可确保添加到图层数据第一位,并在 trailsLayer 之前绘制。

    展开
    代码块使用深色
                                                                        
    添加行。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    // 公园和广场 (polygons)
      const parksLayer = new FeatureLayer({
        url: "https://services3.arcgis.com/GVgbJbqm8hXASVYi/arcgis/rest/services/Parks_and_Open_Space/FeatureServer/0"
      });
    
      map.add(parksLayer, 0);
    
    展开

运行应用程序

CodePen 中,运行代码以显示地图。

最终,地图视图会显示地图中的三个要素图层,并按以下顺序绘制:

  1. 地形图底图图层
  2. 公园和广场 ()
  3. 徒步路线 (线)
  4. 登山点 ()

请务必按正确的顺序添加要素图层,以便正确显示要素(不重叠),并可与要素进行交互。

下一步是什么?

要了解如何使用其他 API 功能,请参阅以下教程:

您的浏览器不再受支持。请升级您的浏览器以获得最佳体验。