乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 53|回复: 3

取得选择集包围盒

[复制链接]

84

主题

543

帖子

12

银币

中流砥柱

Rank: 25

铜币
886
发表于 2011-6-18 16:57:00 | 显示全部楼层 |阅读模式
这是我在网上下载的一个[取得选择集包围盒]子程序,调试不能通过,请高手帮看看是什么原因
BOOL GetSSExtents(ads_name ss, ads_point &maxpt, ads_point &minpt)
{
long len;
int ret=ads_sslength(ss,&len);
if(ret!=RTNORM||lengetGeomExtents(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;
}  
回复

使用道具 举报

56

主题

346

帖子

68

银币

中流砥柱

Rank: 25

铜币
512
发表于 2011-6-18 22:40:00 | 显示全部楼层
楼主的代码都抄的错误百出。
这里给出修改后的。以后说不定也可以用的着。
  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 || lengetGeomExtents(extent) !=Acad::eOk)
  6.   {
  7.    continue;
  8.   }
  9.   
  10.   pt1=extent.maxPoint();
  11.   pt2=extent.minPoint();
  12.   pEnt->close();
  13.   if (maxpt[X]==LDBL_MAX)
  14.   {
  15.    maxpt[X]=pt1.x;
  16.    maxpt[Y]=pt1.y;
  17.       maxpt[Z]=pt1.z;
  18.    minpt[X]=pt2.x;
  19.    minpt[Y]=pt2.y;
  20.    minpt[Z]=pt2.z;
  21.   }
  22.   //下面的段应该写成函数的,太啰嗦了。
  23.   if (pt1.x > maxpt[X]) maxpt[X]=pt1.x;
  24.   if (pt1.y > maxpt[Y]) maxpt[Y]=pt1.y;
  25.   if (pt1.z > maxpt[Z]) maxpt[Z]=pt1.z;
  26.   if (pt2.x < minpt[X]) minpt[X]=pt2.x;
  27.   if (pt2.y < minpt[Y]) minpt[Y]=pt2.y;
  28.   if (pt2.z < minpt[Z]) minpt[Z]=pt2.z;
  29. }
  30. return Acad::eOk;
  31. }  

回复

使用道具 举报

56

主题

346

帖子

68

银币

中流砥柱

Rank: 25

铜币
512
发表于 2011-6-18 22:42:00 | 显示全部楼层

回复
简单的测试代码:
  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);
回复

使用道具 举报

84

主题

543

帖子

12

银币

中流砥柱

Rank: 25

铜币
886
发表于 2011-6-19 09:11:00 | 显示全部楼层

非常感谢你的指导和热心,我再去试试
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-2-5 16:56 , Processed in 0.207084 second(s), 71 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表