Cad求多段线中心点(顶点平均值) C#

using Autodesk.AutoCAD.DatabaseServices;

using Autodesk.AutoCAD.Geometry;

 

namespace PolylineUtility

{

    public static class PolylineHelper

    {

        /// <summary>

        /// 计算多段线顶点坐标的平均值(XYZ三维坐标)

        /// </summary>

        /// <param name="polyline">目标多段线对象</param>

        /// <returns>顶点坐标平均值的Point3d对象(顶点数为0时返回原点(0,0,0))</returns>

        /// <exception cref="ArgumentNullException">当输入的polyline为null时抛出</exception>

        public static Point3d GetVertexAverage(this Polyline polyline)

        {

            // 验证输入对象非空

            if (polyline == null)

                throw new ArgumentNullException(nameof(polyline), "输入的多段线对象不能为null");

 

            int vertexCount = polyline.NumberOfVertices;

            if (vertexCount == 0)

                return Point3d.Origin; // 无顶点时返回原点

 

            double totalX = 0, totalY = 0, totalZ = 0;

 

            // 遍历所有顶点并累加坐标

            for (int i = 0; i < vertexCount; i++)

            {

                Point3d vertex = polyline.GetPoint3dAt(i);

                totalX += vertex.X;

                totalY += vertex.Y;

                totalZ += vertex.Z; // 包含Z坐标,支持三维多段线

            }

 

            // 计算平均值

            double avgX = totalX / vertexCount;

            double avgY = totalY / vertexCount;

            double avgZ = totalZ / vertexCount;

 

            return new Point3d(avgX, avgY, avgZ);

        }

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山水CAD插件定制

你的鼓励是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值