计算空间点到平面的投影点坐标(代码)

计算空间点到平面的投影点坐标(代码)1 pp 为所求的投影点坐标 2 A 为平面上任意已知点 3 n 为平面上的法线 n 的计算方法 一般会已知平面上两个以上的点坐标 例如我是为了求点在任意三角形上的投影点 我当然会知道三角形的三个点坐标 通过其中两个点坐标可以求出法向量 n 假设知道三角形的三个顶点 A x y z B x y z C x y z AB Bx Ax By Ay Bz Az

0、p为平面外
任意一点
1、pp为所求的
投影点坐标
2、A为平面上任意
已知点
3、n为平面上的
法线
n的计算方法:
一般会已知平面上两个以上的点坐标,例如我是为了求点在任意三角形上的投影点,我当然会
知道三角形的三个点坐标,通过其中两个点坐标可以求出法向量n。
假设已知平面为三角形,其三个顶点分别为A(Ax,Ay,Az),B(Bx,By,Bz),C(Cx,Cy,Cz)
AB = (Bx-Ax,By-Ay,Bz-Az);AB为向量;
AC = (Cx-Ax,Cy-Ay,Cz-Az);AC为向量;
n为法向量
        n = AB \times AC   =>     
        nx = ABy\cdot ACz-ABz\cdot ACy
        ny = ABz\cdot ACx-ABx\cdot ACz
        nz = ABx\cdot ACy-ABy\cdot ACx
 
注意:以上的AxA点的x坐标;
ABx指的是AB向量的x分量
 
下面是我算出的现成求法,由于计算太费时间,而且容易出错,就给大伙分享出来啦
希望能帮到大伙~
代码1:

pp.x = (n.x*n.y*A.y + n.y*n.y*p.x - n.x*n.y*p.y + n.x*n.z*A.z + n.z*n.z*p.x - \ n.x*n.z*p.z + n.x*n.x*A.x) / (n.x*n.x + n.y*n.y + n.z*n.z);

pp.y = (n.y*n.z*A.z + n.z*n.z*p.y - n.y*n.z*p.z + n.y*n.x*A.x + n.x*n.x*p.y - \ n.x*n.y*p.x + n.y*n.y*A.y) / (n.x*n.x + n.y*n.y + n.z*n.z);

pp.z = (n.x*A.x*n.z + n.x*n.x*p.z - n.x*p.x*n.z + n.y*A.y*n.z + n.y*n.y*p.z - \ n.y*p.y*n.z + n.z*n.z*A.z) / (n.x*n.x + n.y*n.y + n.z*n.z);
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/207397.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午1:55
下一篇 2026年3月19日 下午1:55


相关推荐

  • vue解决跨域_java跨域解决方案

    vue解决跨域_java跨域解决方案现阶段跨域方式有很多种,但是基本思想只有两种:绕过同源策略:历史遗留的产物,虽然思想很好,但是局限性太大(仅支持、因为数据是在中,所以携带数据小)。:通过反向代理绕过去,这是很完美的解决方案,加上会给服务器增加一点压力,不过这点压力问题并不大[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ddoEgRFd-1656482203293)(https://juejin.cn/)][外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4M4avsX0-1

    2022年9月30日
    5
  • PO:如何更新DEV中PO到QAS再到PRD「建议收藏」

    PO:如何更新DEV中PO到QAS再到PRD「建议收藏」1,首先PO中的单个对象最好以文件夹方式存放,这样便于管理和上传,将DEV中需要上传的文件夹导出: 2.勾选第四个: 可以直接将该文件拖拽过来 之后直接FINISH. 3.打开QAS的ESR,将

    2022年6月28日
    38
  • Python 数组截取

    Python 数组截取#数据源names=[‘a’,’b’,’c’,’d’,’e’,’f’]#正常获取print(names[1])#b#截取print(names[0:3])#[‘a’,’b’,’c’]print(names[3:10])#[‘d’,’e’,’f’]#截取:从指定开始直接到指定结尾print(names[3:])#[‘d’,’e’,’f’]print(names[:3])#[‘a’,’b’,’c’]#倒着切print(na

    2022年6月10日
    76
  • Selenium WebDriver下载与安装[通俗易懂]

    Selenium WebDriver下载与安装[通俗易懂]1.python(anaconda环境)condainfo–envsactivateuntitled2.pip/condainstallselenium3.seleniumdriver(放在anaconda环境path中)Chrome(32位)http://chromedriver.storage.proxy.ustclug.org/index.htmlFire…

    2026年1月23日
    5
  • 【Agent】skill介绍和使用教程

    【Agent】skill介绍和使用教程

    2026年3月15日
    3
  • 绘图杂记【1】Python、R等绘图

    绘图杂记【1】Python、R等绘图离散分布水平条形图Discretedistributionashorizontalbarchartimportnumpyasnpimportmatplotlib.pyplotaspltcategory_names=[‘Stronglydisagree’,’Disagree’,’Neitheragreenordisagree’,’Agree’,’Stronglyagree’]results={‘Que

    2022年5月3日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号