欢迎您来到GIS动力

加入收藏 免费注册 用户登陆 帮助中心
首页 新闻动态 技术专栏 银杏树下 学习考研 软件下载 求职招聘 许愿瓶 节日祝福 用户中心 精彩推荐 资源搜索 地图
专栏导航: AO开发 | SO开发 | ArcGIS桌面 | 超图桌面 | 开发语言 | 数据库 | WebGIS | 银杏文学 | 研究生考题 | FreeMap FreeTalk
   您现在位于: 首页技术专栏ArcGIS应用与开发AO开发 → 正文
使用GxDialog载入一个要素类或要素数据集
07-10-24 16:51:52 作者:半块点心 出处:本站原创
Public Function openDataSet(ByVal pMap As IMap) As Boolean
    'On Error GoTo errH
    Dim pGxDialog As IGxDialog
    Set pGxDialog = New GxDialog
    pGxDialog.AllowMultiSelect = True
    pGxDialog.Title = "选择要素数据集"
    pGxDialog.ButtonCaption = "添加"
    
    Dim pGxFilter As IGxObjectFilter
    Set pGxFilter = New GxFilterFeatureDatasetsAndFeatureClasses
    Set pGxDialog.ObjectFilter = pGxFilter
    
    Dim pGxObjects As IEnumGxObject
    pGxDialog.DoModalOpen 0, pGxObjects
    
    If pGxObjects Is Nothing Then
        MsgBox "没有添加数据"
        Exit Function
    End If
    pGxObjects.Reset

    Dim pFeatLyr As IFeatureLayer
    Dim pGxDataset As IGxDataset
    Set pGxDataset = pGxObjects.Next
    
    Do Until pGxDataset Is Nothing
        If TypeOf pGxDataset.Dataset Is IFeatureClass Then
            Dim pFC As IFeatureClass
            Set pFC = pGxDataset.Dataset
            
            If pFC.FeatureType = esriFTAnnotation Then
                Set pFeatLyr = New FDOGraphicsLayer
            Else
               Set pFeatLyr = New FeatureLayer
            End If
            
            Set pFeatLyr.FeatureClass = pGxDataset.Dataset
            pFeatLyr.Name = pFeatLyr.FeatureClass.AliasName
            
            pMap.AddLayer pFeatLyr
        ElseIf TypeOf pGxDataset.Dataset Is IFeatureDataset Then
            Dim pEnumDataset As IEnumDataset
            Set pEnumDataset = pGxDataset.Dataset.Subsets
            pEnumDataset.Reset

            Dim pDataSet As IDataset
            Set pDataSet = pEnumDataset.Next
            Do While Not pDataSet Is Nothing
                Set pFC = pDataSet
                '如果载入的要素类为标注要素类,则产生特殊图层
                If pFC.FeatureType = esriFTAnnotation Then
                    Set pFeatLyr = New FDOGraphicsLayer
                Else
                    Set pFeatLyr = New FeatureLayer
                End If
                
                Set pFeatLyr.FeatureClass = pFC
                pFeatLyr.Name = pFC.AliasName
                
                Debug.Print pFeatLyr.Name
                pMap.AddLayer pFeatLyr
                
                Set pFeatLyr = Nothing
                Set pDataSet = pEnumDataset.Next
            Loop
        End If

        Set pGxDataset = pGxObjects.Next
    Loop
    
    openDataSet = True
errh:
    'openDataSet = False
    'MsgBox "打开图层发生错误,错误原因:" & vbCrLf & Err.Description
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号