欢迎您来到GIS动力

加入收藏 免费注册 用户登陆 帮助中心
首页 新闻动态 技术专栏 银杏树下 学习考研 软件下载 求职招聘 许愿瓶 节日祝福 用户中心 精彩推荐 资源搜索 地图
专栏导航: AO开发 | SO开发 | ArcGIS桌面 | 超图桌面 | 开发语言 | 数据库 | WebGIS | 银杏文学 | 研究生考题 | FreeMap FreeTalk
   您现在位于: 首页技术专栏ArcGIS应用与开发AO开发 → 正文
复制要素类
07-10-23 09:13:02 作者:半块点心 出处:本站原创
本文提供的两个函数功能是依据一个已经存在的要素类(普通几何要素类或标注要素类)和需要保存的个人geodatabase路径,在目标Workspace中产生一个和源要素类相同的新要素类。

'根据传入的PGB路径和文件名产生一个PGD的工作空间,用于存储裁减后的要素类
Function createWS(ByVal FilePath As String, ByVal File As String) As IFeatureWorkspace
    Dim pAccessWorkspaceFactory As IWorkspaceFactory
    Set pAccessWorkspaceFactory = New AccessWorkspaceFactory
    
    Dim pWorkspaceName As IWorkspaceName
    Set pWorkspaceName = pAccessWorkspaceFactory.Create(FilePath, File, Nothing, 0)
    
    Dim pName As IName
    Set pName = pWorkspaceName
    
    Dim pWS As IWorkspace
    Set pWS = pName.Open
    
    Dim pFWS As IFeatureWorkspace
    Set pFWS = pWS
    
    Set createWS = pFWS
End Function

'在传入的工作空间中复制传入的要素类
Public Function CopyFeatureClass(ByVal pInFeatureClass As IFeatureClass, ByVal pSaveFeatWorkSpace As IFeatureWorkspace) As IFeatureClass
    Dim pSaveFeatureClass As IFeatureClass
    
    If pInFeatureClass.FeatureType = esriFTAnnotation Then
        '如果要复制的是Annotation要素类
        Dim pFWSAnno As IFeatureWorkspaceAnno
        Set pFWSAnno = pSaveFeatWorkSpace
        
        Dim pAnnoClass As IAnnoClass
        Set pAnnoClass = pInFeatureClas*.**tension
        
        Dim pGLS As IGraphicsLayerScale
        Set pGLS = New GraphicsLayerScale
        pGLS.ReferenceScale = pAnnoClass.ReferenceScale
        pGLS.Units = pAnnoClass.ReferenceScaleUnits
        
        '复制一个相同的Annotation要素类
        Set pSaveFeatureClass = pFWSAnno.CreateAnnotationClass("Clip_" + pInFeatureClass.AliasName, pInFeatureClass.Fields, pInFeatureClass.CLSID, pInFeatureClas*.**TCLSID, pInFeatureClass.ShapeFieldName, "", Nothing, Nothing, pAnnoClass.AnnoProperties, pGLS, pAnnoClass.SymbolCollection, True)
    Else
        '复制的是普通要素类
        Set pSaveFeatureClass = pSaveFeatWorkSpace.CreateFeatureClass("Clip_" + pInFeatureClass.AliasName, pInFeatureClass.Fields, pInFeatureClass.CLSID, pInFeatureClas*.**TCLSID, pInFeatureClass.FeatureType, pInFeatureClass.ShapeFieldName, "")
    End If
    
    If Not pSaveFeatureClass Is Nothing Then
        Set CopyFeatureClass = pSaveFeatureClass
    End If
End Function

(本文已被浏览 次)
发布人:admin
推荐给好友:发送给好友
上篇新闻:
下篇新闻:
相关评论
发表我的评论
  • 尊重网上道德,遵守《全国人大常委会关于维护互联网安全的决定》及中华人民共和国其他各项有关法律法;
  • 本站有权保留或删除您发表的任何评论内容;
  •   相关文章  

    关于我们友情链接 ┋ 与我在线 ┋ 管理 ┋ TOP
     
    网站当前版本:GisPower CMS V3.0
    『GIS 动力』- http://www.gispower.org/
    联系我们:webmaster#gispower.org
    Copyright (c) 2003-2007 GisPOwer.Org. All Rights Reserved.
     

                   滇ICP备05006901号