tjie_328 发表于 2012-2-6 09:05:53

紧急求助:求交点的代码总是死机,哪位知道帮忙看下!

本帖最后由 tjie_328 于 2012-2-6 09:10 编辑

以下是一段求交点的代码:
int ret;
AcDbObjectId entId;            //
//AcDbObjectIdArray curveIds_h;// 混凝土边界曲线ID定义为类变量
AcDbCurve *pCurve=NULL;      //混凝土边界曲线指针
AcDbLine *pLine =NULL;         //零应力切割线指针
AcDbEntity *pEnt1=NULL;
AcGePoint3dArraypointarray;//交点数组
lineId_0=CreateLine();
acdbOpenObject(pLine, lineId_0, AcDb::kForRead ); //零应力线ID
//acutPrintf(_T("\nx=%f"),length);
acutPrintf("\n选择集对象个数为%d",curveIds_h.length());
for (int i = 0; i < curveIds_h.length(); i++)
{                                                //for循环开始
entId=curveIds_h;
acdbOpenAcDbEntity(pEnt1, entId, AcDb::kForWrite);
if (pEnt1->isKindOf(AcDbCurve::desc()))          {
pCurve = AcDbCurve::cast(pEnt1);
pLine->intersectWith(pCurve,AcDb::kExtendThis,pointarray,0,0);
ret= pointarray.length();
acutPrintf(_T("\nx=%d"),ret);

pCurve->close();
pEnt1->close();
pLine->close();
}


运行总是出问题推出,不知道怎么回事,哪位知道请指点一下!

hgf876 发表于 2012-2-6 14:21:05


pLine->close();这个应该在for完成后

pCurve->close();
pEnt1->close();
这两个是重复的,只要pEnt1->close();就可以了,放在if()外面后面


页: [1]
查看完整版本: 紧急求助:求交点的代码总是死机,哪位知道帮忙看下!