随笔 - 833  文章 - 1  评论 - 106  阅读 - 200万

光线与椭球体相交 求交点 算法

bool ClipsEllipSimple(double AAxis,double BAxis,double CAxis, //椭圆的三个轴长
     double x1,double y1,double z1, //直线的一个端点
     double x2,double y2,double z2,osg::Vec3d* out_pt1,osg::Vec3d* out_pt2) //直线的另一个端点
    {
        double ta,tb,tc; //参数方程的参数
        double delt; //判断一元二次方程是否有根,求交用
        double ASquare,BSquare,CSquare; //分别代表椭球三轴的平方
        ASquare=AAxis*AAxis;
        BSquare=BAxis*BAxis;
        CSquare=CAxis*CAxis;
        double A = (y2 -y1) / (x2 - x1);
        double B = (z2 -z1) / (x2 - x1);
        ta = BSquare * CSquare + A * A * ASquare * CSquare + B * B * ASquare * BSquare;
        tb = 2 * y1 * ASquare * CSquare * A - 2 * x1 * A * A * ASquare * CSquare + 2 * z1 * ASquare * BSquare * B - 2 * x1 * B * B * ASquare * BSquare;
        tc = ASquare * CSquare* y1 * y1 - 2 * y1 * ASquare * CSquare * A * x1 + A * A * x1 * x1 * ASquare * CSquare +
                    ASquare * BSquare * z1 * z1 - 2 * z1 * ASquare * BSquare * B * x1 + B * B * x1 * x1 * ASquare * BSquare - ASquare * BSquare * CSquare;
        delt = tb*tb - 4*ta*tc;
        double t1,t2;
        if(delt>=0)
        {
            t1=(-tb+sqrt(delt))/(2*ta);
            t2=(-tb-sqrt(delt))/(2*ta);
            double x =t1;
            double y = y1 + A * (x - x1);
            double z = z1 + B * (x - x1);
            *out_pt1 = osg::Vec3d(x,y,z);
            x =t2;
            y = y1 + A * (x - x1);
            z = z1 + B * (x - x1);
            *out_pt2 = osg::Vec3d(x,y,z);
            return true;
        }   
        else
            return false;
    }

posted on   3D入魔  阅读(1045)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2011-02-25 ArcGIS Engine基础开发教程(转)
< 2013年2月 >
27 28 29 30 31 1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 1 2
3 4 5 6 7 8 9

点击右上角即可分享
微信分享提示