乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 11|回复: 0

三点创建圆弧(由于开发需要,将VB版本改成c#版本)

[复制链接]

4

主题

11

帖子

1

银币

初来乍到

Rank: 1

铜币
27
发表于 2012-2-28 16:49:00 | 显示全部楼层 |阅读模式
#region 根据三点创建圆弧
        private Point3d GetArcCenter(Point3d pt1,Point3d pt2,Point3d pt3,ref double radius)
        {
            double xysm, xyse, xy;
            double[] m_ArcCenter = new double[3];
            xy = Math.Pow(pt1.X, 2) + Math.Pow(pt1.Y, 2);
            xyse = xy - Math.Pow(pt3.X, 2) - Math.Pow(pt3.Y, 2);
            xysm = xy - Math.Pow(pt2.X, 2) - Math.Pow(pt2.Y, 2);
            xy = (pt1.X - pt2.X) * (pt1.Y - pt3.Y) - (pt1.X - pt3.X) * (pt1.Y - pt2.Y);
            // 判断参数有效性
            if (Math.Abs(xy) 0 && Y > 0)||(X > 0 && Y  0) || (X  0)
                {
                    CalculateLineAngle = Math.PI / 2;
                }
            }
            else if (Y == 0)
            {
                if (X  0)
                {
                    CalculateLineAngle = 0;
                }
            }
            else
            {
                ;
            }
            if (Math.Abs(CalculateLineAngle - 0)

                               
登录/注册后可看大图

该贴已经同步到
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-15 21:13 , Processed in 0.373080 second(s), 54 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表