明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2399|回复: 3

取得选择集包围盒

[复制链接]
发表于 2011-6-18 16:57:04 | 显示全部楼层 |阅读模式
本帖最后由 chpmould 于 2011-6-18 16:57 编辑

这是我在网上下载的一个[取得选择集包围盒]子程序,调试不能通过,请高手帮看看是什么原因
BOOL GetSSExtents(ads_name ss, ads_point &maxpt, ads_point &minpt)
{
long len;
int ret=ads_sslength(ss,&len);
if(ret!=RTNORM||len<1) return FALSE;
AcDbObjectId objId;
ads_name ename;
AcDbEntity *pEnt;
AcDbExtents extent;
AcGePoint3d pt1,pt2;
ads_ssname (ss, 0, ename);
acdbGetObjectId(objId,ename);
acdbOpenObject(pEnt,objId,AcDb::kForRead);
pEnt->getGeomExtents(extent);
pt1=extent.maxPoint();
pt2=extent.minPoint();
pEnt->close();
//主要是这里调试不能通过,请帮看看是什么原因
for(int i=0;igetGeomExtents(extent);
  if(pt1[X]extent.minPoint()[X]||pt2[Y]>extent.minPoint()[Y])
   pt2=extent.minPoint();
//主要是这里调试不能通过,请帮看看是什么原因
  pEnt->close();
}
maxpt[X]=pt1[X];
maxpt[Y]=pt1[Y];
maxpt[Z]=pt1[Z];

minpt[X]=pt2[X];
minpt[Y]=pt2[Y];
minpt[Z]=pt2[Z];
return TRUE;
}  

发表于 2011-6-18 22:40:55 | 显示全部楼层
楼主的代码都抄的错误百出。

这里给出修改后的。以后说不定也可以用的着。

  1. Acad::ErrorStatus GetSSExtents(ads_name ss, ads_point &maxpt, ads_point &minpt)
  2. {
  3. long len;
  4. int ret=ads_sslength(ss,&len);
  5. if(ret!=RTNORM || len<1)
  6.   return Acad::eInvalidInput;
  7. maxpt[X]= LDBL_MAX;
  8. //maxpt[Y]= LDBL_MAX;
  9. //maxpt[Z]= LDBL_MAX;
  10. //minpt[X]= LDBL_MIN;
  11. //minpt[Y]= LDBL_MIN;
  12. //maxpt[Z]= LDBL_MIN;
  13. AcDbObjectId objId;
  14. ads_name ename;
  15. AcDbEntity *pEnt=NULL;
  16. AcDbExtents extent;
  17. AcGePoint3d pt1,pt2;
  18. for (long i = 0;i < len;i++)
  19. {
  20.   if (acedSSName(ss, i, ename) != RTNORM || \
  21.    acdbGetObjectId(objId,ename) !=Acad::eOk || \
  22.    acdbOpenObject(pEnt,objId,AcDb::kForRead) !=Acad::eOk || \
  23.    pEnt->getGeomExtents(extent) !=Acad::eOk)
  24.   {
  25.    continue;
  26.   }
  27.   
  28.   pt1=extent.maxPoint();
  29.   pt2=extent.minPoint();
  30.   pEnt->close();
  31.   if (maxpt[X]==LDBL_MAX)
  32.   {
  33.    maxpt[X]=pt1.x;
  34.    maxpt[Y]=pt1.y;
  35.       maxpt[Z]=pt1.z;
  36.    minpt[X]=pt2.x;
  37.    minpt[Y]=pt2.y;
  38.    minpt[Z]=pt2.z;
  39.   }
  40.   //下面的段应该写成函数的,太啰嗦了。
  41.   if (pt1.x > maxpt[X]) maxpt[X]=pt1.x;
  42.   if (pt1.y > maxpt[Y]) maxpt[Y]=pt1.y;
  43.   if (pt1.z > maxpt[Z]) maxpt[Z]=pt1.z;
  44.   if (pt2.x < minpt[X]) minpt[X]=pt2.x;
  45.   if (pt2.y < minpt[Y]) minpt[Y]=pt2.y;
  46.   if (pt2.z < minpt[Z]) minpt[Z]=pt2.z;
  47. }
  48. return Acad::eOk;
  49. }  

发表于 2011-6-18 22:42:09 | 显示全部楼层
本帖最后由 highflybird 于 2011-6-18 22:42 编辑

回复 chpmould 的帖子

简单的测试代码:
  1.                ads_name sel;
  2.                 int ret=acedSSGet(NULL,NULL,NULL,NULL,sel);
  3.                 if( ret!=RTNORM)
  4.                 {
  5.                         acedSSFree(sel);
  6.                         return;
  7.                 }
  8.                 ads_point maxpt,minpt;
  9.                 if (GetSSExtents(sel,maxpt,minpt) != Acad::eOk)
  10.                 {
  11.                         acutPrintf(_T("\n获取失败,请检查选择集!"));
  12.                         return;
  13.                 }
  14.                 acedGrDraw(minpt,maxpt,1,1);
 楼主| 发表于 2011-6-19 09:11:49 | 显示全部楼层
highflybird 发表于 2011-6-18 22:40
楼主的代码都抄的错误百出。

这里给出修改后的。以后说不定也可以用的着。

非常感谢你的指导和热心,我再去试试
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-29 03:52 , Processed in 0.169861 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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