admin 发表于 2024-3-14 20:06:28

[每日一码] ARX 选择集获得所有图形然后遍历

////给图形实体,返回与当前图形中,直线实体相交的交点数组、直线方向向量
////参数:曲线实体,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道路方向向量:: %.2f, : %.2f, : %.2f"),v,v,v);
                              }
                              pCur->close();
                        }
                }
      }
}   
页: [1]
查看完整版本: [每日一码] ARX 选择集获得所有图形然后遍历