找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2392|回复: 3

[公告] [ARX函数]:如何在UCS下获得当前鼠标位置的座标

[复制链接]

已领礼包: 145个

财富等级: 日进斗金

发表于 2002-1-28 15:16:24 | 显示全部楼层 |阅读模式

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

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

×
下面代码可以获得鼠标位置的UCS下的座标,显示的和ACAD状态栏内的相同,有兴趣可以验证。

用这个函数替换...\ObjectARX\SAMPLES\MFCSAMPS目录下的PRETRANSLATE程序中的filterMouse() 函数,编译后,加载,然后用命令WMOUSE 执行。

  1. BOOL filterMouse(MSG *pMsg)
  2. {
  3.    if( pMsg->message == WM_MOUSEMOVE )
  4.    {
  5.                 acedDwgPoint cpt;
  6.                 ads_point ptDCS, ptWCS, norm;
  7.                 AcGePoint3d  origin;
  8.                 AcGeVector3d e0, e1, e2;
  9.                 AcGeMatrix3d  matUcs2Wcs, matWcs2Ucs;

  10.                 // 1: 获得显示座标系下的鼠标位置座标
  11.                 CPoint cPnt (pMsg->lParam) ;
  12.                 acedCoordFromPixelToWorld (cPnt, cpt) ;
  13.                 ads_point_set ( cpt, ptDCS );         
  14.                 //ads_printf ( "\nMouse in Ucs %f, %f, %f",  ptDCS[X], ptDCS[Y],
  15. ptDCS[Z] );
  16.                 //return FALSE;
  17.                 // 2: 转换鼠标座标从显示座标系到UCS
  18.                 //
  19.                 // 使用acdbEcs2Ucs 函数,参数是VIEWDIR 系统变量作为NOMAL向量
  20.                 // (Sure we have to transform the VIEWDIR value from UCS to WCS
  21.                 //
  22.                 struct resbuf rbview;
  23.                 ads_getvar( "viewdir", &rbview );
  24.                 ads_point_set( rbview.resval.rpoint, norm );

  25.                 // If the view direction is 0, 0, 1, then
  26. acedCoordFromPixelToWorld()
  27.                 // needs special handling -> we only have to translate the the
  28. point
  29.                 // by the distance the origin of the current UCS was moved
  30.                 double tol = 1e-10;
  31.                 if ((fabs(norm[X]) < tol) && (fabs(norm[Y]) < tol) &&
  32. ((fabs(norm[Z]) - 1.0) < tol)) {
  33.                         AcGePoint3d acadPt;
  34.                         acadPt.x = cpt[0];
  35.                         acadPt.y = cpt[1];
  36.                         acadPt.z = cpt[2];

  37.                         acdbUcsMatrix ( matUcs2Wcs );                 
  38.                         matUcs2Wcs.invert();
  39.                         matUcs2Wcs.getCoordSystem( origin, e0, e1, e2);

  40.                         acadPt += origin.asVector();
  41.                         ads_printf ( "\nMouse in Ucs %f, %f, %f",  acadPt[X],
  42. acadPt[Y], acadPt[Z] );
  43.                         return FALSE;
  44.                 }
  45.                 //转换 VIEWDIR  到 WCS
  46.                 acdbUcs2Wcs ( norm, norm, Adesk::kTrue );
  47.                 // 转换鼠标座标从DCS 到 WCS
  48.                 acdbEcs2Wcs( ptDCS, ptWCS, norm, Adesk::kTrue );

  49.                 // 3: 获得UCS下鼠标位置的座标
  50.                 //
  51.                 // For this we have to project the WCS coordinates to the UCS
  52. plane using
  53.                 // VIEWDIR 作投影方向.
  54.                 //
  55.                 // 获得 UCS->WCS 转换矩阵
  56.                 acdbUcsMatrix ( matUcs2Wcs );                 
  57.                 matUcs2Wcs.getCoordSystem( origin, e0, e1, e2);
  58.                 // 创建一个当前UCS下的平面
  59.                 //
  60.                 AcGePlane thePlane ( origin, e0, e1);

  61.                 AcGePoint3d  pntMouseInWCS( ptWCS[X], ptWCS[Y], ptWCS[Z] );
  62.                 AcGeVector3d vecViewdir( norm [X], norm [Y], norm [Z] );
  63.                 // 投影转换
  64.                 AcGePoint3d resPnt = pntMouseInWCS.project (thePlane, vecViewdir
  65. );
  66.                 // 转换点的座标到UCS.
  67.                 matWcs2Ucs = matUcs2Wcs.inverse();
  68.                 resPnt.transformBy ( matWcs2Ucs );
  69.                 //
  70.                 //查看ACAD状态行验证
  71.                 ads_printf ( "\nMouse in Ucs %f, %f, %f",  resPnt[X], resPnt[Y],
  72. resPnt[Z] );
  73.         }
  74.         return FALSE; // continue
  75. }


注意:这个函数不能工作在图纸空间,由于acedCoordFromPixelToWorld()全局函数不能在图纸空间内工作。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2002-3-13 07:54:22 | 显示全部楼层
我的编译环境 98 vc6 cad14,编译可以通过,连接会有问题.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2002-3-13 08:17:44 | 显示全部楼层
rxtemplt.obj : error LNK2001: unresolved external symbol "__declspec(dllimport) public: __thiscall AcGePoint2d::AcGePoint2d(double,double)" (__imp_??0AcGePoint2d@@QAE@NN@Z)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

 楼主| 发表于 2002-3-13 08:49:58 | 显示全部楼层
最初由 风中的沙粒 发布
[B]rxtemplt.obj : error LNK2001: unresolved external symbol "__declspec(dllimport) public: __thiscall AcGePoint2d::AcGePoint2d(double,double)" (__imp_??0AcGePoint2d@@QAE@NN@Z) [/B]


几何库libacge.lib你加入到PROJECT的LINK里面了吗?


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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-21 22:48 , Processed in 0.190285 second(s), 37 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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