ArcEngine判断要素(feature)是否为multipart feature及分解(炸开)代码
生活随笔
收集整理的這篇文章主要介紹了
ArcEngine判断要素(feature)是否为multipart feature及分解(炸开)代码
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
轉(zhuǎn)自原文 ArcEngine判斷要素(feature)是否為multipart feature及分解(炸開)代碼
#region 校驗合法性 ArrayList pFeatureArray = null; pFeatureArray = Application.Editor.FeatureSelection(); int count=pFeatureArray.Count; if (count<1) { MessageBox.Show("最少必須選擇1個要素才能進行要素分解!", "提示"); return; } #endregion try { //啟動編輯操作 Application.Editor.StartOperation(); #region 對選中的要素進行多部件測試及分解 int multipartcount = 0; for (int i = 0; i < count; i++) { IFeature pFeature = pFeatureArray as IFeature; if (pFeature.ShapeCopy.IsEmpty) continue; IGeometry pGeometry = pFeature.ShapeCopy; IGeometryCollection pGeocoll = pGeometry as IGeometryCollection; int geomcount = pGeocoll.GeometryCount; if (geomcount > 1) { multipartcount++; for (int k = 1; k < geomcount; k++) { IFeature newFeaturte = (pFeature.Class as IFeatureClass).CreateFeature(); IFeatureEdit pFeatureEdit = pFeature as IFeatureEdit; pFeatureEdit.SplitAttributes(newFeaturte); IGeometry newGeom = pGeocoll.get_Geometry(k); if (pFeature.ShapeCopy.GeometryType == esriGeometryType.esriGeometryPolygon) newGeom=GeometryHelper.ConstructPolygon(newGeom); else newGeom = GeometryHelper.ConstructPolyline(newGeom); newGeom.SpatialReference = pFeature.ShapeCopy.SpatialReference; newFeaturte.Shape = newGeom; newFeaturte.Store(); } IGeometry newGeom2 = pGeocoll.get_Geometry(0); if (pFeature.ShapeCopy.GeometryType == esriGeometryType.esriGeometryPolygon) newGeom2 = GeometryHelper.ConstructPolygon(newGeom2); else newGeom2 = GeometryHelper.ConstructPolyline(newGeom2); newGeom2.SpatialReference = pFeature.ShapeCopy.SpatialReference; pFeature.Shape = newGeom2; pFeature.Store(); Application.Editor.StopOperation("分解多部件要素"); } else { continue; } } if (multipartcount == 0) { MessageBox.Show("未選擇多部件要素!", "分解要素"); return; } #endregion } catch (Exception ex) { Application.Editor.AbortOperation(); MessageHelper.WriteLog("分解多部件要素", ex); } finally { Application.ActiveView.Refresh(); FlashFeatures(); }?
總結(jié)
以上是生活随笔為你收集整理的ArcEngine判断要素(feature)是否为multipart feature及分解(炸开)代码的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: tomcat https 配置
- 下一篇: 微信小程序想要最短服务路径