ArcEngine入门笔记1

这篇博客记录了在使用ArcGIS10.1和VS2010进行ArcEngine开发时遇到的两个主要问题及其解决办法。第一个问题是关于ArcGIS版本未指定的错误,解决方法是在程序启动时绑定RuntimeManager。第二个问题是创建QueryFilter时的异常,通过修改引用的嵌入互操作类型属性得以解决。此外,还分享了一段关于在不同数据源类型(Shapefile和GDB)上进行查询时的注意事项,包括字段名格式和模糊查询的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ArcGis10.1+VS 2010


1、错误:1)ArcGIS version not specified. You must call RuntimeManager.Bind before creating any ArcGIS components

2)在调用ARCGIS的组件或者功能时报如下错误:
“检索 COM 类工厂中 CLSID 为 {5374EC4C-1AA2-4829-A811-DE624ECEC23F} 的组件失败,原因是出现以 下错误: 80040111 ClassFactory 无法供应请求的类在调用ARCGIS的组件或者功能时报如下错误:

解决:添加引用Esri.ArcGIS.Version,在program.cs中的main()函数中的Application.Run(new Form1());语句前 添加ESRI.ArcGIS.RuntimeManager.Bind(ESRI.ArcGIS.ProductCode.EngineOrDesktop);


2、错误:pQueryFilter = new QueryFilterClass();虽然已经引用了using ESRI.ArcGIS.Geodatabase;但报错

解决:在引用ESRI.ArcGIS.Geodatabase的属性embed interop types改为false。


3、以下为转载网上的:

未处理 System.Runtime.InteropServices.COMException
Message="每用户订阅上的所有人 SID 不存在 (异常来自 HRESULT:0x80040207)"
Source="ESRI.ArcGIS.Geodatabase"
ErrorCode=-2147220985

        貌似是升级到v9.3才有的错误,检查发现是QueryFilter.WhereClause语句在查询shapefile格式的图层出现了问题,试验在查询gdb格式的图层不会报错。打开ArcGIS比较了两种格式的属性查询存在以下的区别:

        1.shapefile的字段名用双引号如:"fieldName"而GDB的采用[fieldName]格式;

        2.shapefile的模糊查询用like '%A%' 而GDB用like '*A*' ;

       3.shapefile的非字符字段不支持模糊查询而GDB格式的支持;不过我记得9.2的时候好像支持^_^。

        所以在查询前必须判断一下图层的数据源类型:

            if (pDateset.Workspace.Type == esriWorkspaceType.esriFileSystemWorkspace)
            {
                    pQueryFilter.WhereClause = "\"" + fldName + "\"" + " like '%" + this.txt_findObject.Text.Trim() + "%'";//shpfile
             }
            else
            {
                    pQueryFilter.WhereClause = "[" + fldName + "]" + " like '*" + this.txt_findObject.Text.Trim() + "*'"; //gdb
            }


            


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值