田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 11 48
     12
3456789
10111213141516
17181920212223
24252627282930


站点统计

最新评论



Python AutoCAD 系统设置 注册钩子函数的
未知 GetPolyLineCentroid   [ 日期:2021-08-29 ]   [ 来自:本站原创 ]  HTML
public static Point2d GetPolyLineCentroid(Polyline polyline) 
    { 
     double area = polyline.Area; 
     double cx = 0.0; 
     double cy = 0.0; 
     double X0 = 0.0; 
     double Y0 = 0.0; 
     double X1 = 0.0; 
     double Y1 = 0.0; 

     for (int i = 0; i < polyline.NumberOfVertices - 1; i++) 
     { 
      X0 = polyline.GetPoint2dAt(i).X; 
      Y0 = polyline.GetPoint2dAt(i).Y; 
      X1 = polyline.GetPoint2dAt(i + 1).X; 
      Y1 = polyline.GetPoint2dAt(i + 1).Y; 

      cx += (X0 + X1) * (X0 * Y1 - X1 * Y0); 
      cy += (Y0 + Y1) * (X0 * Y1 - X1 * Y0); 
     } 

     // last Point 
     int Lv = polyline.NumberOfVertices - 1; 
     X0 = polyline.GetPoint2dAt(Lv).X; 
     Y0 = polyline.GetPoint2dAt(Lv).Y; 
     X1 = polyline.GetPoint2dAt(0).X; 
     Y1 = polyline.GetPoint2dAt(0).Y; 

     cx += (X0 + X1) * (X0 * Y1 - X1 * Y0); 
     cy += (Y0 + Y1) * (X0 * Y1 - X1 * Y0); 


     cx /= 6 * area; 
     cy /= 6 * area; 

     return new Point2d(cx, cy); 
    } 


public static Point2d GetPolyLineCentroid(DBObjectCollection objs) 

    Solid3d Solid = new Solid3d(); 
    Solid.Extrude(((Region)Region.CreateFromCurves(objs)[0]), 1, 0); 
    Point2d centroid = new Point2d(Solid.MassProperties.Centroid.X, Solid.MassProperties.Centroid.Y); 
    Solid.Dispose(); 
    return centroid; 
}



暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:1*1=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©