iCAx开思工具箱

标题: CAA中CATIGSMIntersect接口的问题 [打印本页]

作者: cupcake    时间: 2005-5-9 16:45
标题: CAA中CATIGSMIntersect接口的问题
各位高手:
CATIGSMIntersect,可以取线线交点,面面交线等,请问怎么样判断得到的到底是交线还是交点?如下:
CATIGSMIntersect_var IntersectionPoint = g_Fact->CreateIntersect(Obj[i+1] , Obj[i-1]);
IntersectionPoint 这个类型怎么转换为CATPoint_var?
  
     
作者: acoka    时间: 2005-5-9 19:55
你可以试试看求它的CATBody,然后找domain, cell,...,  然后看最后的形状是什么
作者: cupcake    时间: 2005-5-9 20:14
怎么求CATBody呢?
作者: acoka    时间: 2005-5-9 23:23
比如你可以写个函数
  
CATBody_var WSHSampleUtil::GetBodyFromFeature( const CATISpecObject_var& ispFeature )
{
   CATBody_var spBody = NULL_var;
   do {
      if( !ispFeature ) {
         break;
      }
      CATIMfBRep_var spBRepOnFeature = ispFeature;
      if( !!spBRepOnFeature ) {
         spBody = spBRepOnFeature->GetBody();
      }
      else {
  ...
      }
      if( !spBody ) {
         break;
      }
   } while(FALSE);
   return spBody;
}
作者: acoka    时间: 2005-5-9 23:46
然后你可以在写一个函数,比如取一个只有一个点组成的body的CATPOint
  
CATPoint_var WSHSampleUtil::FindPointFromBody( const CATBody_var& ispBody )
{
   CATPoint_var spPoint = NULL_var;
   do {
      if ( !ispBody ) {
         break;
      }
  
    // we just limit to 1 domain only here
      CATLONG32 NbDomain = isBody->GetNbDomains();
      if ( NbDomain != 1 ) {
         break;
      }
  
      CATDomain_var spDomain = isBody->GetDomain( NbDomain );
      if ( !spDomain ) {
         break;
      }
  
      CATLONG32 NbCell = spDomain->GetNbCellUses();
      if ( NbCell < 1 ) {
         break;
      }
      CATCell_var spCell = spDomain->GetCell( 1);  
      if ( !spCell ) {
         break;
      }
  
      if ( !spCell->IsATypeOf( CATPointType ) ) {
         break;
      }
  
      CATVertex_var spVertex = spCell;
      if ( !spVertex ) {
         break;
      }
      spPoint = spVertex->GetCurve();
      if ( !spPoint ) {
         break;
      }
   } while (FALSE);
  
   return spPoint;
}
  
当然实际上还要考虑你的点会是个什么样的点,比如一个3D点和一个edge上的构成点的特性还是有些地方不同的,你有时候可能需要取RepGeomertry,或不能直接用smartpoint来转型
这2个函数只是看着帮助随便写的,所以可能实际上还需要对转型做些修正
作者: acoka    时间: 2005-5-10 00:55
特别要注意的是CATIGSMFactory生成的东西要你自己agregate
  
如果你只是找交点坐标,还可以使用
CATHybIntersect* CATCreateTopIntersect( CATGeoFactory*  iFactory,  
  CATTopData*  iData,  
  CATBody*  iBody1ToIntersect,  
  CATBody*  iBody2ToIntersect)   
找到坐标后把resultbody给remove掉就好,比较好处理,避免内存泄漏
作者: cupcake    时间: 2005-5-10 11:45
谢谢acoka兄,前面的我已经懂了,这些是什么意思,是不是说已经选中了交点,求交点坐标?
  
CATHybIntersect* CATCreateTopIntersect( CATGeoFactory* iFactory,  
CATTopData* iData,  
CATBody* iBody1ToIntersect,  
CATBody* iBody2ToIntersect)  
找到坐标后把resultbody给remove掉就好,比较好处理,避免内存泄漏
作者: cupcake    时间: 2005-5-10 20:50
acoka兄,还有,在GetBodyFromFeature()中为什么用了
CATIMfBRep_var spBRepOnFeature = ispFeature;后,spBRepOnFeature 为空?我是这样调用GetBodyFromFeature()的:
  CATISpecObject_var spObj=spREdge;
//其中spREdge是CATIGSMIntersect_var类型的。  
  if(spObj!=NULL_var)
  {
  CATBody_var spBody=GetBodyFromFeature(spObj);
  
  }
结果在调用GetBodyFromFeature()时候出现了
spBRepOnFeature ==NULL_var请问怎么解决阿?
  
  
作者: acoka    时间: 2005-5-11 01:00
那你就试试看
  
{
  CATBody_var spBody = NULL_var;
  do {
    if( !ispFeature ) {
      break;
    }
    CATIGeometricalElement_var spGeometricalElementOnFeature = ispFeature;
    if( !spGeometricalElementOnFeature ) {
      break;
    }
    spBody = spGeometricalElementOnFeature->GetBodyResult();
    if( !spBody ) {
      break;
    }
  } while(FALSE);
  return spBody;
}
  
CATCreateTopIntersect是operator,
作者: cupcake    时间: 2005-5-11 16:29
acoka兄,这次spBody 非空了。
谢谢你
:)




欢迎光临 iCAx开思工具箱 (https://t.icax.org/) Powered by Discuz! X3.3