天气与日历 切换到窄版

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

ARX 交叉绑定问题

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
[code]Acad::ErrorStatus AuPolyline::subIntersectWith(const AcDbEntity* pEnt,
                                            AcDb::Intersect intType,
                                            AcGePoint3dArray& points,
                                            Adesk::GsMarker thisGsMarker,
                                            Adesk::GsMarker otherGsMarker) const
{
  if (thisGsMarker < 1000) {
    return AcDbPolyline::subIntersectWith(pEnt, intType, points, thisGsMarker, otherGsMarker);
  } else {
    Acad::ErrorStatus es = Acad::eOk;
    objArray::const_iterator it;
    int gs = 1000;
    for(it = m_Array.begin();it!=m_Array.end() && gs < thisGsMarker; it++, gs +=100);
    if (it != m_Array.end() && gs == thisGsMarker)
    {
      AcRxObject* intPtr=0;
      intPtr=(*it).second;
      if (intPtr) {
        AcDbEntity *pSubEnt = AcDbEntity::cast(intPtr);
        if (pSubEnt) {
          es = pSubEnt->intersectWith(pEnt, intType, points,  0 /* thisGsMarker */, otherGsMarker);
          return es;
        }
      }
    }
  }
  return Acad::eOk;
}

Acad::ErrorStatus AuPolyline::subIntersectWith(const AcDbEntity* pEnt,
                                            AcDb::Intersect intType,
                                            const AcGePlane& projPlane,
                                            AcGePoint3dArray& points,
                                            Adesk::GsMarker thisGsMarker,
                                            Adesk::GsMarker otherGsMarker) const
{
  if (thisGsMarker < 1000) {
    return AcDbPolyline::subIntersectWith(pEnt, intType, projPlane, points, thisGsMarker, otherGsMarker);
  } else {
    Acad::ErrorStatus es = Acad::eOk;
    objArray::const_iterator it;
    int gs = 1000;
    for(it=m_Array.begin();it!=m_Array.end() && gs < thisGsMarker;it++, gs +=100);
    if (it != m_Array.end() && gs == thisGsMarker)
    {
      AcRxObject* intPtr=0;
      intPtr=(*it).second;
      if (intPtr) {
        AcDbEntity *pSubEnt = AcDbEntity::cast(intPtr);
        if (pSubEnt) {
          es = pSubEnt->intersectWith(pEnt, intType, projPlane, points,  0 /* thisGsMarker */, otherGsMarker);
          return es;
        }
      }
    }
  }
  return Acad::eOk;
}[/code]

 

 

 

 

ARX  交叉绑定问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-11-1 15:33 , Processed in 0.144260 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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