ArcGIS Engine

ArcGIS Engine

arcgis engine如何绘制面元素?

回复

ArcGIS EngineCmystery 发起了问题 • 1 人关注 • 0 个回复 • 13 次浏览 • 2020-07-06 12:00 • 来自相关话题

绘制线元素时可以使用 ILineElement.Symbol进行赋值线样式,而IPolygonElement不存在相关属性,请问如何才能对IPolygonElement赋值面样式?

关于ArcGIS Engine中ITopologicalOperator.Simplify()方法问题?

回复

ArcGIS EngineCmystery 发起了问题 • 1 人关注 • 0 个回复 • 27 次浏览 • 2020-07-04 00:02 • 来自相关话题

$(document).ready(function() {$('pre code').each(function(i, block) { hljs.highlightBlock( block); }); });
IGeometry FocusGeometry;
ITopologicalOperator pTopo = FocusGeometry as ITopologicalOperator

c#编写addin 使用INewFeedback残影问题

回复

ArcGIS Engine宽恕 发起了问题 • 1 人关注 • 0 个回复 • 26 次浏览 • 2020-06-23 14:20 • 来自相关话题

我在使用m_LineFeedback.MoveTo(point)的时候偶尔会出现原来线段的残影,调用 m_LineFeedback.Refresh(hDc)方法却还是没有用,请问这个怎么处理

ERROR 010096: 当前没有或未启用 Spatial Analyst 许可,该怎么办呢?有详细说明的吗?

ArcGIS Engine一只蒸熟的包子 回复了问题 • 2 人关注 • 2 个回复 • 4199 次浏览 • 2020-05-26 11:36 • 来自相关话题

 

ESRI.ArcGIS.ConversionTools.ExportCAD中的in_features应该赋值什么?

ArcGIS Engine施凯敏 回复了问题 • 3 人关注 • 3 个回复 • 2483 次浏览 • 2020-05-08 14:11 • 来自相关话题

权限已经给过,为什么会报错对 COM 组件的调用返回了错误 HRESULT E_FAIL。

ArcEngine 请问如何遍历一个矢量里的所有记录,分别与另一个矢量进行相交分析?

回复

ArcGIS Engine陳大鼓 发起了问题 • 1 人关注 • 0 个回复 • 170 次浏览 • 2020-04-23 16:27 • 来自相关话题

我看都是两个shp进行相交判断,能不能直接用selected记录进行如果使用gp工具的话,使用intersect还是用select layer by location,代码应该怎么写?
不使用gp有别的办法么

ArcGIS Engine开发的数据库管理系统可以用ArcGIS Runtime完全实现吗

Runtime SDK@__@ 回复了问题 • 5 人关注 • 2 个回复 • 1925 次浏览 • 2020-04-23 00:44 • 来自相关话题

 本人五年前做了一套数据库管理系统,用的是ArcGIS Engine 10.1,.Net Framework 4.0。
取得了很好的应用,但是随着微软和ESRI的技术更新,想要完全迁移到新的平台
我刚接触ArcGIS Runtime,目前看中了ArcGIS Runtime for .Net 100.3,开发工具VS2015。
请教各位老师,技术上是否可行?
 
原系统有如下功能:
1 s

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

四百多 回复了问题 • 7 人关注 • 2 个回复 • 2987 次浏览 • 2020-02-28 15:38 • 来自相关话题

Engine中如何对要素类进行投影变换?例如Desktop中的Project工具。以要素类从WGS84地理坐标系转为西安80投影坐标系为例

Engine中如何在布局视图下固定地图的Extent?

countsun 回复了问题 • 3 人关注 • 2 个回复 • 2361 次浏览 • 2020-02-24 10:25 • 来自相关话题

Engine中如何在布局视图下固定地图的Extent?ArcMap中操作:在Data Frame Properties->Data Frame->Extent 下选择Fixed Extent,然后手动设置Extent。

咨询一下三维仿真

回复

ArcGIS Desktopxuddk727 发起了问题 • 3 人关注 • 0 个回复 • 300 次浏览 • 2020-02-19 16:16 • 来自相关话题

我现在是要做一个污水厂的仿真系统,通过无人机航飞建模,并通过相机拍摄建筑实际照片作为纹理贴附在模型上,并在三维系统中展示(一些节点还接入摄像头,三维场景运行到该处直接呈现视频流接入,给人AR的感觉),这个东西要做按你们以往经验是该用scene还是globe的控件,异或要用pro(没用过)?有没有可参考案例或示例?另外三维这块确实不会,导入了3ds模型之后连纹理都贴不对,这块有资料么?




 

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

ArcGIS Engine邢书书 回复了问题 • 3 人关注 • 3 个回复 • 974 次浏览 • 2020-02-17 15:34 • 来自相关话题

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





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

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

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

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

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

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-03-27 23:47 • 2 个回复 不感兴趣

Engine中如何在布局视图下固定地图的Extent?

赞同来自:

【解决办法】:
可以通过以下步骤:
1,获取IMapFrame;
2,将IMapFrame.ExtentType设置为esriExtentTypeEnum.esriExtentBounds;
3,自定义Envelope,将其赋予IMapFrame.MapBou... 显示全部 »
【解决办法】:
可以通过以下步骤:
1,获取IMapFrame;
2,将IMapFrame.ExtentType设置为esriExtentTypeEnum.esriExtentBounds;
3,自定义Envelope,将其赋予IMapFrame.MapBounds,刷新即可。


IGraphicsContainer pGraphicsContainer = axPageLayoutControl1.GraphicsContainer; 
IMapFrame pMapFrame = pGraphicsContainer.FindFrame(axPageLayoutControl1.ActiveView.FocusMap) as IMapFrame; 
pMapFrame.ExtentType = esriExtentTypeEnum.esriExtentBounds; 
IEnvelope env = new EnvelopeClass(); 
env.PutCoords(111939.3058, 27729.6982, 131821.6658, 41643.6886); //地理坐标系下的坐标,即范围
pMapFrame.MapBounds = env; 
axPageLayoutControl1.Refresh();
朱新颖

朱新颖 回答了问题 • 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后该问题得以解决。
试试IMarkerNorthArrow
试试IMarkerNorthArrow
Runtime更侧重于轻量级程序开发,确实跟web gis这块联系更紧,Runtime中使用的是mpk,geodatabase、tpk、mmpk等等,Identify、空间查询、缓冲区分析等常用功能是具备的,但复杂的编辑功能、数据导入导出功能目前比较弱。
Runtime更侧重于轻量级程序开发,确实跟web gis这块联系更紧,Runtime中使用的是mpk,geodatabase、tpk、mmpk等等,Identify、空间查询、缓冲区分析等常用功能是具备的,但复杂的编辑功能、数据导入导出功能目前比较弱。

arcgis engine如何绘制面元素?

回复

ArcGIS EngineCmystery 发起了问题 • 1 人关注 • 0 个回复 • 13 次浏览 • 2020-07-06 12:00 • 来自相关话题

绘制线元素时可以使用 ILineElement.Symbol进行赋值线样式,而IPolygonElement不存在相关属性,请问如何才能对IPolygonElement赋值面样式?

关于ArcGIS Engine中ITopologicalOperator.Simplify()方法问题?

回复

ArcGIS EngineCmystery 发起了问题 • 1 人关注 • 0 个回复 • 27 次浏览 • 2020-07-04 00:02 • 来自相关话题

IGeometry FocusGeometry;
ITopologicalOperator pTopo = FocusGeometry as ITopologicalOperator;
if (!pTopo.IsSimple)
pTopo.Simplify();在使用ITopologicalOperator.Simplify()方法时,有时会使原IGe

c#编写addin 使用INewFeedback残影问题

回复

ArcGIS Engine宽恕 发起了问题 • 1 人关注 • 0 个回复 • 26 次浏览 • 2020-06-23 14:20 • 来自相关话题

我在使用m_LineFeedback.MoveTo(point)的时候偶尔会出现原来线段的残影,调用 m_LineFeedback.Refresh(hDc)方法却还是没有用,请问这个怎么处理

ERROR 010096: 当前没有或未启用 Spatial Analyst 许可,该怎么办呢?有详细说明的吗?

回复

ArcGIS Engine一只蒸熟的包子 回复了问题 • 2 人关注 • 2 个回复 • 4199 次浏览 • 2020-05-26 11:36 • 来自相关话题

 

ESRI.ArcGIS.ConversionTools.ExportCAD中的in_features应该赋值什么?

回复

ArcGIS Engine施凯敏 回复了问题 • 3 人关注 • 3 个回复 • 2483 次浏览 • 2020-05-08 14:11 • 来自相关话题

权限已经给过,为什么会报错对 COM 组件的调用返回了错误 HRESULT E_FAIL。

ArcEngine 请问如何遍历一个矢量里的所有记录,分别与另一个矢量进行相交分析?

回复

ArcGIS Engine陳大鼓 发起了问题 • 1 人关注 • 0 个回复 • 170 次浏览 • 2020-04-23 16:27 • 来自相关话题

我看都是两个shp进行相交判断,能不能直接用selected记录进行如果使用gp工具的话,使用intersect还是用select layer by location,代码应该怎么写?
不使用gp有别的办法么

ArcGIS Engine开发的数据库管理系统可以用ArcGIS Runtime完全实现吗

回复

Runtime SDK@__@ 回复了问题 • 5 人关注 • 2 个回复 • 1925 次浏览 • 2020-04-23 00:44 • 来自相关话题

 本人五年前做了一套数据库管理系统,用的是ArcGIS Engine 10.1,.Net Framework 4.0。
取得了很好的应用,但是随着微软和ESRI的技术更新,想要完全迁移到新的平台
我刚接触ArcGIS Runtime,目前看中了ArcGIS Runtime for .Net 100.3,开发工具VS2015。
请教各位老师,技术上是否可行?
 
原系统有如下功能:
1 s

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

回复

四百多 回复了问题 • 7 人关注 • 2 个回复 • 2987 次浏览 • 2020-02-28 15:38 • 来自相关话题

Engine中如何对要素类进行投影变换?例如Desktop中的Project工具。以要素类从WGS84地理坐标系转为西安80投影坐标系为例

Engine中如何在布局视图下固定地图的Extent?

回复

countsun 回复了问题 • 3 人关注 • 2 个回复 • 2361 次浏览 • 2020-02-24 10:25 • 来自相关话题

Engine中如何在布局视图下固定地图的Extent?ArcMap中操作:在Data Frame Properties->Data Frame->Extent 下选择Fixed Extent,然后手动设置Extent。

咨询一下三维仿真

回复

ArcGIS Desktopxuddk727 发起了问题 • 3 人关注 • 0 个回复 • 300 次浏览 • 2020-02-19 16:16 • 来自相关话题

我现在是要做一个污水厂的仿真系统,通过无人机航飞建模,并通过相机拍摄建筑实际照片作为纹理贴附在模型上,并在三维系统中展示(一些节点还接入摄像头,三维场景运行到该处直接呈现视频流接入,给人AR的感觉),这个东西要做按你们以往经验是该用scene还是globe的控件,异或要用pro(没用过)?有没有可参考案例或示例?另外三维这块确实不会,导入了3ds模型之后连纹理都贴不对,这块有资料么?




 

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

回复

ArcGIS Engine邢书书 回复了问题 • 3 人关注 • 3 个回复 • 974 次浏览 • 2020-02-17 15:34 • 来自相关话题

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





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

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

回复

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

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

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

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

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

例如下图在C#是可以的

 






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

 






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

 






PS:ja

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

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

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

Linux 下如何运行Engine Java 程序

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

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

//workspace一般等同于数据库

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

Linux上安装ArcGIS Engine 10.4详解

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

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