Add raster from service

View on GitHub

Create a raster layer from a raster image service.

Image of Add raster from service sample

Use case

Accessing a raster image from an online service can be useful for analysing the most up-to-date data available for an area. For example, retrieving recent results of bathymetry surveys within a shipping channel monitored for its sediment build-up would allow planners to assess dredging needs.

How to use the sample

Simply launch the sample to see a raster from an image service being used on a map.

How it works

  1. Create an ImageServiceRaster using the service's URL.
  2. Create a RasterLayer from the image service raster.
  3. Add the raster layer to the map.

Relevant API

  • ImageServiceRaster
  • RasterLayer

About the data

This sample uses a NOAA raster image service. The service computes a bathymetry image from the depth (in meters) of U.S. coastal waters.

Tags

image service, raster

Sample Code

AddRasterFromServiceView.swift
Use dark colors for code blocksCopy
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
// Copyright 2024 Esri
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//   https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

import ArcGIS
import SwiftUI

struct AddRasterFromServiceView: View {
    /// The error shown in the error alert.
    @State private var error: Error?

    /// The current draw status of the map.
    @State private var currentDrawStatus: DrawStatus = .inProgress

    /// A map with a dark gray basemap and a raster layer.
    @State private var map: Map = {
        let map = Map(basemapStyle: .arcGISDarkGrayBase)
        // Creates an initial viewpoint with a coordinate point centered on
        // San Francisco's Golden Gate Bridge.
        map.initialViewpoint = Viewpoint(
            center: Point(x: -13_637_000, y: 4_550_000, spatialReference: .webMercator),
            scale: 100_000
        )
        // Creates a raster from an image service.
        let imageServiceRaster = ImageServiceRaster(url: .imageServiceURL)
        // Creates a raster layer from the raster.
        let rasterLayer = RasterLayer(raster: imageServiceRaster)
        map.addOperationalLayer(rasterLayer)
        return map
    }()

    /// The raster layer in the map.
    private var rasterLayer: RasterLayer {
        map.operationalLayers.first as! RasterLayer
    }

    var body: some View {
        MapView(map: map)
            .onDrawStatusChanged { drawStatus in
                // Updates the state when the map's draw status changes.
                withAnimation {
                    currentDrawStatus = drawStatus
                }
            }
            .overlay(alignment: .center) {
                if currentDrawStatus == .inProgress {
                    ProgressView("Drawing…")
                        .padding()
                        .background(.ultraThinMaterial)
                        .clipShape(.rect(cornerRadius: 10))
                        .shadow(radius: 50)
                }
            }
            .task {
                do {
                    // Loads a raster layer from online service.
                    try await rasterLayer.load()
                } catch {
                    // Presents an error message if the raster fails to load.
                    self.error = error
                }
            }
            .errorAlert(presentingError: $error)
    }
}

private extension URL {
    static let imageServiceURL = URL(string: "https://gis.ngdc.noaa.gov/arcgis/rest/services/bag_bathymetry/ImageServer")!
}

#Preview {
    AddRasterFromServiceView()
}

Your browser is no longer supported. Please upgrade your browser for the best experience. See our browser deprecation post for more details.