How to create a geodatabase network dataset

简介: // Create a new empty data element for a buildable network dataset. IDENetworkDataset deNetworkDataset = new DENetworkDatasetClass(); deNetworkDataset.
// Create a new empty data element for a buildable network dataset.
IDENetworkDataset deNetworkDataset = new DENetworkDatasetClass();
deNetworkDataset.Buildable = true;

// Open the feature dataset and cast to the IGeoDataset interface.
IWorkspaceFactory workspaceFactory = new FileGDBWorkspaceFactory();
IWorkspace workspace = workspaceFactory.OpenFromFile(@
    "C:\Program Files\ArcGIS\DeveloperKit\SamplesNET\data\CreateNetworkDataset\Paris.gdb", 0);
IFeatureWorkspace featureWorkspace = (IFeatureWorkspace)workspace;
IFeatureDataset featureDataset = featureWorkspace.OpenFeatureDataset("RoadNetwork");
IGeoDataset geoDataset = (IGeoDataset)featureDataset;

// Copy the feature dataset's extent and spatial reference to the network dataset data element.
IDEGeoDataset deGeoDataset = (IDEGeoDataset)deNetworkDataset;
deGeoDataset.Extent = geoDataset.Extent;
deGeoDataset.SpatialReference = geoDataset.SpatialReference;

// Specify the name of the network dataset.
IDataElement dataElement = (IDataElement)deNetworkDataset;
dataElement.Name = "ParisNet";

 

 

// Create a new EdgeFeatureSource object and point it to the Streets feature class.
INetworkSource edgeNetworkSource = new EdgeFeatureSourceClass();
edgeNetworkSource.Name = "Streets";
edgeNetworkSource.ElementType = esriNetworkElementType.esriNETEdge;

// Set the edge feature source's connectivity settings.
IEdgeFeatureSource edgeFeatureSource = (IEdgeFeatureSource)edgeNetworkSource;
edgeFeatureSource.UsesSubtypes = true;
edgeFeatureSource.set_SubtypeConnectivityGroup(1, 1);
edgeFeatureSource.set_SubtypeConnectivityPolicy(1,
    esriNetworkEdgeConnectivityPolicy.esriNECPEndVertex);
edgeFeatureSource.set_SubtypeConnectivityGroup(2, 1);
edgeFeatureSource.set_SubtypeConnectivityPolicy(2,
    esriNetworkEdgeConnectivityPolicy.esriNECPEndVertex);
edgeFeatureSource.set_SubtypeConnectivityGroup(3, 1);
edgeFeatureSource.set_SubtypeConnectivityPolicy(3,
    esriNetworkEdgeConnectivityPolicy.esriNECPAnyVertex);

 

// Create a StreetNameFields object and populate its settings.
IStreetNameFields streetNameFields = new StreetNameFieldsClass();
streetNameFields.Priority = 1; // Indicates the primary street name.
streetNameFields.StreetNameFieldName = "FULL_NAME";

// Add the StreetNameFields object to a new NetworkSourceDirections object,
// then add it to the EdgeFeatureSource created earlier.
INetworkSourceDirections nsDirections = new NetworkSourceDirectionsClass();
IArray nsdArray = new ArrayClass();
nsdArray.Add(streetNameFields);
nsDirections.StreetNameFields = nsdArray;
edgeNetworkSource.NetworkSourceDirections = nsDirections;

 

 

 

// Create a new EvaluatedNetworkAttribute object and populate its settings.
IEvaluatedNetworkAttribute minutesAttribute = new EvaluatedNetworkAttributeClass();
INetworkAttribute2 minutesNetworkAttribute2 = (INetworkAttribute2)minutesAttribute;
minutesNetworkAttribute2.Name = "Minutes";
minutesNetworkAttribute2.UsageType = esriNetworkAttributeUsageType.esriNAUTCost;
minutesNetworkAttribute2.DataType = esriNetworkAttributeDataType.esriNADTDouble;
minutesNetworkAttribute2.Units = esriNetworkAttributeUnits.esriNAUMinutes;
minutesNetworkAttribute2.UseByDefault = true;

// Create evaluator objects and set them on the EvaluatedNetworkAttribute object.
INetworkFieldEvaluator ftMinutesNetworkFieldEvaluator = new
    NetworkFieldEvaluatorClass();
INetworkEvaluator ftMinutesNetworkEvaluator = (INetworkEvaluator)
    ftMinutesNetworkFieldEvaluator;
ftMinutesNetworkFieldEvaluator.SetExpression("[FT_Minutes]", "");
minutesAttribute.set_Evaluator(edgeNetworkSource,
    esriNetworkEdgeDirection.esriNEDAlongDigitized, ftMinutesNetworkEvaluator);

INetworkFieldEvaluator tfMinutesNetworkFieldEvaluator = new
    NetworkFieldEvaluatorClass();
INetworkEvaluator tfMinutesNetworkEvaluator = (INetworkEvaluator)
    tfMinutesNetworkFieldEvaluator;
tfMinutesNetworkFieldEvaluator.SetExpression("[TF_Minutes]", "");
minutesAttribute.set_Evaluator(edgeNetworkSource,
    esriNetworkEdgeDirection.esriNEDAgainstDigitized, tfMinutesNetworkEvaluator);

INetworkConstantEvaluator minutesNetworkConstantEvaluator = new
    NetworkConstantEvaluatorClass();
INetworkEvaluator minutesConstantNetworkEvaluator = (INetworkEvaluator)
    minutesNetworkConstantEvaluator;
minutesNetworkConstantEvaluator.ConstantValue = 0;
minutesAttribute.set_DefaultEvaluator(esriNetworkElementType.esriNETEdge,
    minutesConstantNetworkEvaluator);
minutesAttribute.set_DefaultEvaluator(esriNetworkElementType.esriNETJunction,
    minutesConstantNetworkEvaluator);
minutesAttribute.set_DefaultEvaluator(esriNetworkElementType.esriNETTurn,
    minutesConstantNetworkEvaluator);

// Add the attribute to the array.
attributeArray.Add(minutesAttribute);

 

 

 

相关文章
arcgis catalog 连接sde时出现 Target state not found in the STATES table 错误
Target state not found in the STATES table [SDE.DEFAULT][STATE_ID = 8802] 除了arcgis论坛说的这种情况 http://support.esri.com/technical-article/000005952 我自己分析是stateid不在status 表中了 我根据正常的sde库分析了一下,ver
2058 0
|
API
Product Master data model harmonization guiding principle
Product Master data model harmonization guiding principle
131 0
Product Master data model harmonization guiding principle
AVEVA Model Data Exchange Exports Structure Models
AVEVA Model Data Exchange Exports Structure Modelseryar@163.com   Use Model Data Exchange Addin to export structure models for PDMS: Figure 1.
945 0
|
Ruby C++
AVEVA Model Data Exchange ChangeLog
配置方法见程序文档说明或:http://www.cppblog.com/eryar/archive/2013/05/01/199875.html   RvmTranslator2.1  [20150818]----------------1.
1510 0
|
存储 Shell
Open CASCADE Modeling Data – Topology
Open CASCADE Modeling Data – Topology eryar@163.com 一、概述 Overview Open CASCADE拓朴数据结构可以在几何对象不显示的情况下访问或控制对象的数据。
1139 0