明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2023|回复: 3

[求助]为什么夹点拖动会出现错误中断,怎么解决

[复制链接]
发表于 2008-3-1 10:59:00 | 显示全部楼层 |阅读模式

为什么夹点拖动会出现错误中断,怎样解决?谢谢

我用ObjectARX做了一个剖视符号的自定义实体,可是有时候拖动夹点会弹出下面的对话框

致命错误:Unhandled Access Violation Reading 0x12c0000 Exception at 63acda70h

请大家帮帮我,万分感激

发表于 2008-3-1 11:33:00 | 显示全部楼层

自定义实体的virtual函数都重载了吗?比如getGripPoint之类的,moveGripPoint。光贴个地址没用,版本不同,异常的地址是不同的,要分析。贴点代码出来。

 楼主| 发表于 2008-3-1 11:46:00 | 显示全部楼层

请问怎么样读取多点,谢谢

都重载了,代码如下,调试发现问题出现在倒数第二个if,谢了

Acad::ErrorStatus TyIcDbSectViewSym::moveGripPointsAt (const AcDbIntArray &indices, const AcGeVector3d &offset)
{
 assertWriteEnabled () ;
 //----- This method is never called unless you return eNotImplemented
 //----- from the new moveGripPointsAt() method below (which is the default implementation)
 
  for(int i=0; i<indices.length(); ++i)
  {

  int index = indices.at(i);
  if (index == 0)
  {
   view_name_pnt += offset;
   break;
  }
  if (index == 1)
  {
   AcGePoint3d tempnt = ori_dir_pnt + offset;
   AcGeVector3d ver = ori_dir_pnt - m_pnts[0];
   AcGeVector3d ofs_ver = tempnt - m_pnts[0];
   if (ver.angleTo(ofs_ver) > 0.5 * PI)
   {
    AcGeVector3d tempvec = m_pnts[0] - ori_dir_pnt;
    ori_dir_pnt = m_pnts[0] + tempvec;
   }
   break;
  }
  if (index == 2)
  {
   AcGePoint3d tempnt = end_dir_pnt + offset;
   AcGeVector3d ver = end_dir_pnt - m_pnts[m_pnts_num - 1];
   AcGeVector3d ofs_ver = tempnt - m_pnts[m_pnts_num - 1];
   if (ver.angleTo(ofs_ver) > 0.5 * PI)
   {
    AcGeVector3d tempvec = m_pnts[m_pnts_num - 1] - end_dir_pnt;
    end_dir_pnt = m_pnts[m_pnts_num - 1] + tempvec;
   }
   break;
  }
  if ((2 < index) && (index < m_pnts_num + 3))
  {
   m_pnts[index - 3] += offset;
   loca_pnts[index -3] += offset;

   if (index == 3 || index == 4 || index == m_pnts_num + 1 || index == m_pnts_num +2)
   {
    AcGeVector3d odir_vec(m_pnts[1] - m_pnts[0]);
    AcGeVector3d oarr_vec(ori_dir_pnt - m_pnts[0]);
    if (!oarr_vec.isPerpendicularTo(odir_vec) || (oarr_vec.length() != LineLength))
    {
     AcGePlane oplane(m_pnts[0], odir_vec);
     AcGePoint3d otempnt(ori_dir_pnt.orthoProject(oplane));
     AcGeVector3d otem_vec = otempnt - m_pnts[0];
     ori_dir_pnt = m_pnts[0] + LineLength * otem_vec.normalize();
    }

    AcGeVector3d edir_vec(m_pnts[m_pnts_num - 2] - m_pnts[m_pnts_num -1]);
    AcGeVector3d earr_vec(end_dir_pnt - m_pnts[m_pnts_num -1]);
    if (!earr_vec.isPerpendicularTo(edir_vec) || (earr_vec.length() != LineLength))
    {
     AcGePlane eplane(m_pnts[m_pnts_num -1], edir_vec);
     AcGePoint3d etempnt(end_dir_pnt.orthoProject(eplane));
     AcGeVector3d etem_vec = etempnt - m_pnts[m_pnts_num -1];
     ori_dir_pnt = m_pnts[m_pnts_num -1] + LineLength * etem_vec.normalize();
    }
   }

   break;
  }
  if ((m_pnts_num + 2 < index) && (index < 2 * m_pnts_num + 3))
  {
   loca_pnts[index - m_pnts_num - 3] += offset;
   break;
  }

}
 
 return Acad::eOk;

 //return (AcDbEntity::moveGripPointsAt (indices, offset)) ;
}

发表于 2008-3-1 12:09:00 | 显示全部楼层

我浏览了一下你代码,我没法调,所以只能给你几点建议。

1.避免数组访问越界。

2.用AcGeVector3d时注意,是不是0向量。因为move这函数会被不断调用,对调试带来难度。再就是,你这类的基类是撒,根据不同要求,有些情况是需要调用基类的move的。要看你要做什么。

3.确定Crash是确定发生在你的代码。而不是由你产生错误,导致CAD其他地方CRASH,后一种较难调。如果发生在你的CODE。那就把倒数第二个IF全comment。运行,如果不crash,可以确定是在这里面问题,慢慢减小范围来查。comment最多造成功能不正确。若可避免crash,问题就很清楚,重新审视这段代码吧

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 16:20 , Processed in 0.176630 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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