几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » AutoCAD二次开发 » ObjectARX(C++)
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


回复
 
主题工具 搜索本主题 显示模式
旧 2009-04-18, 07:05 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】自定义实体制作中出现 的问题

自定义实体制作中出现 的问题
自定义实体制作中出现 的问题
我从acdbentity派生了一个子类azhtentity,然后又从azhtentity派生azhtbreaker,如下:一些必须的重载函数还有些返回值都已省略,
azhtentity中:
class azhtentityublic acdbentity
{
public:
acrx_declare_members(azhtentity);
azhtentity();
virtual ~azhtentity();
.....................................
.....................................
..................movegrippointsat()..........
..................getgrippoints()................
..................transformby()..................
.........................................................
........................................................
private:
acgepoint3d m_insertpt; //插入点
};
azhtentity::getgrippoints(acgepoint3darray& grippoints, acdbintarray& osnapmodes, acdbintarray& geomids) const
{
assertreadenabled();
grippoints.append(m_insertpt);
return acad::eok;
}
azhtentity::movegrippointsat(const acdbintarray& indices, const acgevector3d& offset)
{
assertwriteenabled();
return acad::eok;
}
azhtentity::transformby(const acgematrix3d& xform)
{
assertwriteenabled();
return acad::eok;
}
azhtbreaker中:
class azhtbreakerublic azhtentity
{
public:
acrx_declare_members(azhtbreaker);
azhtbreaker();
virtual ~azhtbreaker();
.....................................
.....................................
..................movegrippointsat()..........
..................getgrippoints()................
..................transformby()..................
.........................................................
........................................................
private:
acgepoint3d m_otherpt; //插入点
};
azhtbreaker::getgrippoints(acgepoint3darray& grippoints, acdbintarray& osnapmodes, acdbintarray& geomids) const
{
assertreadenabled();
int idirection = ((azhtentity*)this)->getdirection();
acgepoint3d insertpt = ((azhtentity*)this)->getinsertpt();
grippoints.append(m_otherpt);
azhtentity::getgrippoints(grippoints, osnapmodes, geomids);
return acad::eok;
}
azhtbreaker::movegrippointsat(const acdbintarray& indices, const acgevector3d& offset)
{
assertwriteenabled();
//若没有选中点或偏移为0
if(indices.length()==0 || offset.iszerolength())
return acad::eok;
return transformby(acgematrix3d::translation(offset));
}
azhtbreaker::transformby(const acgematrix3d& xform)
{
assertwriteenabled();
acgepoint3d insertpt = getinsertpt();
insertpt.transformby(xform);
m_otherpt.transformby(xform);
return acad::eok;
}
我这样做之后,能够得到夹点,但在移动的时候出现问题,说什么内存不足!请高手指教一下,谢谢!!!!!!
在下想知道,在重载这些函数的时候需要有些什么原则和注意的地方吗?
看你的worlddraw,估计是那的问题
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭



所有的时间均为北京时间。 现在的时间是 05:20 AM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多