MapXtreme多边形有关的方法

一、获取图元的外部曲线(多边形节点集)


        /// <summary>
        /// 获取图元的外部曲线(多边形节点集)
        /// </summary>
        /// <param name="ftr">面或矩形</param>
        /// <returns></returns>
        internal static FeatureGeometry GetGeometryCurve(FeatureGeometry ftr)
        {
            if (ftr is MultiPolygon)
            {
                var mulPolygon = ftr as MultiPolygon;
                if (mulPolygon.PolygonCount > 0)
                {
                    var pts = mulPolygon[0].Exterior[0].SamplePoints();
                    return new MultiCurve(ftr.CoordSys, CurveSegmentType.Linear, pts);
                }
            }
            else if (ftr is MapInfo.Geometry.Rectangle)
            {
                var rc = ftr as MapInfo.Geometry.Rectangle;
                var pts = new List<DPoint>();
                pts.AddRange(rc.Data.Corners());
                pts.Add(pts[0]);
                return new MultiCurve(ftr.CoordSys, CurveSegmentType.Linear, pts.ToArray());
            }
            else if (ftr is MultiCurve)
            {
                return (MultiCurve)ftr;
            }
            return null;
        }

二、取图元的拐点

        /// <summary>
        /// 取图元的拐点
        /// </summary>
        /// <param name="ftr">图元</param>
        /// <returns></returns>
        internal static List<DPoint> GetBorderNode(FeatureGeometry ftr)
        {
            var list = new List<DPoint>();
            if (ftr is MultiPolygon)
            {
                var polygon = ((MultiPolygon)ftr)[0];
                var pts = polygon.Exterior[0].SamplePoints();
                list.AddRange(pts);
            }
            else if (ftr is MultiCurve)
            {
                var multiCurve = (MultiCurve)ftr;
                foreach (Curve cv in multiCurve)
                {
                    list.AddRange(cv.SamplePoints());
                }
            }
            return list;
        }


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值