c语言实现平面和直线的交点,OpenGL 直线和直线 直线和平面求交点

OpenGL 直线和直线   直线和平面求交点

关于头文件myglbase.h 和 myglbase.cpp的链接

http://blog.csdn.net/rorger/archive/2011/04/19/6334489.aspx

或者点此下载:

http://rorger.download.csdn.net/

#include "myglbase.h" #include "iostream" using namespace std ; /* R(t)=A + c*tHit; //直线参数表示 B为另一条上一点,n是另一条直线法向量 PHit为交点 */ int GetLinesIntersect(Point2 A, Vector2 c,Point2 B,Vector2 n, double& tHit,Point2& PHit) { if (n*c==0) { //射线与直线平行 return 0 ; } else { tHit= (n*(B-A))/(n*c); PHit=A+c*tHit; if(n*c >0) { return 1; //射线沿着法向量方向 } else { return -1 ; //射线与法向量相反 } } } // R(t)=A + c*tHit; //直线参数表示 // B为面上一点,n是另一面法向量 // PHit为交点 int GetLinePanelIntersec(Point3 A, Vector3 c,Point3 B,Vector3 n, double& tHit,Point3& PHit) { if (n*c==0) { //射线与直线平行 return 0 ; } else { tHit= (n*(B-A))/(n*c); PHit=A+c*tHit; if(n*c >0) { return 1; //射线沿着法向量方向 } else { return -1 ; //射线与法向量相反 } } } template int TGetLinesOrPanel(TPoint A, TVector c,TPoint B,TVector n, double& tHit,TPoint& PHit) { if (n*c==0) { //射线与直线平行 return 0 ; } else { tHit= (n*(B-A))/(n*c); PHit=A+c*tHit; if(n*c >0) { return 1; //射线沿着法向量方向 } else { return -1 ; //射线与法向量相反 } } } void testLinesIntersect(Point2 A, Vector2 c,Point2 B,Vector2 n, double& tHit,Point2& PHit) { int result = GetLinesIntersect(A,c,B,n,tHit,PHit); if (result == 0) { cout << "射线和直线平行"<0) { cout <0) { cout < void testTGetLinesOrPanel(TPoint A, TVector c,TPoint B,TVector n, double& tHit,TPoint& PHit) { int result = TGetLinesOrPanel(A,c,B,n,tHit,PHit); if (result == 0) { cout << "射线与之平行"<0) { cout <

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值