Skip to content

You can take certain utility network information offline. Associations, which are used to describe containment, structural attachment, and connection between features with non-coincident geometry, can be queried and displayed with offline data. Simple edits can also be made to utility network features while offline and synchronized back to ArcGIS Enterprise.

The following code takes a web map offline that contains a utility network. The utility network tables are automatically synced with a map when a utility network is detected within.

You can take certain utility network information offline. Associations, which are used to describe containment, structural attachment, and connection between features with non-coincident geometry, can be queried and displayed with offline data. Simple edits can also be made to utility network features while offline and synchronized back to ArcGIS Enterprise.

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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
    // Create an offline map task with the map.
    final offlineMapTask = OfflineMapTask.withOnlineMap(map);
    final offlineMapParameters =
        await offlineMapTask.createDefaultGenerateOfflineMapParameters(
      areaOfInterest: areaOfInterest,
    );

    // Create an offline map job with the download directory path and parameters
    final job = offlineMapTask.generateOfflineMap(
      parameters: offlineMapParameters,
      downloadDirectoryUri: Uri.parse(downloadDirectoryPath),
    );
    final result = job.result;
    if (result == null || result.offlineMap.utilityNetworks.isEmpty) return;
    // Get the utility network from the offline map.
    final utilityNetwork = result.offlineMap.utilityNetworks.first;

The following code takes a utility network offline using a service geodatabase. The utility network tables only get synced when the sync mode in the generate geodatabase parameters is set to sync system tables.

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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
    // Create a geodatabase sync task with the feature service uri.
    final geodatabaseSyncTask = GeodatabaseSyncTask.withUri(featureServiceUri);
    await geodatabaseSyncTask.load();

    // Create generate geodatabase parameters for the selected extents.
    final geodatabaseParameters = await geodatabaseSyncTask
        .createDefaultGenerateGeodatabaseParameters(extent: areaOfInterest);
    geodatabaseParameters
      ..returnAttachments = false
      ..utilityNetworkSyncMode = UtilityNetworkSyncMode.syncSystemTables;

    // Create a generate geodatabase job.
    final geodatabaseJob = geodatabaseSyncTask.generateGeodatabase(
      parameters: geodatabaseParameters,
      pathToGeodatabaseFileUri: Uri.parse(pathToGeodatabaseFile),
    );

    // Start the generateGeodatabase job.
    geodatabaseJob.start();

    final output = geodatabaseJob.result;
    if (output == null || output.utilityNetworks.isEmpty) return;
    final utilityNetwork = output.utilityNetworks.first;
    debugPrint(utilityNetwork.name);

For more information about offline workflows using ArcGIS Maps SDKs for Native Apps, see the Offline maps, scenes, and data topic.

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