MapXtreme创建扇形

/// <summary>
        /// 顺时针正北0度->逆时针正东0度
        /// </summary>
        /// <param name="azimuth"></param>
        /// <returns></returns>
        public static int AngleConvertN2E(int azimuth)
        {
            return ((360 - azimuth) + 90) % 360;
        }

/// <summary>
        /// 创建扇形
        /// </summary>
        /// <param name="coordSys">坐标系</param>
        /// <param name="pt">中心点</param>
        /// <param name="radius">半径</param>
        /// <param name="startAngle">起始角</param>
        /// <param name="endAngle">终止角</param>
        /// <returns></returns>
        internal static FeatureGeometry CreateSector(CoordSys coordSys, DPoint pt, double radius, int startAngle, int endAngle)
        {
            FeatureGeometry ftr;
            if (startAngle == 0 && endAngle == 360)
                ftr = new MapInfo.Geometry.Ellipse(coordSys, pt, radius * 0.75, radius * 0.75, DistanceUnit.Meter,
                                                   DistanceType.Spherical);//因为是经纬度坐标系,所以只能用Spherical
            else
            {
                int a2 = AngleConvertN2E(startAngle);
                int a1 = AngleConvertN2E(endAngle);//因为LegacyArc是用的逆时针坐标轴,所以转换后起始位置要交换一下
                var arc = new MapInfo.Geometry.LegacyArc(coordSys, pt, radius, radius, DistanceUnit.Meter,
                                                     DistanceType.Spherical, a1, a2);
                var mc = arc.CreateMultiCurve(100);

                var arcPts = mc[0][0].SamplePoints();

                var linePts = new[] { mc[0].EndPoint, pt, mc[0].StartPoint };

                var pts = new MapInfo.Geometry.DPoint[arcPts.Length - 1 + 3];
                for (int i = 0, j = 0; i < arcPts.Length - 1 + 3; i++)
                {
                    if (i < arcPts.Length - 1)
                        pts[i] = arcPts[i];
                    else
                        pts[i] = linePts[j++];
                }

                ftr = new MultiPolygon(coordSys, CurveSegmentType.Linear, pts);
            }
            return ftr;
        }


效果预览:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值