光线与椭球体相交 求交点 算法
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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
2011-02-25 ArcGIS Engine基础开发教程(转)