找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 675|回复: 0

[每日一码] 系统变量viewtwist值如何通过数学方法计算?

[复制链接]

已领礼包: 13个

财富等级: 恭喜发财

发表于 2016-9-27 10:05:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
系统变量viewtwist 表示的是WCS下相对于观察方向的up向量和DCS下实际的视口UP向量之间的夹角。

下面代码使用view 方向,构建一个UP 向量(垂直于观察方向),然后计算出实际视口的UP向量,然后测量出他们之间的夹角。

  1. #define PI  3.14159265359

  2. // utility to calculate the viewtwist to illustrate how this works
  3. //
  4. void getViewTwist()
  5. {
  6.     // 首先获得view方向
  7.     struct resbuf viewRb;
  8.     acedGetVar( "VIEWDIR", &viewRb );

  9.     AcGeVector3d dirVector = asVec3d(viewRb.resval.rpoint);
  10.     // 确保在WCS下
  11.     acdbUcs2Wcs( asDblArray( dirVector), asDblArray( dirVector), Adesk::kTrue );

  12.     //计算这个VIEW方向向量的缺省的  upVector
  13.     AcGeVector3d sideVector = dirVector.perpVector();
  14.     AcGeVector3d upVector = dirVector.crossProduct(sideVector).normal();

  15.     ads_point UpVec;
  16.     asVec3d( UpVec) = upVector;

  17.     // 计算实际的 upVector, by applying the view transformation.
  18.     struct resbuf from, to;
  19.     from.restype = RTSHORT;
  20.     from.resval.rint = 0;    // WCS
  21.     to.restype = RTSHORT;
  22.     to.resval.rint = 2;   // MS DCS
  23.     acedTrans(UpVec, &from, &to, TRUE, UpVec);

  24.     // 计算 twist angle
  25.     double safeViewTwist;
  26.     safeViewTwist = atan2(UpVec[Y],UpVec[X]) - PI/2 ;

  27.     // 在数学上,我们已经完成了计算,有个问题是系统吧变量VIEWTWIST的值在0到2PI之间,所以我们继续

  28.     //如果计算结果为负数
  29.     if( safeViewTwist < -1e-6 )
  30.         safeViewTwist+= (PI * 2.0 );
  31.     acutPrintf("\nsafeViewTwist: %f", safeViewTwist);

  32.     // 下面来检查下计算结果和系统变量VIEWTWIST值进行比较是否一样。
  33.     struct resbuf viewTwist;
  34.     acedGetVar("VIEWTWIST", &viewTwist );
  35.     acutPrintf("\nReal VIEWTWIST: %f", viewTwist.resval.rreal );
  36. }


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-26 07:22 , Processed in 0.371948 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表