Author and publish a geoprocessing model
This tutorial will guide you through the process of authoring a geoprocessing model using Model Builder in ArcMap, and publishing this model as a geoprocessing package (.gpk) to be consumed in an ArcGIS Runtime for WPF application.
Copy SDK sample data packages
Complete the following steps to locate and copy the SFNetwork.mpk map package to a directory created for this exercise. You'll use the SFNetwork.mpk sample data that's included when you install the ArcGIS Runtime SDK for WPF.
- Create a new folder named RoutingExercise in a location of your choice.
- Locate the SFNetwork.mpk sample data installed with the ArcGIS Runtime SDK for WPF.
- Copy the SFNetwork.mpk map package from the sample data folder into your RoutingExercise folder.
- Double-click the SFNetwork.mpk package in the RoutingExercise folder to start ArcMap and unpack the map package's files into your Documents library.
Become familiar with the map document and the data it contains.
Create a geoprocessing model
In the following steps, you'll create a geoprocessing model in a new toolbox. You'll add commercial tools to your model, such as the Make Route Layer and Add Locations tools from the Network Analyst Tools toolbox, and configure the model's parameters to use data types supported by ArcGIS Runtime.
- In the ArcMap Catalog window, right-click the RoutingExercise folder and click New > Toolbox to create a toolbox named RoutingTools.
- Right-click the RoutingTools toolbox, and click New > Model to create a model.
- From the ArcMap main menu, select Windows > Search to open the ArcMap Search window.
- Search Tools for the Network Analyst Make Route Layer tool.
- Drag the tool from the search results window to the ModelBuilder window to add an instance of the tool to your model.
- Double-click the Make Route Layer tool in the ModelBuilder window to open the tool’s dialog box and review its parameters.
- Click the drop-down arrow to the right of the Input Analysis Network field and select your map's Streets_ND network dataset layer.
- Click OK to accept the default values for the remaining fields and close the Make Route Layer dialog box.
- In the ArcMap Search window, search Tools for the Network Analyst Add Locations tool.
- Add an instance of the tool to your model by dragging the tool from the search results window to the ModelBuilder window.
- Use the ModelBuilder Connect tool to connect the Make Route Layer tool’s output to the Add Locations tool.
- Connect the output as the input parameter Input Network Analysis Layer.
The model should be open for editing in ModelBuilder. To add tools to your model, continue with the following steps:
Modify the model's parameters
For your model to work with applications developed with the ArcGIS Runtime SDK for WPF, feature class inputs need to be provided as Feature Set data type parameters. Complete the following steps to designate the Add Locations tool’s Input Locations as a model parameter of the required data type:
- In the ArcMap Catalog window, create a file geodatabase named FC_Templates in your RoutingExercise folder.
- Create a point feature class named RoutePtTemplate in the geodatabase.
- Select Point Features as the geometry type and WGS 1984 as the geographic coordinate system.
- Accept the default XY Tolerance, Configuration Keyword, and attribute fields.
- Click Finish to create the feature class.
- In the open ModelBuilder window, right-click the Add Locations tool and select Make Variable > From Parameter > Input Locations.
- Click the Auto Layout button then the Full Extent button to arrange the model elements in the ModelBuilder window.
- Right-click the Input Locations variable and click Model Parameter on the displayed context menu.
- Right-click the Input Locations variable and click Properties.
- Click the Data Type tab. The currently specified data type is Table View .
- Using the Data Type field’s pull-down menu, change the data type to Feature Set .
A bold letter "P" appears next to the variable indicating that it's now a model parameter.
Configuring your model to use Feature Set inputs is required to support ArcGIS Runtime development. Feature Sets are in-memory feature classes compatible with the runtime’s GPFeatureRecordSetLayer data type.
Define feature set schema and symbology
The attribute schema and spatial reference for a feature set is imported from a template feature class. No particular attribute schema is required for this exercise, so a basic point feature class using the WGS 1984 geographic coordinate system will suffice. Follow these steps to complete the Input Locations Feature Set input's configuration:
- On the open Input Locations Properties dialog box, click the browse button to the right of the Import schema and symbology from field.
- Browse to the RoutePtTemplate feature class you created in the FC_Templates geodatabase.
- Click OK to apply the changes to the Input Locations model variable and close the Properties dialog box.
- If you have not already done so, save your model by clicking Model > Save.
All of the nodes in your model are now colored indicating that the model is ready to run.
Your feature set's label Input Locations will be used as the input parameter name when an ArcGIS Runtime geoprocessing task is created to consume your model. It is recommended that the names you assign your model variables be descriptive but simple enough for application developers to program against.
Complete the geoprocessing model
The geoprocessing model is nearly complete. Complete the following steps to add the Solve and Select Data tools and configure your model’s output parameter:
- If your model is not already open for editing in ModelBuilder, right-click the model in the ArcMap Catalog window and click Edit.
- In the ArcMap Search window, search Tools for the Network Analyst Solve tool.
- Add an instance of the tool to your model by dragging the tool from the search results window to the ModelBuilder window.
- Use the Model Builder Connect tool to connect the Add Locations tool’s output to the Solve tool. Connect the output as the input parameter Input Network Analysis Layer .
- Rename the Solve tool's output to Network Analyst Layer.
- Use the ArcMap Search window to search Tools for the ModelBuilder Select Data tool.
- Add an instance of the tool to your model by dragging the tool from the search results window to the ModelBuilder window.
- Connect the Network Analyst Layer output as the Select Data tool’s Input Data Element input parameter.
- Double-click the Select Data tool in the ModelBuilder window to open the tool’s dialog box and review its parameters.
- Click the drop-down arrow to the right of the Child Data Element field to change the selected value from Stops to Routes. (The Select Data tool allows you to pull a result out of a group result. In this case, the input layer contains the route, barriers, and stops. You'll only use the resulting routes in this exercise.)
- Click OK to close the Select Data tool’s parameter window.
- Right-click the Select Data tool’s Routes output and make the output a model parameter.
- Click the Auto Layout > Full Extent buttons to arrange the model elements in the ModelBuilder window.
- From the ModelBuilder main menu, click Model > Model Properties.
- Change the Name and Label properties of your model from Model to Route.
- On the Properties dialog box, click the Parameters tab and review your model’s parameters.
- Click OK to close the Properties dialog box.
- Click Model > Save to save the changes you made to your model.
- Close the ModelBuilder window.
Your model has only one required input parameter and one derived output parameter. If your model accepted multiple inputs, this is where you see all he parameters, change the order in which scripts and applications are expected to supply their inputs to your model, and verify each parameter’s data type.
Execute the model and check the results
To run your model from within ArcMap, complete the following steps. The result can be shared as a geoprocessing package.
- Zoom to an extent at which you can easily select a point on one of the streets from the Streets_ND network dataset.
- In the ArcMap Catalog window, double-click the model to open its interface panel.
- Zoom in if detail from the Streets, Signposts, or RestrictedTurns layers are not displayed; by default, these layers do not display when zoomed-out beyond a certain map scale.
- Click any two locations on the map display being careful to select points that intersect streets from one of the layers in the network dataset.
- Once you've sketched two points, click OK on the Route tool's interface to run the geoprocessing model.
- Open the ArcMap Results window (Geoprocessing > Results).
- Expand the most recent geoprocessing result for the Current Session.
- Select and drag the Routes: Routes result to the map display.
The user interface generated by ArcMap indicates that the model is expecting point features as input. Notice that an in-memory feature class, Route::Input_Locations, has been temporarily added to your Table of Contents as a new layer. Also, a point feature appears to follow your mouse cursor as you pan across the map. ArcMap is waiting for you to sketch point features as input for the tool.
If you previously disabled background geoprocessing (Geoprocessing > Geoprocessing Options), a modal dialog box will display providing status on the running job. Close this dialog box once the geoprocessing has completed successfully; otherwise, the model will be executed as a background process.
If you previously selected to have geoprocessing results added to the display (Geoprocessing > Geoprocessing Options), a new feature layer named Route will be added to your map display, and you'll see a route that follows the street network connecting the first point you selected (the route start point) to the second selected point (the route end point).
If the route is not displayed on your map, you can add it to the map display by dragging the geoprocessing output to the map display from the ArcMap Results window.
Create a geoprocessing package
Once you've verified that your model executes and produces valid results, you can package the model for distribution. Complete the following steps to have ArcMap complete an analysis of your geoprocessing result. This must be done before the result can be published as a geoprocessing package.
- From the ArcMap main menu, click Customize > Arcmap Options.
- Click the Sharing tab and make sure that the Enable ArcGIS Runtime Tools option is checked.
- Click Geoprocessing > Results to open the ArcMap Results window.
- Expand the most recent geoprocessing result for the Current Session.
- Right-click the result and select Share As > Geoprocessing Package from the displayed context menu.
- On the Geoprocessing Package dialog box, select the radio button next to Save package to file and browse to your RoutingExercise folder. Name the output package Route.gpk.
- On the Geoprocessing Package dialog, make sure that the Support ArcGIS Runtime option is checked.
- Click the Analyze button on the Geoprocessing Package dialog box.
ArcMap analyzes the geoprocessing result and displays any warnings or errors in a dockable window.
Correct errors and create the geoprocessing package
Complete the following steps to correct any errors. You can ignore warnings from an analysis in ArcMap, but errors must be addressed before you can create the geoprocessing package.
- In the Prepare window, right-click the The Route/Input_Locations parameter is missing a syntax dialog explanation error, and select Update Tool Metadata from the displayed context menu.
- On the Item Description dialog box, click the Edit button.
- Scroll down to the Syntax field with its input parameter and drop-down arrow.
- Click the arrow next to the Input_Locations parameter to reveal its text entry field.
- Type the following text in the Input_Locations parameter's Dialog Explanation field:
- Save your edit and close the Item Description dialog box.
- On the ArcMap Geoprocessing Package dialog box, click the Analyze button to re-analyze the result you are attempting to package. Repeat the previous steps (right-clicking any warnings or errors, working to address the warning or error condition, and then rerunning the analyzer).
Type the following text in the Summary (Required) and Tags (Required) fields:
Summary (Required):
Geoprocessing package containing a model which uses commercial Network Analyst tools to complete a point-to-point analysis.
Tags (Required):
point-to-point, routing, San Francisco
- Once you've addressed all the errors discovered by the analyzer and reviewed the potential impact of ignoring any of the analyzer's warnings, click the Share button to create the geoprocessing package.
Model requires at least two input point features which intersect street network features in order to determine a route between the sketched route points.
ArcMap displays a Package dialog box that reports the approximate size of the package being built. This may take several minutes to complete.
You've developed a geoprocessing model within ModelBuilder, run the model within ArcMap, and published the results as a geoprocessing package. Your geoprocessing package, Route.gpk, uses Feature Set inputs, so it can be used to support applications developed using the ArcGIS Runtime SDK for WPF.