几何尺寸与公差论坛------致力于产品几何量公差标准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-14, 03:15 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】arx (vc60+acad2)自定义实体类读写出错

arx (vc60+acad2)自定义实体类读写出错
arx (vc60+acad2)自定义实体类读写出错
定义成员:
acgepoint3d mfirst, msecond, mthree, mfour;
acgepoint3d mcenter;
acad::errorstatus cascocentity::dwginfields(acdbdwgfiler* pfiler)
{
assertwriteenabled();
acad::errorstatus es;
// call dwginfields from acdbentity
if ((es = acdbentity::dwginfields(pfiler)) != acad::eok) {
return es;
}
// read version number.
adesk::uint16 version;
pfiler->readitem(&version);
if (version > version_cascocentity)
return acad::emakemeproxy;
// read the data members.
switch (version)
{
case (1):
// todo: here you can file datamembers not
// created by the objectarx add-in.
pfiler->readitem(&version); //原来这儿多了一行,读了两次,谢谢xd论坛binbin
pfiler->readitem(&mcenter);
pfiler->readitem(&mfirst);
pfiler->readitem(&msecond);
pfiler->readitem(&mthree);
pfiler->readitem(&mfour);
break;
}
return pfiler->filerstatus();
}
acad::errorstatus cascocentity::dwgoutfields(acdbdwgfiler* pfiler) const
{
assertreadenabled();
acad::errorstatus es;
// call dwgoutfields from acdbentity
if ((es = acdbentity::dwgoutfields(pfiler)) != acad::eok) {
return es;
}
// write version number.
pfiler->writeitem((adesk::uint16) version_cascocentity);
// write the data members.
// todo: here you can file datamembers not
// created by the objectarx add-in.
pfiler->writeitem(mcenter);
pfiler->writeitem(mfirst);
pfiler->writeitem(msecond);
pfiler->writeitem(mthree);
pfiler->writeitem(mfour);
return pfiler->filerstatus();
}
acad::errorstatus cascocentity::dxfinfields(acdbdxffiler* pfiler)
{
assertwriteenabled();
struct resbuf rb;
if ((acdbentity::dxfinfields(pfiler) != acad::eok) ||
!pfiler->atsubclassdata("cascocentity"))
return pfiler->filerstatus();
// read version number.
pfiler->readitem(&rb);
if (rb.restype != acdb::kdxfint16) {
pfiler->pushbackitem();
pfiler->seterror(acad::einvaliddxfcode,
"nerror: expected object version group code %d",
acdb::kdxfint16);
return pfiler->filerstatus();
} else {
adesk::uint16 version = rb.resval.rint;
if (version > version_cascocentity)
return acad::emakemeproxy;
}
// todo: here you can file datamembers not
// created by the objectarx add-in.
pfiler->readitem(&rb);
if (rb.restype != acdb::kdxfxcoord)
mcenter = aspnt3d(rb.resval.rpoint);
pfiler->readitem(&rb);
if (rb.restype != acdb::kdxfxcoord +1)
mfirst = aspnt3d(rb.resval.rpoint);
pfiler->readitem(&rb);
if (rb.restype != acdb::kdxfxcoord +2)
msecond = aspnt3d(rb.resval.rpoint);
pfiler->readitem(&rb);
if (rb.restype != acdb::kdxfxcoord +3)
mthree= aspnt3d(rb.resval.rpoint);
pfiler->readitem(&rb);
if (rb.restype == acdb::kdxfxcoord +4)
mfour = aspnt3d(rb.resval.rpoint);
return pfiler->filerstatus();
}
acad::errorstatus cascocentity::dxfoutfields(acdbdxffiler* pfiler) const
{
assertreadenabled();
acad::errorstatus es;
if ((es = acdbentity::dxfoutfields(pfiler)) != acad::eok)
return es;
// write subclass marker.
pfiler->writeitem(acdb::kdxfsubclass, "cascocentity");
// write version number.
pfiler->writeitem(acdb::kdxfint16, (adesk::uint16) version_cascocentity);
// todo: here you can file datamembers not
// created by the objectarx add-in.
pfiler->writeitem(acdb::kdxfxcoord, mcenter);
pfiler->writeitem(acdb::kdxfxcoord, mfirst);
pfiler->writeitem(acdb::kdxfxcoord, msecond);
pfiler->writeitem(acdb::kdxfxcoord, mthree);
pfiler->writeitem(acdb::kdxfxcoord, mfour);
return es;
}
请问我这个自定义实体类保存读取出错在哪儿?
还有本例中夹点函数、拉伸函数、变换函数以及对象捕捉点函数如何编程?
acad::errorstatus cascocentity::getgrippoints(acgepoint3darray& grippoints,
acdbintarray& osnapmodes,
acdbintarray& geomids) const
{。。。。}
acad::errorstatus cascocentity::getstretchpoints(acgepoint3darray& stretchpoints) const
{。。。。}
acad::errorstatus cascocentity::movegrippointsat(const acdbintarray& indices,
const acgevector3d& offset)
{。。。。}
acad::errorstatus cascocentity::movestretchpointsat(const acdbintarray& indices,
const acgevector3d& offset)
{。。。。}
请各位大侠帮帮忙呀,能不能给出一个从实体类派生的例子。谢谢大家。
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



所有的时间均为北京时间。 现在的时间是 11:16 PM.


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