Programmatically change the data source of a layer in ArcMap
The sample code provided is to programmatically change a layer's data source in ArcMap.
 Public Sub ChangeDataSource()
Public Sub ChangeDataSource() Dim pmxdoc As IMxDocument
Dim pmxdoc As IMxDocument Set pmxdoc = ThisDocument
Set pmxdoc = ThisDocument 
     Dim pmap As IMap
Dim pmap As IMap Set pmap = pmxdoc.ActiveView
Set pmap = pmxdoc.ActiveView 
     Dim pfeatlayer As IFeatureLayer
Dim pfeatlayer As IFeatureLayer Set pfeatlayer = pmap.Layer(0)
Set pfeatlayer = pmap.Layer(0) 
     Dim pdatalayer As IDataLayer
Dim pdatalayer As IDataLayer Set pdatalayer = pfeatlayer
Set pdatalayer = pfeatlayer 
     Dim pname As IName
Dim pname As IName Dim strTable As String
Dim strTable As String Dim strLocation As String
Dim strLocation As String 
     ' Set the path to the directory containing the shapefile.
' Set the path to the directory containing the shapefile. strLocation = "C:\testing\canada"
strLocation = "C:\testing\canada" 
     ' Set the shapefile name to be used as the data source.
' Set the shapefile name to be used as the data source. strTable = "provinces"
strTable = "provinces" 
     Dim pdatasetname As IDatasetName
Dim pdatasetname As IDatasetName Dim ptable As ITable
Dim ptable As ITable Dim pwrkspc As IWorkspaceName
Dim pwrkspc As IWorkspaceName
 Set pwrkspc = New WorkspaceName
Set pwrkspc = New WorkspaceName pwrkspc.PathName = strLocation
pwrkspc.PathName = strLocation 
     ' If a data source other than a shapefile is used,
' If a data source other than a shapefile is used, ' the workspace type will need to be changed.
' the workspace type will need to be changed. pwrkspc.WorkspaceFactoryProgID = "esricore.shapefileworkspacefactory.1"
pwrkspc.WorkspaceFactoryProgID = "esricore.shapefileworkspacefactory.1"
 Set pdatasetname = New TableName
Set pdatasetname = New TableName pdatasetname.Name = strTable
pdatasetname.Name = strTable Set pdatasetname.WorkspaceName = pwrkspc
Set pdatasetname.WorkspaceName = pwrkspc Set pname = pdatasetname
Set pname = pdatasetname Set ptable = pname.Open
Set ptable = pname.Open 
     Dim pgeodataset As IGeoDataset
Dim pgeodataset As IGeoDataset Set pgeodataset = ptable
Set pgeodataset = ptable Set m_penv = pgeodataset.Extent
Set m_penv = pgeodataset.Extent 
     Dim pfcname As IDatasetName
Dim pfcname As IDatasetName Set pfcname = pname
Set pfcname = pname pdatalayer.DataSourceName = pname
pdatalayer.DataSourceName = pname 
     Dim pav As IActiveView
Dim pav As IActiveView Set pav = pmap
Set pav = pmap 
     pav.Extent = m_penv
pav.Extent = m_penv Set pav = pmap
Set pav = pmap pav.Refresh
pav.Refresh
 End Sub
End Sub----------------------------------------------------------- 
佛对我说:你心里有尘。我用力的拭擦。
 
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号