ArcEngine打开数据源(FeatureClass)

1、打开GDB
FileGDBWorkspaceFactory fileGDBWorkspaceFactory = new FileGDBWorkspaceFactory();
IWorkspace workspace = fileGDBWorkspaceFactory.OpenFromFile("GDB路径", 0);
IFeatureWorkspace featureWorkspace = workspace as IFeatureWorkspace;
IFeatureClass featureClass = featureWorkspace.OpenFeatureClass("GDB中要素类名字");

 /// <summary>
        /// 获取GDB MDB工作空间的要素类
        /// </summary>
        /// <param name="workspace"></param>
        /// <param name="workspaceType"></param>
        /// <returns></returns>
        public List<string> GetFeatureClassByWorkspace(IWorkspace workspace)
        {
            List<string> listFeaClass = new List<string>();
            try
            {
                //遍历工作空间下的featureclass
                IFeatureWorkspace pFeatureWorkspace = workspace as IFeatureWorkspace;
                IEnumDataset pEnumDatasets = workspace.get_Datasets(esriDatasetType.esriDTAny) as IEnumDataset;
                IDataset pDataset = pEnumDatasets.Next();
                while (pDataset != null)
                {
                    if (pDataset.Type == esriDatasetType.esriDTFeatureClass)
                    {
                        //string aliasName = pFeatureWorkspace.OpenFeatureClass(pDataset.Name).AliasName;
                        listFeaClass.Add(pDataset.Name);
                    }
                    else if (pDataset.Type == esriDatasetType.esriDTFeatureDataset)
                    {
                        IEnumDataset pESubDataset = pDataset.Subsets;
                        IDataset pSubDataset = pESubDataset.Next();
                        while (pSubDataset != null)
                        {
                            listFeaClass.Add(pSubDataset.Name);

                            pSubDataset = pESubDataset.Next();
                        }
                    }

                    pDataset = pEnumDatasets.Next();
                }
            }
            catch (Exception ex)
            {
                return null;
            }

            return listFeaClass;
        }

 


2、打开mdb
AccessWorkspaceFactory accessWorkspaceFactory = new AccessWorkspaceFactoryClass();
IFeatureWorkspace featureWorkspace = (IFeatureWorkspace)accessWorkspaceFactory.OpenFromFile("MDB路径", 0);
IFeatureClass featureClass = featureWorkspace.OpenFeatureClass("MDB中要素类名字");

3、打开shapefile
IWorkspaceFactory workspaceFactory = new ShapefileWorkspaceFactoryClass();
IWorkspace workspace = workspaceFactory.OpenFromFile("shp路径", 0);
IFeatureWorkspace featureWorkspace = workspace as IFeatureWorkspace;
IFeatureClass featureClass = featureWorkspace.OpenFeatureClass("shp名字");

 

4打开raster 影像

            string rasterPath = System.IO.Path.GetDirectoryName(rasterFulPath);
            string rasterFileName = System.IO.Path.GetFileName(rasterFulPath);
            IWorkspaceFactory rasterWorkspaceFactory = new RasterWorkspaceFactoryClass();
            IRasterWorkspace rasterWorkspace = (IRasterWorkspace)rasterWorkspaceFactory.OpenFromFile(rasterPath, 0);
            IRasterDataset rasterDataset = rasterWorkspace.OpenRasterDataset(rasterFileName);
            IRasterLayer rasterLayer = new RasterLayerClass();
            rasterLayer.CreateFromDataset(rasterDataset);

//影像去黑边


            IRasterRGBRenderer2 rasterRGBRen = new RasterRGBRendererClass();
            IRasterStretchColorRampRenderer pRasterStretchRenderer = new RasterStretchColorRampRendererClass();

            if (rasterLayer.Renderer is IRasterRGBRenderer2)
            {
                IRasterRenderer pRasterRendererRGB = (IRasterRenderer)rasterRGBRen;
                IRasterStretch2 rasterStretchType = (IRasterStretch2)rasterRGBRen;

                rasterStretchType.Background = true;
                rasterStretchType.BackgroundValue = 0;
                pRasterRendererRGB = (IRasterRenderer)rasterRGBRen;
                pRasterRendererRGB.Update();
                IRasterProps pRstProps = rasterLayer.Raster as IRasterProps;
                pRstProps.NoDataValue = 0;
                rasterLayer.Renderer = pRasterRendererRGB;
            }
            else if (rasterLayer.Renderer is IRasterStretchColorRampRenderer)
            {
                IRasterRenderer pRasterRendererStretch = (IRasterRenderer)pRasterStretchRenderer;
                IRasterStretch2 rasterStretchType = (IRasterStretch2)pRasterStretchRenderer;

                rasterStretchType.Background = true;
                rasterStretchType.BackgroundValue = 0;
                pRasterRendererStretch = (IRasterRenderer)pRasterStretchRenderer;
                pRasterRendererStretch.Update();
                IRasterProps pRstProps = rasterLayer.Raster as IRasterProps;
                pRstProps.NoDataValue = 0;
                rasterLayer.Renderer = pRasterRendererStretch;
            }

 


注:对workspace验证是否存在
if (fileGDBWorkspaceFactory.IsWorkspace(GDBPath) == false)
            {
                msg = "GDB文件不正确,不能打开!";
                return msg;
            }

 

转自:http://blog.csdn.net/hellolib/article/details/7861806

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ArcEngine 是一个用于开发和部署空间分析应用程序的软件开发工具包。FeatureClassArcEngine 中用于存储和管理地理要素的数据结构。叠加分析是一种空间分析方法,用于确定两个或多个地理要素之间的相互关系。 在使用 ArcEngine 进行 FeatureClass 的叠加分析时,首先需要加载要处理的地理数据,包括待叠加的 FeatureClass 和用于叠加的参考数据。然后,通过使用空间查询语言(Spatial Query Language)或 ArcEngine 提供的空间查询函数,可以根据不同的空间关系(如相交、包含、接触等)筛选出符合条件的地理要素。 然后可以根据需要进行叠加操作,常见的叠加操作包括求交、求并、求异等。可以利用 ArcEngine 提供的叠加函数,或者通过自定义算法实现叠加操作。在进行叠加操作时,需要注意数据的投影、坐标系统等因素,确保数据的一致性。 叠加分析的结果可以生成新的 FeatureClass,其中包含了叠加后的地理要素。可以根据需求,对新生成的 FeatureClass 进行后续的分析、可视化、导出等操作。 总结来说,ArcEngine 提供了丰富的工具和函数,可以通过 FeatureClass 进行叠加分析。通过加载待处理的地理数据,使用空间查询语言或空间查询函数筛选出符合条件的地理要素,然后进行叠加操作,最终生成新的 FeatureClass。这样可以方便地进行空间关系分析、数据集成等操作,帮助用户更好地理解和利用地理数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值