PLM之家PLMHome-工业软件践行者

[二次开发源码] 【二次开发源码】一种基于点投影,获取投影原始点的方法

[复制链接]

2023-2-28 20:27:29 1141 0

admin 发表于 2023-2-28 20:27:29 |阅读模式

admin 楼主

2023-2-28 20:27:29

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x

) v/ `& ]# W3 k7 z( c. t6 j3 u4 L5 z1 L
6 |# L9 U+ b6 x& U- M
【二次开发源码】一种基于点投影,获取投影原始点的方法
& n- _! k' g* u* I
) ^4 b8 W3 }2 d5 K一直斜边和一个直边的向量,单位向量可以通过dot 获取 夹角' f3 y9 d- F/ X& x. I4 U( I
然后通过勾股定理,计算得到长边值,最后进行基于点的affine,即可获取斜边向量; B! _  k4 G- P8 |5 M: S1 S' s

' M. v+ }1 ?( K' e- H

  1. 0 X7 f5 Z$ ^% n3 r
  2. //这里仅仅考虑Z轴方向
    5 m# j; V! {' F( r  s
  3. void Get_Projection_OrignalPoint(double basePoint[3],double maxZValue,double projectOrignialUnitDir[3], double newOriginalPoint[3]); ?1 o' ~) @$ M9 g" k% e" A( |
  4. {
    / H" t, L9 C+ ~& c
  5.         double dotResult;
    + z5 o. r& U8 l# {4 l# o6 ^6 B
  6.         double longDistance;
    2 m1 N+ W1 R% P
  7.         double zDir[3] = { 0.0,0.0,1.0 };
    . F9 q+ D; h: J& f
  8.         //直线距离) h6 l! r6 d/ u2 o8 z
  9.         double deltaProjectDistance = fabs(maxZValue - basePoint[2]);8 b& [+ Y. _& ^5 q1 @, @  k

  10. " M2 B4 `/ U5 z$ B2 p$ ?
  11.         Echo("斜度垂直直线距离:%.3f maxZValue:%.3f", deltaProjectDistance, maxZValue);( L( R7 Q. Y6 w, j. C
  12. 2 r' j- [% |0 P$ r0 F5 p$ Y
  13.         if ( EQ_is_eq(deltaProjectDistance,0.0,MINTOL)) //就是最高点 ,直接返回9 }, Z- o/ Y. G( t5 y# C2 g- V$ d
  14.         {
    $ W7 Q2 r" @; O
  15.                 UF_VEC3_copy(basePoint, newOriginalPoint);) |- f; L% n9 z6 |
  16.                 return;
    ; @  J) ~4 X) t8 U0 c% C/ p
  17.         }" d! @; }# N, m9 E+ `4 _" {
  18. , i2 N6 k9 ]0 \/ m+ T! k3 d! q
  19.         //计算夹角,通过单位矢量; x! ^/ e3 D: x
  20.         //faceDir 可能反向 5 A! u3 \; X* U3 `' k1 B
  21.         UF_VEC3_dot(projectOrignialUnitDir, zDir, &dotResult);
    7 G6 w, J/ I2 g! d* d6 v" g) p
  22.         // cos() faceDir.zDir = |FaceDir||ZDir|cos(angle)
    ' @4 l. D4 C1 R% A6 F  j$ v
  23.         double cosAngle = fabs(dotResult);
    8 S  D, v% j. @1 ~
  24.         " v& U* R+ L( v& c& `2 x' D4 C% d
  25.         //斜边距离6 H( k- p- M) ~  d3 k
  26.         if (EQ_is_zero(cosAngle, MINTOL))8 e8 C" ?' e+ ]; i/ ]
  27.         {4 |% Q0 p; X3 \% J5 X0 P  Q. \7 J, q
  28.                 longDistance = deltaProjectDistance;) n4 y5 n% X% c' ^2 X
  29.         }+ x/ p# t6 b5 L1 _8 B" Z! o
  30.         else
    7 p$ J) |) o6 u' s/ K
  31.         {# ^. i# x; s; u# z0 a/ U  u8 |
  32.                 longDistance = deltaProjectDistance / cosAngle;
    : i8 P, t" V  l; f
  33.         }! Q" \& y/ F6 e% c
  34.        
    # {( B$ C: t/ e' `- R. _) U8 G2 G
  35.         //这里可能出现方向相反,我们需要进行一次判定
    " t# W* K9 i, L+ k  |. V1 I

  36. 5 c! O3 F) T. g" N
  37.         UF_VEC3_affine_comb(basePoint, longDistance, projectOrignialUnitDir, newOriginalPoint);
    $ o% T; H/ q4 k9 X0 o

  38. 4 o, p# r- v4 f, N; n4 m0 I
  39.         Echo("maxZValue: %f ,newOriginalPoint[2]:%.3f", maxZValue, newOriginalPoint[2]);' ?, H1 E0 Q6 s" z/ Y

  40. ( v( ]2 q5 m- M
  41.         if (!EQ_is_eq(maxZValue,newOriginalPoint[2],MINTOL))
    / U5 ^/ e/ J, {7 R: K
  42.         {
    9 ~) E4 q1 ?1 T  `
  43.                 UF_VEC3_affine_comb(basePoint, -longDistance, projectOrignialUnitDir, newOriginalPoint);
    * l/ g/ }9 [* ]6 \* c
  44.         }
    . o& I3 _9 g: D4 ^2 a5 Y/ {6 [

  45. 7 e8 V' y9 `% j

  46. , u0 j" |& ?% e: _" i
  47.         Echo("cosAngle: %f ,longDistance:%.3f", cosAngle, longDistance);
    ( \+ B  Z* j* z* a
  48. }
复制代码

2 {* w" v8 e% ?4 H) v6 ?2 X0 B
% H, k! @3 N% P6 a+ [5 K! A+ L
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了