矢量图层叠加求交分析
AE开发中,矢量图层叠加分析需要用到的主要类为BasicGeoprocessor,其主要接口为IBasicGeoprocessor。IBasicGeoprocessor接口提供了基本的空间数据处理的方法和属性,其中包括叠加求交(Interset)和叠加求和(Union)。
下面提供两个叠加求交的开发实例:
一、 VB+AE9.1叠加求交示例代码:
1
Private Sub M_OverLayer_Click()
2
' Get the input layer and feature class
3
Dim pLayer As ILayer
4
Set pLayer = MapControl1.Layer(0)
5
Dim pInputFeatLayer As IFeatureLayer
6
Set pInputFeatLayer = pLayer
7
' Use the Itable interface from the Layer (not from the FeatureClass)
8
9
Dim pInputTable As ITable
10
Set pInputTable = pLayer
11
' Get the input feature class.
12
' The Input feature class properties, such as shape type,
13
' will be needed for the output
14
15
Dim pInputFeatClass As IFeatureClass
16
Set pInputFeatClass = pInputFeatLayer.FeatureClass
17
' Get the overlay layer
18
' Use the Itable interface from the Layer (not from the FeatureClass)
19
Set pLayer = MapControl1.Layer(1)
20
Dim pOverlayTable As ITable
21
Set pOverlayTable = pLayer
22
23
' Error checking
24
If pInputTable Is Nothing Then
25
MsgBox "Table QI failed"
26
Exit Sub
27
End If
28
29
If pOverlayTable Is Nothing Then
30
MsgBox "Table QI failed"
31
Exit Sub
32
End If
33
34
' Define the output feature class name and shape type (taken from the
35
' properties of the input feature class)
36
Dim pFeatClassName As IFeatureClassName
37
Set pFeatClassName = New FeatureClassName
38
With pFeatClassName
39
.FeatureType = esriFTSimple
40
.ShapeFieldName = "Shape"
41
.ShapeType = pInputFeatClass.ShapeType
42
End With
43
44
' Set output location and feature class name
45
Dim pNewWSName As IWorkspaceName
46
Set pNewWSName = New WorkspaceName
47
pNewWSName.WorkspaceFactoryProgID = "esriCore.ShapeFileWorkspaceFactory.1"
48
pNewWSName.PathName = "C:\temp"
49
50
Dim pDatasetName As IDatasetName
51
Set pDatasetName = pFeatClassName
52
pDatasetName.Name = "Intersect_result"
53
Set pDatasetName.WorkspaceName = pNewWSName
54
' Set the tolerance. Passing 0.0 causes the default tolerance to be used.
55
' The default tolerance is 1/10,000 of the extent of the data frame's spatial domain
56
57
Dim tol As Double
58
tol = 0# ' Perform the intersect
59
Dim pBGP As IBasicGeoprocessor
60
Set pBGP = New BasicGeoprocessor
61
62
Dim pOutputFeatClass As IFeatureClass
63
Set pOutputFeatClass = pBGP.Intersect(pInputTable, False, pOverlayTable, False, _
64
tol, pFeatClassName)
65
66
' Add the output layer to the map
67
Dim pOutputFeatLayer As IFeatureLayer
68
Set pOutputFeatLayer = New FeatureLayer
69
Set pOutputFeatLayer.FeatureClass = pOutputFeatClass
70
pOutputFeatLayer.Name = pOutputFeatClass.AliasName
71
MapControl1.AddLayer pOutputFeatLayer
72
End Sub
73data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
74data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
75data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
2
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
3
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
4
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
5
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
6
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
7
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
8
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
9
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
10
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
11
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
12
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
13
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
14
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
15
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
16
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
17
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
18
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
19
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
20
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
21
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
22
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
23
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
24
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
25
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
26
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
27
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
28
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
29
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
30
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
31
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
32
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
33
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
34
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
35
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
36
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
37
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
38
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
39
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
40
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
41
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
42
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
43
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
44
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
45
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
46
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
47
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
48
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
49
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
50
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
51
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
52
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
53
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
54
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
55
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
56
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
57
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
58
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
59
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
60
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
61
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
62
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
63
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
64
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
65
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
66
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
67
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
68
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
69
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
70
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
71
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
72
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
73
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
74
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
75
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
二、C#+AE9.1叠加求交示例代码:
1
private void M_OverLayer_Click(object sender, System.EventArgs e)
2
{
3
try
4
{
5
//分析层
6
ILayer pLayer=this.axMapControl1.get_Layer(0);
7
IFeatureLayer pInputFeatLayer=pLayer as IFeatureLayer;
8
ITable pInputTable=pLayer as ITable;
9
IFeatureClass pInputFeatClass=pInputFeatLayer.FeatureClass;
10data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
11
//叠加表
12
pLayer=this.axMapControl1.get_Layer(1);
13
ITable pOverlayTable=pLayer as ITable;
14data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
15
//叠加分析表
16
IFeatureClassName pFeatClassName=new FeatureClassNameClass();
17
pFeatClassName.FeatureType=esriFeatureType.esriFTSimple;
18
pFeatClassName.ShapeFieldName="shape";
19
pFeatClassName.ShapeType=pInputFeatClass.ShapeType;
20data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
21
//工作空间名称
22
IWorkspaceName pNewWSName=new WorkspaceNameClass();
23
pNewWSName.WorkspaceFactoryProgID = "esriDataSourcesFile.ShapefileWorkspaceFactory";
24
pNewWSName.PathName = @"C:\temp";
25data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
26
//数据集名称
27
IDatasetName pDatasetName=pFeatClassName as IDatasetName;
28
pDatasetName.Name="ss";
29
pDatasetName.WorkspaceName=pNewWSName;
30data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
31
//几何处理
32
IBasicGeoprocessor pBGP=new BasicGeoprocessorClass();
33
IFeatureClass pOutputFeatClass=pBGP.Intersect(pInputTable,false,pOverlayTable,false,0.01,pFeatClassName);
34
35
//输出要素层设置
36
IFeatureLayer pOutputFeatLayer=new FeatureLayerClass();
37
pOutputFeatLayer.FeatureClass=pOutputFeatClass;
38
pOutputFeatLayer.Name=pOutputFeatClass.AliasName;
39data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
40
this.axMapControl1.AddLayer((ILayer)pOutputFeatClass,0);
41
axMapControl1.Update();
42
}
43
catch(Exception ex)
44
{
45
MessageBox.Show(ex.Message);
46
}
47
}
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
2
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
3
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
4
data:image/s3,"s3://crabby-images/660db/660dbadd6c9ef03df5698a1947200796a88b70bb" alt=""
5
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
6
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
7
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
8
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
9
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
10
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
11
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
12
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
13
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
14
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
15
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
16
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
17
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
18
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
19
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
20
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
21
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
22
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
23
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
24
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
25
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
26
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
27
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
28
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
29
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
30
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
31
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
32
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
33
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
34
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
35
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
36
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
37
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
38
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
39
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
40
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
41
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
42
data:image/s3,"s3://crabby-images/ca5da/ca5daf2c0fa3128f49e63431e4f051ab3d1e0127" alt=""
43
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
44
data:image/s3,"s3://crabby-images/660db/660dbadd6c9ef03df5698a1947200796a88b70bb" alt=""
45
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
46
data:image/s3,"s3://crabby-images/ca5da/ca5daf2c0fa3128f49e63431e4f051ab3d1e0127" alt=""
47
data:image/s3,"s3://crabby-images/236c7/236c7110a3d28630d6db8780cfd27f09834f6fe9" alt=""