arcobjects,arcengine处理自相交对象

这篇博客介绍了如何在Delphi和C#中使用ArcObjects和ArcEngine来处理自相交对象。通过IsSimple方法进行简单拓扑检查,结合ITopologicalOperator接口的Simplify方法,确保几何对象的正确性。同时提供了针对不同几何类型的简化示例,如Polygon和Polyline。
摘要由CSDN通过智能技术生成

内容摘要
很多线划图数据进ArcSDE库中都会有些对象转换不进去。这些对象有很大一部分是由于数据本身有自相交的情况。如果这些线划图数据只是用来做底图,而不需要做对象分析。则可以采用数据简单化操作后再转换入ArcSDE中。具体操作如下例子:

delphi

//简单拓扑一个对象

procedure IsSimple(var PGeoMetry: IGeoMetry);
var
    pTopo                               : ITopologicalOperator;
    PGeoMetryCollect                    : IGeoMetryCollection;
    ShapeType                           : TOleEnum;
    OldGeoMetry                         : IGeoMetry;

begin
    if IsEmpty(PGeoMetry) then Exit;
    OldGeoMetry := CopyGeoMetry(PGeoMetry);  //拷贝一个原始的对象,因为 有些IsSimple后,原来不为空,处理后为空
    PGeoMetry.Get_GeometryType(ShapeType);
    if ShapeType = esriGeometryPoint then Exit;
    if ShapeType = esriGeometryRing then
    begin
        PGeoMetry := CreatePolygonfromRing(PGeoMetry as IRing);

    end;

    PGeoMetryCollect := PGeoMetry as IGeoMetryCollection;
    try
        PGeoMetryCollect.GeometriesChanged;

        pTopo := PGeoMetry as ITopologicalOperator;

        pTopo.Simplify;
        if IsEmpty(PGeoMetry) then
        begin
            PGeoMetry := OldGeoMetry;
        end;
    except
    end;

end; 

C#

/处理自相交对象

        public static bool IsSimple(ref IGeometry PGeoMetry)

        {

            if (PGeoMetry == null)

            {

                return false;//不用处理

            }

            if (PGeoMetry.GeometryType == esriGeometryType.esriGeometryPoint) //不做任何处理

            {

                return false;//

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值