ArcGIS Engine

ArcGIS Engine

ArcGIS Engine 如何实现多图层叠加分析

ArcGIS Engine朱新颖 回复了问题 • 3 人关注 • 2 个回复 • 36 次浏览 • 2020-02-17 12:08 • 来自相关话题

两个图层可以 三个图层就不可以了,能帮忙看一下吗





我把多个图层转换成list 也不可以,能解释一下如何实现多个图层吗?

Engine中哪个接口可以实现与ArcMap中的Planarize Lines工具相同的功能?

我是大树 回复了问题 • 2 人关注 • 2 个回复 • 515 次浏览 • 2020-02-13 11:38 • 来自相关话题

ArcMap中的Planarize Lines工具分隔椭圆弧正常,但是相同数据Engine中使用SplitAtPoints方法所得结点与ArcMap中的工具所得结果不一致,Engine有无接口可以实现Planarize Lines工具的功能?

ArcEngine9.3到ArcEngine一些接口方法的变动,比如IDataGraph和 IDataGraphProperties

回复

ArcGIS Engine风君座 回复了问题 • 1 人关注 • 1 个回复 • 88 次浏览 • 2020-01-12 14:39 • 来自相关话题

IDataGraph pDataGraph = new DataGraphClass();
pDataGraph.Attach(this.pictureBox1.Handle.ToInt32());
//pDataGraph(this.pictureBox1.Handle.ToInt32());
//设

利用arcengien 进行ExtractValuesToPoints 出现 ERROR 010092: 无效的输出范围。

ArcGIS Engine朱新颖 回复了问题 • 3 人关注 • 2 个回复 • 250 次浏览 • 2019-12-02 16:06 • 来自相关话题

大家有遇到过吗,有什么解决建议吗?

Project工具报错 000365 : 无效的地理(坐标)变换。

ArcGIS Desktop陈晨 回复了问题 • 5 人关注 • 4 个回复 • 3440 次浏览 • 2019-10-16 09:38 • 来自相关话题

 在Arcgis10.4中使用Project工具




报错 000365 : 无效的地理(坐标)变换。
同样的数据在Arcgis10.1中没有问题。

Add-in扩展button,如何保存地图文档?

泡馍是甜的 回复了问题 • 3 人关注 • 2 个回复 • 840 次浏览 • 2019-09-06 17:49 • 来自相关话题

Add-in扩展button,如何保存地图文档?

Engine中如何删除mdb或者FileGDB?

koococo 回复了问题 • 2 人关注 • 2 个回复 • 1069 次浏览 • 2019-08-29 15:58 • 来自相关话题

Engine中如何删除mdb或者FileGDB?

在父目录和子目录之间切换工作空间

ArcGIS Enginejiushidt 回复了问题 • 2 人关注 • 2 个回复 • 261 次浏览 • 2019-08-21 12:01 • 来自相关话题

想打开子目录中的一个shp数据,处理后的结果写到父目录中,如何进行工作空间的切换。
$(document).ready(function() {$('pre code').each(function(i, block) { hljs.highlightBlock( block); }); });string childpath="workspace\\temp";
IWor

使用IObjectCopy进行map对象拷贝后,造成滚轮异常

ArcGIS Engine石羽 回复了问题 • 2 人关注 • 1 个回复 • 223 次浏览 • 2019-08-21 10:57 • 来自相关话题

.net sdk中copyfocusmap例子,使用IObjectCopy将mapcontrol中的地图对象拷贝复写到pagelayoutcontrol中,然后对pagelayoutcontrol进行滚轮缩放,结果p制图页面和主数据框中的地图都被缩放了。如果pagelayoutcontrol进行通过addlayers进行图层添加,则没有这个问题,只有制图页面缩放,而主数据框中的地图没有缩放。
这个

Arcgis Engine(ae)接口详解(1):featureClass

ArcGIS Engine秘制生煎包 回复了问题 • 7 人关注 • 3 个回复 • 2764 次浏览 • 2019-08-20 14:03 • 来自相关话题

//IFeatureClass来源请自行解决
IFeatureClass featureClass = null;

//获取featureClass的各种名称
//PS:featureClass可以as到IDataset,因此不能只看接口名,并不是只有数据集才实现IDa

IDynamicMap 设置DynamicMapEnabled属性报错

回复

ArcGIS Engineherry 回复了问题 • 1 人关注 • 1 个回复 • 303 次浏览 • 2019-08-02 15:21 • 来自相关话题

下面的加载动态图层的代码在ArcGIS Engine10.3下运行过,没有问题
                customDynamicLayerClass pLayer = new customDynamicLayerClass();
                pLayer.Name = "dynamiclayer";
                pLayer.V

AE+C#开发中自定义button继承toolbarContol某功能的方法

回复

ArcGIS Engine湫谷 回复了问题 • 1 人关注 • 1 个回复 • 283 次浏览 • 2019-07-27 11:35 • 来自相关话题

开发环境:vs2013、Arcengine(SDK)10.4.1、win10
这是我接触AE的第三个星期(萌新),我有一个想法,Arcgis中的一些功能譬如—添加数据的功能,在toolbarContol里面都有相对应的功能按钮,能不能声明一个类来继承继承这个控件的类(为了实现不添加toolbarContol控件),再将我自己定义的button控件的Click事件用来调用它对应功能的方法~这样一些功
条新动态, 点击查看
刘峥

刘峥 回答了问题 • 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-01-24 20:42 • 2 个回复 不感兴趣

Add-in扩展button,如何保存地图文档?

赞同来自:

【解决办法】:
保存mxd直接使用 IApplication.SaveDocument(); 另存为使用IApplication.SaveAsDocument(); 注意执行保存时不能有其它程序打开该mxd,如Engine或者ArcMap,测试代码如下: 
... 显示全部 »
【解决办法】:
保存mxd直接使用 IApplication.SaveDocument(); 另存为使用IApplication.SaveAsDocument(); 注意执行保存时不能有其它程序打开该mxd,如Engine或者ArcMap,测试代码如下: 


IMapDocument mapDoc = ArcMap.Application.Document as IMapDocument; 
string path = mapDoc.DocumentFilename; 

ArcMap.Application.SaveDocument(path);
朱新颖

朱新颖 回答了问题 • 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;
        }

朱新颖

朱新颖 回答了问题 • 2016-04-08 19:36 • 2 个回复 不感兴趣

Engine中如何删除mdb或者FileGDB?

赞同来自:

【解决办法】:
将IWorkspace转为IDataset,然后使用IDataset.Delete();进行删除。最好不要使用System.IO.File.Delete(path); 根据mdb或FileGDB的路径删除,这种方法可能删除不掉或者删不干净。

... 显示全部 »
【解决办法】:
将IWorkspace转为IDataset,然后使用IDataset.Delete();进行删除。最好不要使用System.IO.File.Delete(path); 根据mdb或FileGDB的路径删除,这种方法可能删除不掉或者删不干净。

注意:删除该workspace之前需要将使用到的FeatureClass,Feature,FeatureCursor,Field等AO对象先释放掉,可以使用System.Runtime.InteropServices.Marshal.FinalReleaseComObject();释放。



IDataset dataset = pWorkspace as IDataset; 
dataset.Delete();
【解决办法】:
通过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; 
}
【解决办法】:
测试后发现Engine中的SplitAtPoints方法和ArcMap的Planarize Lines方法分割椭圆弧时所得的结点坐标确实有些差别,在小数点后第四位,建议使用IFeatureConstruction.PlanarizeLines方... 显示全部 »
【解决办法】:
测试后发现Engine中的SplitAtPoints方法和ArcMap的Planarize Lines方法分割椭圆弧时所得的结点坐标确实有些差别,在小数点后第四位,建议使用IFeatureConstruction.PlanarizeLines方法,该方法所得结果与ArcMap相同,测试代码如下:


IFeatureLayer FL = axMapControl1.get_Layer(0) as IFeatureLayer; 
ISelection sel = axMapControl1.Map.FeatureSelection; 
IEnumFeature features = sel as IEnumFeature; 
IFeatureConstruction con = new FeatureConstructionClass(); 
con.PlanarizeLines(null, features, 0.001);
【解决办法】:
往SDE中导入数据需要初始化EngineGeoDB许可,初始化Engine许可的话就报这个错,改为EngineGeoDB后该问题得以解决。
【解决办法】:
往SDE中导入数据需要初始化EngineGeoDB许可,初始化Engine许可的话就报这个错,改为EngineGeoDB后该问题得以解决。
【解决办法】:
获取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获取像素值即可

ArcGIS Engine 如何实现多图层叠加分析

回复

ArcGIS Engine朱新颖 回复了问题 • 3 人关注 • 2 个回复 • 36 次浏览 • 2020-02-17 12:08 • 来自相关话题

两个图层可以 三个图层就不可以了,能帮忙看一下吗





我把多个图层转换成list 也不可以,能解释一下如何实现多个图层吗?

Engine中哪个接口可以实现与ArcMap中的Planarize Lines工具相同的功能?

回复

我是大树 回复了问题 • 2 人关注 • 2 个回复 • 515 次浏览 • 2020-02-13 11:38 • 来自相关话题

ArcMap中的Planarize Lines工具分隔椭圆弧正常,但是相同数据Engine中使用SplitAtPoints方法所得结点与ArcMap中的工具所得结果不一致,Engine有无接口可以实现Planarize Lines工具的功能?

ArcEngine9.3到ArcEngine一些接口方法的变动,比如IDataGraph和 IDataGraphProperties

回复

ArcGIS Engine风君座 回复了问题 • 1 人关注 • 1 个回复 • 88 次浏览 • 2020-01-12 14:39 • 来自相关话题

IDataGraph pDataGraph = new DataGraphClass();
pDataGraph.Attach(this.pictureBox1.Handle.ToInt32());
//pDataGraph(this.pictureBox1.Handle.ToInt32());
//设

利用arcengien 进行ExtractValuesToPoints 出现 ERROR 010092: 无效的输出范围。

回复

ArcGIS Engine朱新颖 回复了问题 • 3 人关注 • 2 个回复 • 250 次浏览 • 2019-12-02 16:06 • 来自相关话题

大家有遇到过吗,有什么解决建议吗?

Project工具报错 000365 : 无效的地理(坐标)变换。

回复

ArcGIS Desktop陈晨 回复了问题 • 5 人关注 • 4 个回复 • 3440 次浏览 • 2019-10-16 09:38 • 来自相关话题

 在Arcgis10.4中使用Project工具




报错 000365 : 无效的地理(坐标)变换。
同样的数据在Arcgis10.1中没有问题。

Add-in扩展button,如何保存地图文档?

回复

泡馍是甜的 回复了问题 • 3 人关注 • 2 个回复 • 840 次浏览 • 2019-09-06 17:49 • 来自相关话题

Add-in扩展button,如何保存地图文档?

Engine中如何删除mdb或者FileGDB?

回复

koococo 回复了问题 • 2 人关注 • 2 个回复 • 1069 次浏览 • 2019-08-29 15:58 • 来自相关话题

Engine中如何删除mdb或者FileGDB?

在父目录和子目录之间切换工作空间

回复

ArcGIS Enginejiushidt 回复了问题 • 2 人关注 • 2 个回复 • 261 次浏览 • 2019-08-21 12:01 • 来自相关话题

想打开子目录中的一个shp数据,处理后的结果写到父目录中,如何进行工作空间的切换。
string childpath="workspace\\temp";
IWorkspaceFactory pWsFactory = new ShapefileWorkspaceFactoryClass();
IWorkspace pWorkSpace = pWsFactory.OpenFro

使用IObjectCopy进行map对象拷贝后,造成滚轮异常

回复

ArcGIS Engine石羽 回复了问题 • 2 人关注 • 1 个回复 • 223 次浏览 • 2019-08-21 10:57 • 来自相关话题

.net sdk中copyfocusmap例子,使用IObjectCopy将mapcontrol中的地图对象拷贝复写到pagelayoutcontrol中,然后对pagelayoutcontrol进行滚轮缩放,结果p制图页面和主数据框中的地图都被缩放了。如果pagelayoutcontrol进行通过addlayers进行图层添加,则没有这个问题,只有制图页面缩放,而主数据框中的地图没有缩放。
这个

Arcgis Engine(ae)接口详解(1):featureClass

回复

ArcGIS Engine秘制生煎包 回复了问题 • 7 人关注 • 3 个回复 • 2764 次浏览 • 2019-08-20 14:03 • 来自相关话题

//IFeatureClass来源请自行解决
IFeatureClass featureClass = null;

//获取featureClass的各种名称
//PS:featureClass可以as到IDataset,因此不能只看接口名,并不是只有数据集才实现IDa

IDynamicMap 设置DynamicMapEnabled属性报错

回复

ArcGIS Engineherry 回复了问题 • 1 人关注 • 1 个回复 • 303 次浏览 • 2019-08-02 15:21 • 来自相关话题

下面的加载动态图层的代码在ArcGIS Engine10.3下运行过,没有问题
                customDynamicLayerClass pLayer = new customDynamicLayerClass();
                pLayer.Name = "dynamiclayer";
                pLayer.V

AE+C#开发中自定义button继承toolbarContol某功能的方法

回复

ArcGIS Engine湫谷 回复了问题 • 1 人关注 • 1 个回复 • 283 次浏览 • 2019-07-27 11:35 • 来自相关话题

开发环境:vs2013、Arcengine(SDK)10.4.1、win10
这是我接触AE的第三个星期(萌新),我有一个想法,Arcgis中的一些功能譬如—添加数据的功能,在toolbarContol里面都有相对应的功能按钮,能不能声明一个类来继承继承这个控件的类(为了实现不添加toolbarContol控件),再将我自己定义的button控件的Click事件用来调用它对应功能的方法~这样一些功

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

ArcGIS Enginecannel 发表了文章 • 0 个评论 • 517 次浏览 • 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 个评论 • 319 次浏览 • 2019-02-10 15:29 • 来自相关话题

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

例如下图在C#是可以的

 






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

 






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

 






PS:ja

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

ArcGIS Enginecannel 发表了文章 • 4 个评论 • 1974 次浏览 • 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 个评论 • 715 次浏览 • 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 个评论 • 1072 次浏览 • 2017-11-17 00:00 • 来自相关话题

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

Linux 下如何运行Engine Java 程序

ArcGIS Engine朱新颖 发表了文章 • 0 个评论 • 681 次浏览 • 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 个评论 • 1215 次浏览 • 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 个评论 • 1395 次浏览 • 2017-10-08 20:57 • 来自相关话题

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

//workspace一般等同于数据库

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

Linux上安装ArcGIS Engine 10.4详解

ArcGIS Engine朱新颖 发表了文章 • 0 个评论 • 747 次浏览 • 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 个评论 • 981 次浏览 • 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 个评论 • 1029 次浏览 • 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 个评论 • 2466 次浏览 • 2017-04-14 00:00 • 来自相关话题

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