ArcGIS Engine

ArcGIS Engine

开发地理信息数据管理系统,目前(2019年)最新的技术路线是什么?

ArcGIS Engineblue 回复了问题 • 4 人关注 • 3 个回复 • 321 次浏览 • 2019-05-24 09:54 • 来自相关话题

之前做了一套数据库管理系统,是用ArcGIS Engine10.1+Oracle 11g做的,目前来看有点落后了,想升级一下。
包含 数据导入导出、更新、发布服务、空间查询等。数据库版本选用oracle12c。
之前是用ArcObjects SDK开发,现在还有别的技术路线吗?
ArcGIS Runtime本身的数据处理功能较弱,那配合一些服务(例如Local Server)呢?

ArcGIS 10.5有Engine吗

ArcGIS Engineblue 回复了问题 • 4 人关注 • 3 个回复 • 583 次浏览 • 2019-05-23 16:29 • 来自相关话题

10.5还有没有单独的Engine和AO了?

对 COM 组件的调用返回了错误 HRESULT E_FAIL

ArcGIS EngineV仔 回复了问题 • 5 人关注 • 6 个回复 • 2349 次浏览 • 2019-05-23 15:17 • 来自相关话题

在winform程序中 运行统计功能的时候显示“对 COM 组件的调用返回了错误 HRESULT E_FAIL”,然后点击关闭这个错误后,程序依然能运行 这个报错是什么原因呢?

如何在C#中调用引用了arcpy的python脚本?

kongfankongfan 回复了问题 • 2 人关注 • 2 个回复 • 1793 次浏览 • 2019-05-22 08:47 • 来自相关话题

自定义python脚本,脚本中调用了arcpy,如何在C#中调用该脚本?

Shapefile 图层导入到Oracle空间库时,如何判断字段名称是否合法?

ArcGIS Engine菠萝仔 回复了问题 • 2 人关注 • 2 个回复 • 106 次浏览 • 2019-04-19 17:00 • 来自相关话题

Shapefile 图层导入到Oracle空间库时发生错误:对象名不是基础 DBMS 的常规识别符 [ORA-00942: 表或视图不存在] ;检查发现shapefile图层有一个字段名称包含了括号特殊字符,导致了创建sde图层失败;
现在有个疑问就是在创建图层前已经通过
IFieldChecker检查字段名称是否合法,为什么字段名称包含括号的问题检查不出来?检查的函数如下:
$(document

arcengine开发目标平台只能是X86吗?

ArcGIS EngineV仔 回复了问题 • 3 人关注 • 2 个回复 • 565 次浏览 • 2019-04-16 16:26 • 来自相关话题

如何在X64的目标平台下开发arcengine,因为系统其他部分要用64位的开发。求大神解决!

ArcgisEngine中利用IFeatureDataConverter.ConvertFeatureDataset()复制FeatrueDataset报错

ArcGIS Engine公子小白666 回复了问题 • 3 人关注 • 2 个回复 • 800 次浏览 • 2019-04-10 11:41 • 来自相关话题

//获取SDE工作空间public IWorkspace FindWsByDefault()
        {
            IPropertySet propSet = new PropertySetClass();
            propSet.SetProperty("Server", "zhaofei-PC");
   

ae(ArcEngine) java swing开发入门系列(1):开发环境和代码部署

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 236 次浏览 • 2019-02-13 11:32 • 来自相关话题

前言:做ae开发大部分人都是用C#版,很少用到java版,本系列文章主要介绍java版ae开发的入门,对于ae接口的高级应用,可以看C#版相关文章

 

开发环境软件:

Intellij IDEA 2018

java jdk 1.8 32位版

arcgis desktop 10.4.1

ArcObject sdk java 10.4.1

 

PS:本文

ae(ArcEngine) java swing开发入门系列(2):ae的类型转换和Proxy类说明

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 133 次浏览 • 2019-02-10 15:29 • 来自相关话题

做过C#版ae的都知道,操作同一个“对象”,用他的不同功能要转换到相应的接口,但java版有时不能直接做类型转换

例如下图在C#是可以的

 






但在java不行,这样转会报错,看IFeatureClass的定义,可以看到根本没继承IDataset

 






在java的转换方法是利用对应的Proxy类

 






PS:ja

你好,请问我想用 table.UpdateSearchedRows(queryFilter, rowBuffer)更新属性

ArcGIS Engine溪伊君 回复了问题 • 3 人关注 • 3 个回复 • 363 次浏览 • 2019-01-09 15:13 • 来自相关话题

用这个方法更新完之后,某一字段确实按照我设置的条件进行了更新,但是,原来字段的已有信息都变成了0.。。。请问如何解决这个问题。。谢谢您

AE位置查询时,在遍历图层数量加载时,报“未将对象引用设置到对象的实例。”的错,可以看一下图片

ArcGIS EngineMENTHA 回复了问题 • 3 人关注 • 2 个回复 • 960 次浏览 • 2018-12-17 18:53 • 来自相关话题

  private void FrmSpatialQuery_Load(object sender, EventArgs e)
        {
            ILayer pLayer = null;
            //添加图层到ckListBoxLayer
            for (int i = 0;i<frmMap.axMapControl1.L

Engine中,对于这样个一个多部件的Polyline,我如何得到其内所有的闭合区域。就像ArcGIS工具箱的要素转面工具那样

ArcGIS Engine朱新颖 回复了问题 • 2 人关注 • 1 个回复 • 194 次浏览 • 2018-12-05 11:56 • 来自相关话题

 
条新动态, 点击查看
刘峥

刘峥 回答了问题 • 2015-04-17 16:41 • 2 个回复 不感兴趣

Engine中如何渲染LiDAR数据(.las)?

赞同来自:

【解决办法】:
按属性(强度Intensity)渲染参考代码:
 
string lasdfile = @E:testlas.lasd;
ILasDataset lasdataset = new LasDatasetClass();
lasdataset.I... 显示全部 »
【解决办法】:
按属性(强度Intensity)渲染参考代码:
 
string lasdfile = @E:testlas.lasd;
ILasDataset lasdataset = new LasDatasetClass();
lasdataset.Init(lasdfile);
ILasFile lasfile = lasdataset.get_File(0);
ILasDatasetLayer laslayer = new LasDatasetLayerClass();
laslayer.Dataset = lasdataset;
laslayer.Name = test.las;
ILasStatistics lasstat = lasfile.GetStatistics();

ISimpleStatistics simstat = lasstat.GetAttributeStatistics(esriLasAttributeType.esriLasIntensity);
int min = (Int32)simstat.Minimum;
int max = (Int32)simstat.Maximum;

IRgbColor fromColor = new RgbColorClass();
fromColor.Red = 0;
fromColor.Green = 0;
fromColor.Blue = 0;
IColor toColor = new RgbColorClass();
fromColor.Red = 255;
fromColor.Green = 255;
fromColor.Blue = 255;

IAlgorithmicColorRamp colorRamp = new AlgorithmicColorRampClass();
colorRamp.Size = max;
colorRamp.FromColor = fromColor;
colorRamp.ToColor = toColor;
bool createColorRamp;
colorRamp.CreateRamp(out createColorRamp);

IEnumColors pEnumColors = colorRamp.Colors;
pEnumColors.Reset();

ILasAttributeRenderer lasattri = new LasUniqueValueRendererClass();
lasattri.Attribute = esriLasAttributeType.esriLasIntensity;

ITinUniqueValueRenderer tinuvren = lasattri as ITinUniqueValueRenderer;
for (int i = 0; i < max; i++)
{
IColor SymColor = pEnumColors.Next();
IMarkerSymbol MarkSym = new SimpleMarkerSymbolClass();
MarkSym.Color = SymColor;
tinuvren.AddValue(i.ToString(), i.ToString(), MarkSym as ISymbol);
tinuvren.AddValue(i.ToString(), i.ToString(), MarkSym as ISymbol);
}

laslayer.ClearRenderers();
laslayer.AddRenderer((ITinRenderer)lasattri);

ILegendInfo LegenInfo = laslayer as ILegendInfo;
for (int k = 0; k < LegenInfo.LegendGroupCount; k++)
{
ILegendGroup legenGrp = LegenInfo.get_LegendGroup(k);
legenGrp.Heading = ;
legenGrp.Visible = false;
ILegendClass legenCls = legenGrp.get_Class(0);
}

axSceneControl1.Scene.AddLayer(laslayer, false);
axSceneControl1.SceneGraph.RefreshViewers();

按高程LAS point elevation渲染参考代码:
 
string lasdfile = @E:testlas.lasd;
ILasDataset lasdataset = new LasDatasetClass();
lasdataset.Init(lasdfile);
ILasFile lasfile = lasdataset.get_File(0);
ILasDatasetLayer laslayer = new LasDatasetLayerClass();
laslayer.Dataset = lasdataset;
laslayer.Name = test.las;

IRgbColor fromColor = new RgbColorClass();
fromColor.Red = 0;
fromColor.Green = 0;
fromColor.Blue = 0;
IColor toColor = new RgbColorClass();
fromColor.Red = 255;
fromColor.Green = 255;
fromColor.Blue = 255;

int BreakCount = 9;
IAlgorithmicColorRamp colorRamp = new AlgorithmicColorRampClass();
colorRamp.Size = BreakCount;
colorRamp.FromColor = toColor;
colorRamp.ToColor = fromColor;
bool createColorRamp;
colorRamp.CreateRamp(out createColorRamp);

IEnumColors pEnumColors = colorRamp.Colors;
pEnumColors.Reset();

ITinColorRampRenderer TinColRamRend = new LasPointElevationRendererClass();
IDatasetRenderer DatasetRen = TinColRamRend as IDatasetRenderer;
DatasetRen.Dataset = lasdataset as IDataset;
TinColRamRend.BreakCount = BreakCount;
for (int i = 0; i < BreakCount; i++)
{
IColor SymColor = pEnumColors.Next();
IMarkerSymbol MarkSym = new SimpleMarkerSymbolClass();
MarkSym.Color = SymColor;
TinColRamRend.set_Symbol(i, MarkSym as ISymbol);
}

laslayer.ClearRenderers();
laslayer.AddRenderer((ITinRenderer)TinColRamRend);
axSceneControl1.Scene.AddLayer((ILayer)laslayer);

朱新颖

朱新颖 回答了问题 • 2015-12-19 21:40 • 2 个回复 不感兴趣

如何在C#中调用引用了arcpy的python脚本?

赞同来自:

【解决办法】:
1.可以将该脚本制作为脚本工具,然后在Engine中直接调用该工具,推荐使用此种方法。
2.如果无法做成脚本工具,可以尝试在.Net中调用该.py文件,参考AO帮助: 
http://resources.arcgis.com/en/help/a... 显示全部 »
【解决办法】:
1.可以将该脚本制作为脚本工具,然后在Engine中直接调用该工具,推荐使用此种方法。
2.如果无法做成脚本工具,可以尝试在.Net中调用该.py文件,参考AO帮助: 
http://resources.arcgis.com/en/help/arcobjects-net/conceptualhelp/index.html#/Leveraging_ArcPy_in_a_NET_application/000100000m0s000000/
下面方式可以调用成功: 
[code]
string strPyScFile = string.Format({0}\\{1}, Application.StartupPath, zxy.py); //.py文件的路径

//Parameters 
string sArguments = string.Format({0}, strPyScFile); 
System.Diagnostics.Process p = new System.Diagnostics.Process(); 

p.StartInfo.FileName = @C:\Python27\ArcGIS10.2\python.exe;//Python程序路径 
p.StartInfo.Arguments = sArguments; 
p.StartInfo.UseShellExecute = false; 
// Do not create the black window. 
p.StartInfo.CreateNoWindow = true; 
p.StartInfo.RedirectStandardOutput = true; 
p.StartInfo.RedirectStandardInput = true; 
p.Start(); 
p.WaitForExit(); 
string result = p.StandardOutput.ReadToEnd(); //获取输出信息
【解决办法】:
 
AO帮助中有关于获取HDF的示例代码,在线网址: 
http://resources.arcgis.com/en/help/arcobjects-net/conceptualhelp/index.html#//0001000001sz000... 显示全部 »
【解决办法】:
 
AO帮助中有关于获取HDF的示例代码,在线网址: 
http://resources.arcgis.com/en/help/arcobjects-net/conceptualhelp/index.html#//0001000001sz000000 

用下面代码可以成功获取HDF5数据的三个子数据,并作为RGB图层显示。
[code]
string FileName1 = @D:\ZhuXinying\测试数据\Raster\H2A_RM2A20150113000086_0294.h5;
RasterWorkspaceFactoryClass pRasterWorkspaceFactoryClass1 = new RasterWorkspaceFactoryClass();
IWorkspace pWorkspace1 = pRasterWorkspaceFactoryClass1.OpenFromFile(System.IO.Path.GetDirectoryName(FileName1), 0);
IRasterWorkspace pRasterWorkspace = pWorkspace1 as IRasterWorkspace;
ESRI.ArcGIS.DataSourcesRaster.IRasterBandCollection rasterBandCollection = new ESRI.ArcGIS.DataSourcesRaster.RasterClass();

int[] ListSub = { 16, 17, 18 };//获取子数据集,以16 17 18为例
for (int i = 0; i < ListSub.Length; i++)
{
IRasterDataset pRasterDataset = pRasterWorkspace.OpenRasterDataset(System.IO.Path.GetFileName(FileName1));
IRasterDatasetJukebox pRasterDatasetJukebox = pRasterDataset as IRasterDatasetJukebox;
if (pRasterDatasetJukebox.SubdatasetCount > ListSub[i])
{
IRasterDatasetJukebox pRasterDatasetJukeboxdas = pRasterDataset as IRasterDatasetJukebox;
pRasterDatasetJukeboxdas.Subdataset = ListSub ;
IRasterDataset pSubDataset = pRasterDatasetJukeboxdas as IRasterDataset;
IRasterBandCollection pRasterBands1 = pSubDataset as IRasterBandCollection;
rasterBandCollection.Add(pRasterBands1.Item(0), i);
}
}

IRasterLayer pRasterLayerClass = new RasterLayerClass();
pRasterLayerClass.CreateFromRaster(rasterBandCollection as IRaster);
pRasterLayerClass.Name = asdf;
axMapControl1.AddLayer(pRasterLayerClass);
axMapControl1.Refresh();
IGeoDataset geodataset = rasterBandCollection as IGeoDataset;
ISaveAs saveAs = geodataset as ISaveAs;
saveAs.SaveAs(zxy7.tif, pWorkspace1, TIFF);
朱新颖

朱新颖 回答了问题 • 2016-03-04 20:04 • 1 个回复 不感兴趣

Engine中如何对要素类进行投影变换?

赞同来自:

【解决办法】:
主要分三步:
1,由于WGS84地理坐标系和西安80投影坐标系的椭球体不同,需要先定义一个地理变换,参考AO帮助链接:
http://resources.arcgis.com/en/help/arcobjects-net/conceptualh... 显示全部 »
【解决办法】:
主要分三步:
1,由于WGS84地理坐标系和西安80投影坐标系的椭球体不同,需要先定义一个地理变换,参考AO帮助链接:
http://resources.arcgis.com/en/help/arcobjects-net/conceptualhelp/index.html#/d/0001000009sw000000.htm
2,获取要素类,遍历每个要素,获取IGeometry,使用IGeometry5.ProjectEx()方法进行投影,将投影后的Geometry重新赋值给Feature,并且报存。
http://resources.arcgis.com/en/help/arcobjects-net/componenthelp/index.html#//002m000001rp000000
3,将处理过的要素类的空间参考改为新的空间参考,使用IGeoDatasetSchemaEdit.AlterSpatialReference方法。
http://resources.arcgis.com/en/help/arcobjects-net/componenthelp/index.html#//0025000003mn000000

注:如果两个坐标系的椭球体相同的话,直接使用IGeometry5.Project()进行投影即可,也不需要定义地理变换

参考代码(以WGS84到西安80为例):



IGeographicCoordinateSystem wgs84GCS = createGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_WGS1984);
            IProjectedCoordinateSystem xian80PCS = createProjectedCoordinateSystem((int)esriSRProjCS4Type.esriSRProjCS_Xian1980_3_Degree_GK_CM_102E);
            IGeoTransformation geoTrans = createCustomGeoTrans((ISpatialReference)wgs84GCS, (ISpatialReference)xian80PCS);
            IWorkspace workspace = getWorkspace(esriDataSourcesGDB.FileGDBWorkspaceFactory, @E:\ZhuXinying\testData\Data.gdb);
            IFeatureClass featureClass = openFeatureClass(workspace, WGS841);
            IFeatureCursor featureCur = featureClass.Search(null, false);
            IFeature feature = featureCur.NextFeature();
            while (feature != null)
            {
                IGeometry5 geometry = feature.ShapeCopy as IGeometry5;
                geometry.ProjectEx(xian80PCS as ISpatialReference, esriTransformDirection.esriTransformForward,geoTrans, false, 0, 0);
                feature.Shape = geometry;
                feature.Store();
                feature = featureCur.NextFeature();
            }
            // 定义投影
            defineSpatialReference(featureClass as IDataset, xian80PCS);

​ private void defineSpatialReference(IDataset dataset,ISpatialReference spatialReference)
        {
            IGeoDatasetSchemaEdit geoSchemaEdit = dataset as IGeoDatasetSchemaEdit;
            if (geoSchemaEdit.CanAlterSpatialReference)
            {
                geoSchemaEdit.AlterSpatialReference(spatialReference);
            }
       }
        private IProjectedCoordinateSystem createProjectedCoordinateSystem(int WKID)
        {
            Type factoryType = Type.GetTypeFromProgID(esriGeometry.SpatialReferenceEnvironment);
            System.Object obj = Activator.CreateInstance(factoryType);
            ISpatialReferenceFactory2 pSRF = obj as ISpatialReferenceFactory2;

            // Initialize and create the input and output coordinate systems.
            IProjectedCoordinateSystem pPCS = new ProjectedCoordinateSystemClass();
            pPCS = pSRF.CreateProjectedCoordinateSystem(WKID);
            return pPCS;
        }

        private IGeographicCoordinateSystem createGeographicCoordinateSystem(int WKID)
        {
            Type factoryType = Type.GetTypeFromProgID(esriGeometry.SpatialReferenceEnvironment);
            System.Object obj = Activator.CreateInstance(factoryType);
            ISpatialReferenceFactory2 pSRF = obj as ISpatialReferenceFactory2;
           
            IGeographicCoordinateSystem pGCS = new GeographicCoordinateSystemClass();
            // Initialize and create the input and output coordinate systems.
            pGCS = pSRF.CreateGeographicCoordinateSystem(WKID);
            return pGCS;
        }
        private IGeoTransformation createCustomGeoTrans(ISpatialReference pInputSR, ISpatialReference pOutputSR)
        {
            IGeographicCoordinateSystem pGCSfrom = null;
            IGeographicCoordinateSystem pGCSto = null;
            if (pInputSR is IGeographicCoordinateSystem)
                pGCSfrom = pInputSR as IGeographicCoordinateSystem;
            else if (pInputSR is IProjectedCoordinateSystem)
                pGCSfrom = (pInputSR as IProjectedCoordinateSystem).GeographicCoordinateSystem;
            if (pOutputSR is IGeographicCoordinateSystem)
                pGCSto = pOutputSR as IGeographicCoordinateSystem;
            else if (pOutputSR is IProjectedCoordinateSystem)
                pGCSto = (pOutputSR as IProjectedCoordinateSystem).GeographicCoordinateSystem;
            
            ICoordinateFrameTransformation pCFT = new CoordinateFrameTransformationClass();
            pCFT.PutParameters(p1, p2, p3, p4, p5, p6, p7); //七参数
            pCFT.PutSpatialReferences(pGCSfrom, pGCSto);
            pCFT.Name = Custom GeoTran;
            IGeoTransformation pGeoTrans = pCFT as IGeoTransformation;
            return pGeoTrans;
        }

【解决办法】:
通过IDisplayTable.DisplayTable获取Join后的Table。


private IFeatureClass FeatureJoinTableFon(IFeatureLayer mFeatureLayer, ITabl... 显示全部 »
【解决办法】:
通过IDisplayTable.DisplayTable获取Join后的Table。


private IFeatureClass FeatureJoinTableFon(IFeatureLayer mFeatureLayer, ITable mTable, string mFeatureField, string mTableField) 

IFeatureClass inputFeatureClass = mFeatureLayer.FeatureClass; 
ITable FeatureTable = inputFeatureClass as ITable; 
IMemoryRelationshipClassFactory memoryRelClassFactory = new MemoryRelationshipClassFactory(); 
IRelationshipClass relationshipClass = memoryRelClassFactory.Open(test, FeatureTable as IObjectClass, mFeatureField, mTable as IObjectClass, mTableField, Forwardfield, Backwardfield, esriRelCardinality.esriRelCardinalityOneToOne); 
IRelationshipClassCollectionEdit pRelClassCollEdit = mFeatureLayer as IRelationshipClassCollectionEdit; 
pRelClassCollEdit.AddRelationshipClass(relationshipClass); 
IDisplayTable displayTable = pRelClassCollEdit as IDisplayTable; 
IFeatureClass outputFeatureClass = displayTable.DisplayTable as IFeatureClass; 
return outputFeatureClass; 
}
【解决办法】:
1,第一种方法:
连接Server后,获取该服务的IServerObjectConfiguration,其isCached属性,返回值为true即为切片服务,返回值为false即没有切片。

2,第二种方法:
获取到IMapServer后转为I... 显示全部 »
【解决办法】:
1,第一种方法:
连接Server后,获取该服务的IServerObjectConfiguration,其isCached属性,返回值为true即为切片服务,返回值为false即没有切片。

2,第二种方法:
获取到IMapServer后转为ITiledMapServer,然后通过HasSingleFusedMapCache和HasLayerCache判断是否有切片,如果这两个bool值都返回false就是没有切片,如果有一个返回true就是有切片  


IServerObjectAdmin m_ServerObjectAdmin = ConnectAGS(https://xinying.arcgismap.com:6443/arcgis/admin, arcgis, arcgis);
            IServerObjectConfiguration con = m_ServerObjectAdmin.GetConfiguration(SampleWorldCities, MapServer);
            IPropertySet propertySet = con.Properties;
          
            object value = propertySet.GetProperty(isCached);



if(mapserver is ITiledMapServer) 

ITiledMapServer2 tiled = mapserver as ITiledMapServer2; 

bool a = tiled.HasSingleFusedMapCache(mapserver.DefaultMapName); 
bool b = tiled.HasLayerCache(mapserver.DefaultMapName, 0); 
}
朱新颖

朱新颖 回答了问题 • 2018-04-01 00:00 • 1 个回复 不感兴趣

Engine中如何获取某一点坐标的像素值?

赞同来自:

【解决办法】:
可以将点的地图坐标转为像素的行列号,然后获取该位置的像素值,这种方法获取的精度高,可以达到预期。
 


IRaster2 raster2 = (IRaster2)RasterLayer.Raster; 
//Get the column a... 显示全部 »
【解决办法】:
可以将点的地图坐标转为像素的行列号,然后获取该位置的像素值,这种方法获取的精度高,可以达到预期。
 


IRaster2 raster2 = (IRaster2)RasterLayer.Raster; 
//Get the column and row by giving x,y coordinates in a map space. 
int col = raster2.ToPixelColumn(point.X); 
int row = raster2.ToPixelRow(point.Y); 
//Get the value at a given band. 
double pixelValue = Convert.ToDouble(raster2.GetPixelValue(0, col, row));
【解决办法】:
设置IEngineEditProperties2.StickyMoveTolerance
【解决办法】:
设置IEngineEditProperties2.StickyMoveTolerance
【解决办法】:
1,经测试,下面代码可以成功。但是有两点一定要注意,一是程序要绑定Desktop产品,初始化Desktop产品下的许可,例如Advanced(注意使用Desktop许可的话是无法使用任何控件的),初始化Engine许可无法成功;二是用代码检出e... 显示全部 »
【解决办法】:
1,经测试,下面代码可以成功。但是有两点一定要注意,一是程序要绑定Desktop产品,初始化Desktop产品下的许可,例如Advanced(注意使用Desktop许可的话是无法使用任何控件的),初始化Engine许可无法成功;二是用代码检出esriLicenseExtensionCodeGeoStats许可,使用LicenseControl控件的话无法检出该扩展许可,只能使用代码检出。


RuntimeManager.Bind(ProductCode.Desktop); 
ESRI.ArcGIS.esriSystem.IAoInitialize ao = new ESRI.ArcGIS.esriSystem.AoInitialize(); ao.Initialize(ESRI.ArcGIS.esriSystem.esriLicenseProductCode.esriLicenseProductCodeAdvanced);ao.CheckOutExtension(esriLicenseExtensionCode.esriLicenseExtensionCodeGeoStats);
ESRI.ArcGIS.Geoprocessor.Geoprocessor gp = new ESRI.ArcGIS.Geoprocessor.Geoprocessor(); 
gp.OverwriteOutput = true; 
ESRI.ArcGIS.GeostatisticalAnalystTools.IDW IDW = new ESRI.ArcGIS.GeostatisticalAnalystTools.IDW(); 
IDW.in_features = @C:\Users\Administrator\Downloads\交通大区\AdminZone.shp; 
IDW.z_field = AREA; 
IDW.out_ga_layer = zxyTset; 
IDW.out_raster = @D:\ZhuXinying\测试数据\Raster.gdb\test3; 
IDW.power = 2; 
IDW.search_neighborhood = NBRTYPE=Standard S_MAJOR=2.89390101003182 S_MINOR=2.89390101003182 ANGLE=0 NBR_MAX=15 NBR_MIN=10 SECTOR_TYPE=ONE_SECTOR; 
GeoProcessorResult gpResult = new GeoProcessorResult(); 

try 

gp.Execute(IDW, null); 


catch (Exception ex) 

// Print geoprocessing execution error messages. 
for (int i = 0; i < gp.MessageCount; i++) 
Console.WriteLine(gp.GetMessage(i)); 

 

2,可以使用IGPUtilities.DecodeLayer方法来获取返回的out_ga_layer,参考代码:



IGPUtilities gpUtilities = new GPUtilitiesClass(); 
ILayer layer = gpUtilities.DecodeLayer(gpResult.GetOutput(0));

【解决办法】:
获取IRasterRenderer,修改IRasterRenderer.ResamplingType即可
【解决办法】:
获取IRasterRenderer,修改IRasterRenderer.ResamplingType即可
【解决办法】:
调用工具时,将参数设置为service_type 设置为EXISTING
【解决办法】:
调用工具时,将参数设置为service_type 设置为EXISTING
【解决办法】:
1,先通过IDisplayTransformation.ToMapPoint();将屏幕坐标转为地图坐标
2,使用IRaster2.ToPixelRow以及IRaster2.ToPixelColumn获取该点位置像元的行列号
3,IRaster... 显示全部 »
【解决办法】:
1,先通过IDisplayTransformation.ToMapPoint();将屏幕坐标转为地图坐标
2,使用IRaster2.ToPixelRow以及IRaster2.ToPixelColumn获取该点位置像元的行列号
3,IRaster2.GetPixelValue获取像素值即可

开发地理信息数据管理系统,目前(2019年)最新的技术路线是什么?

回复

ArcGIS Engineblue 回复了问题 • 4 人关注 • 3 个回复 • 321 次浏览 • 2019-05-24 09:54 • 来自相关话题

之前做了一套数据库管理系统,是用ArcGIS Engine10.1+Oracle 11g做的,目前来看有点落后了,想升级一下。
包含 数据导入导出、更新、发布服务、空间查询等。数据库版本选用oracle12c。
之前是用ArcObjects SDK开发,现在还有别的技术路线吗?
ArcGIS Runtime本身的数据处理功能较弱,那配合一些服务(例如Local Server)呢?

ArcGIS 10.5有Engine吗

回复

ArcGIS Engineblue 回复了问题 • 4 人关注 • 3 个回复 • 583 次浏览 • 2019-05-23 16:29 • 来自相关话题

10.5还有没有单独的Engine和AO了?

对 COM 组件的调用返回了错误 HRESULT E_FAIL

回复

ArcGIS EngineV仔 回复了问题 • 5 人关注 • 6 个回复 • 2349 次浏览 • 2019-05-23 15:17 • 来自相关话题

在winform程序中 运行统计功能的时候显示“对 COM 组件的调用返回了错误 HRESULT E_FAIL”,然后点击关闭这个错误后,程序依然能运行 这个报错是什么原因呢?

如何在C#中调用引用了arcpy的python脚本?

回复

kongfankongfan 回复了问题 • 2 人关注 • 2 个回复 • 1793 次浏览 • 2019-05-22 08:47 • 来自相关话题

自定义python脚本,脚本中调用了arcpy,如何在C#中调用该脚本?

Shapefile 图层导入到Oracle空间库时,如何判断字段名称是否合法?

回复

ArcGIS Engine菠萝仔 回复了问题 • 2 人关注 • 2 个回复 • 106 次浏览 • 2019-04-19 17:00 • 来自相关话题

Shapefile 图层导入到Oracle空间库时发生错误:对象名不是基础 DBMS 的常规识别符 [ORA-00942: 表或视图不存在] ;检查发现shapefile图层有一个字段名称包含了括号特殊字符,导致了创建sde图层失败;
现在有个疑问就是在创建图层前已经通过
IFieldChecker检查字段名称是否合法,为什么字段名称包含括号的问题检查不出来?检查的函数如下:
public st

arcengine开发目标平台只能是X86吗?

回复

ArcGIS EngineV仔 回复了问题 • 3 人关注 • 2 个回复 • 565 次浏览 • 2019-04-16 16:26 • 来自相关话题

如何在X64的目标平台下开发arcengine,因为系统其他部分要用64位的开发。求大神解决!

ArcgisEngine中利用IFeatureDataConverter.ConvertFeatureDataset()复制FeatrueDataset报错

回复

ArcGIS Engine公子小白666 回复了问题 • 3 人关注 • 2 个回复 • 800 次浏览 • 2019-04-10 11:41 • 来自相关话题

//获取SDE工作空间public IWorkspace FindWsByDefault()
        {
            IPropertySet propSet = new PropertySetClass();
            propSet.SetProperty("Server", "zhaofei-PC");
   

你好,请问我想用 table.UpdateSearchedRows(queryFilter, rowBuffer)更新属性

回复

ArcGIS Engine溪伊君 回复了问题 • 3 人关注 • 3 个回复 • 363 次浏览 • 2019-01-09 15:13 • 来自相关话题

用这个方法更新完之后,某一字段确实按照我设置的条件进行了更新,但是,原来字段的已有信息都变成了0.。。。请问如何解决这个问题。。谢谢您

AE位置查询时,在遍历图层数量加载时,报“未将对象引用设置到对象的实例。”的错,可以看一下图片

回复

ArcGIS EngineMENTHA 回复了问题 • 3 人关注 • 2 个回复 • 960 次浏览 • 2018-12-17 18:53 • 来自相关话题

  private void FrmSpatialQuery_Load(object sender, EventArgs e)
        {
            ILayer pLayer = null;
            //添加图层到ckListBoxLayer
            for (int i = 0;i<frmMap.axMapControl1.L

Engine中,对于这样个一个多部件的Polyline,我如何得到其内所有的闭合区域。就像ArcGIS工具箱的要素转面工具那样

回复

ArcGIS Engine朱新颖 回复了问题 • 2 人关注 • 1 个回复 • 194 次浏览 • 2018-12-05 11:56 • 来自相关话题

 

arcengine添加多个图层 不能实时显示呢??

回复

ArcGIS Engine朱新颖 回复了问题 • 2 人关注 • 1 个回复 • 651 次浏览 • 2018-11-09 09:00 • 来自相关话题

  for (int i = 1; i < 9; i++)
            {
                string path = "..//..//sample//HH//数据";
                string name = i + ".shp";
                axMapControl1.AddSh

MDB转SHP之后Float类型字段值在ArcGIS Engine中读取与在Arcmap中看到的不一致

回复

ArcGIS Enginexiaosi9524 回复了问题 • 2 人关注 • 1 个回复 • 334 次浏览 • 2018-11-06 09:49 • 来自相关话题

SHP图层的Float类型字段,一些要素在ArcGIS Engine中的取值与在ArcMap中看到的不一致。比如在ArcMap中看到的值是0.005,在ArcGISEngine中读取到的值有可能为0.004996。这个是什么原因,有没有解决方法。

ae(ArcEngine) java swing开发入门系列(1):开发环境和代码部署

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 236 次浏览 • 2019-02-13 11:32 • 来自相关话题

前言:做ae开发大部分人都是用C#版,很少用到java版,本系列文章主要介绍java版ae开发的入门,对于ae接口的高级应用,可以看C#版相关文章

 

开发环境软件:

Intellij IDEA 2018

java jdk 1.8 32位版

arcgis desktop 10.4.1

ArcObject sdk java 10.4.1

 

PS:本文

ae(ArcEngine) java swing开发入门系列(2):ae的类型转换和Proxy类说明

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 133 次浏览 • 2019-02-10 15:29 • 来自相关话题

做过C#版ae的都知道,操作同一个“对象”,用他的不同功能要转换到相应的接口,但java版有时不能直接做类型转换

例如下图在C#是可以的

 






但在java不行,这样转会报错,看IFeatureClass的定义,可以看到根本没继承IDataset

 






在java的转换方法是利用对应的Proxy类

 






PS:ja

Arcgis Engine(ae)接口详解:全集目录

ArcGIS Enginecannel 发表了文章 • 4 个评论 • 1434 次浏览 • 2017-11-29 10:48 • 来自相关话题

Arcgis Engine(ae)接口详解(1):featureClass
 
Arcgis Engine(ae)接口详解(2):featureClass查询
 
Arcgis Engine(ae)接口详解(3):featureClass的feature编辑和删除
 
Arcgis Engine(ae)接口详解(4):featureClass的feature插入
 
Arcgis Engine(a

Arcgis Engine(ae)接口详解(8):临时元素(element)

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 518 次浏览 • 2017-11-29 10:46 • 来自相关话题

IMap map = null;
IActiveView activeView =null;

//IGraphicsContainer用于操作临时元素,可以通过map获取
IGraphicsContainer gc = map as IGraphicsContainer

ArcGIS Engine 10.5下构建Java程序—轻松入门

ArcGIS Engine朱新颖 发表了文章 • 0 个评论 • 706 次浏览 • 2017-11-17 00:00 • 来自相关话题

虽然接触Engine Java的时间比较长,也接触过用户的一些问题,但是一般都是直接从ArcObjects SDK for Java的示例工程中找一个,然后测试用户代码,并没有自己动手搭建过Engine Java工程,尤其是带控件的,今天正好有用户问起,就动手搭建工程测试一下。现把详细的流程写下来,希望对刚刚开始进行Engine Java开发的用户有所帮助。
一、 环境的准备
1,Engine J

Linux 下如何运行Engine Java 程序

ArcGIS Engine朱新颖 发表了文章 • 0 个评论 • 494 次浏览 • 2017-11-08 00:00 • 来自相关话题

上篇文章讲解了Linux下如何安装ArcGIS Engine软件并授权,这篇文章主要介绍下Linux下如何运行Engine Java程序,主要是环境的搭建。
本文以Redhat 6.5操作系统,ArcGIS Engine 10.2以及运行基于Engine Java开发的.jar为例,进行环境的搭建。首先我们需要安装Java JDK,这里使用Java 6 Update 20(32bit)环境。
一、

Arcgis Engine(ae)接口详解(7):地图(map)操作

ArcGIS Enginecannel 发表了文章 • 1 个评论 • 842 次浏览 • 2017-10-11 14:05 • 来自相关话题

IMap map = hookHelper.FocusMap;
//跟map同一层次的activeView对象,他们都是“地图”的对象,map管理地图内容,activeView管理显示内容
IActiveView activeView = map as IActiveView;

//获取当前地图显示范

Arcgis Engine(ae)接口详解(6):workspace操作

ArcGIS Enginecannel 发表了文章 • 2 个评论 • 938 次浏览 • 2017-10-08 20:57 • 来自相关话题

//此处用的workspace来源与用户选择
IWorkspace workspace = null;

//workspace一般等同于数据库

//工作空间类型,也可理解为数据库类型
//esriFileSystemWorkspace:

Linux上安装ArcGIS Engine 10.4详解

ArcGIS Engine朱新颖 发表了文章 • 0 个评论 • 563 次浏览 • 2017-09-29 00:00 • 来自相关话题

ArcGIS Engine的优势之一就是其跨平台性,既可以在Windows操作系统上使用,也可以在Linux操作系统上使用。但由于绝大部分用户都是在Windows上使用的,因此,对于Linux上如何安装ArcGIS Engine以及如何运行Engine应用程序并没有研究过。最近正好有用户问到Linux下ArcGIS Engine的安装问题,于是便动手搭建了Linux环境,进行了安装测试,过程有些曲

Arcgis Engine(ae)接口详解(5):IGeometry几何高级操作

ArcGIS Enginecannel 发表了文章 • 1 个评论 • 672 次浏览 • 2017-09-26 14:03 • 来自相关话题

IPoint point = new PointClass();
point.PutCoords(100, 200);

//ITopologicalOperator接口用于几何对象的几何操作
ITopologicalOperator topo = point as ITopologicalOperat

ArcGIS Engine中调用地理处理工具(gp工具)的方法与注意事项

ArcGIS Engine刘峥 发表了文章 • 0 个评论 • 696 次浏览 • 2017-07-05 00:00 • 来自相关话题

(以10.3版本下使用C#调用系统工具为例)
1. 在程序中调用gp是否需要安装Desktop软件?
不用安装Desktop软件,安装ArcGIS Engine运行时以后就可以调用gp工具。
2. 如何查看gp工具的许可级别?
可以直接在Desktop的帮助文档中定位到该工具的帮助页面,或者在Desktop软件中开启gp工具的执行页面,点击右下角的“tool help”按钮,也会弹出该工具的帮助页

【ArcGIS 10.5 产品白皮书】第四章 ArcGIS开发包---ArcGIS Engine

ArcGIS EngineArcGIS极客说 发表了文章 • 1 个评论 • 1877 次浏览 • 2017-04-14 00:00 • 来自相关话题

在许多应用中,用户需要通过定制应用或者在现有应用中增添GIS逻辑来实现对GIS的需求,而这些应用程序常常是运行在Windows和Linux上,ArcGIS Engine则被用来建立这样一些应用程序。ArcGIS Engine是ArcObjects组件跨平台应用的核心集合,它提供多种开发的接口,可以适应.NET,Java和C++等开发环境。开发者可以使用这些组件来开发和GIS相关的地图应用,应用程序