天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 67|回复: 0

ARX 选择集获得所有图形 遍历 实例 备忘

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
给图形实体,返回与当前图形中,直线实体相交的交点数组、直线方向向量
参数:曲线实体,2dpoint数组,三维向量
static void GetLineNum(AcDbCurve* pLine,AcGePoint3dArray& ptArr,AcGeVector3d& v)
{
遍历所有实体
ads_name ssName;选择集名称
acedSSGet(_T("X"),NULL,NULL,NULL,ssName);
long len = 0;
acedSSLength(ssName,&len);


ads_name entName;
AcDbObjectId id;
AcDbEntity* pEnt = NULL;
AcDbCurve* pCur = NULL;
AcGePoint3dArray ptSecArr;交点集合


for (int i=0;i<len;i++)
{
if (acedSSName(ssName, i, entName) == RTNORM)
{


根据名称得到ID
acdbGetObjectId(id,entName);


以读模式打开,根据ID索引到对象,并打开ENTITY
acdbOpenObject(pEnt,id,AcDb::OpenMode::kForRead);
if (pEnt->isKindOf(AcDbCurve::desc()))
{
pCur = (AcDbCurve*)pEnt;
pCur->intersectWith(pLine,AcDb::Intersect::kOnBothOperands,ptSecArr);
if (ptSecArr.length() > 0)
{
拿出第一个交点(两直线相交只可能有这一个交点)
AcGePoint3d pt3d (ptSecArr.at(0));
添加交点
ptArr.append(pt3d);
ptSecArr.removeAll();
pCur->getFirstDeriv(pt3d,v);
//acutPrintf(_T("\n道路方向向量:[x]: %.2f,[y] : %.2f, [z] : %.2f"),v[X],v[Y],v[Z]);
}
pCur->close();
}
}
}
}

 

 

 

 

ARX 选择集获得所有图形 遍历 实例 备忘
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 12:36 , Processed in 0.114896 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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