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


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


回复
 
主题工具 搜索本主题 显示模式
旧 2009-04-22, 03:44 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 高手,帮忙看一下,这个程序为什么会出错?

高手,帮忙看一下,这个程序为什么会出错?
www.dimcax.com
高手,帮忙看一下,这个程序为什么会出错?
static public void plhypline() { document doc = application.documentmanager.mdiactivedocument; editor ed = doc.editor; database db = hostapplicationservices.workingdatabase; promptkeywordoptions mykey = new promptkeywordoptions("\n请选择选项[不拟合(n)/曲线拟合(c)/二次拟合(sf)/三次拟合(sc)]","n c sf sc"); mykey.allownone = true; promptresult resmykey = ed.getkeywords(mykey); if (resmykey.status == promptstatus.cancel || resmykey.status == promptstatus.none) return; else { switch (resmykey.stringresult) { case "n": promptkeywordoptions layerkey = new promptkeywordoptions("\n空回车直接选择实体或[输入图层名(l)]","l"); layerkey.allownone = true; promptresult reslayerkey = ed.getkeywords(layerkey); if (reslayerkey.status == promptstatus.cancel) return; else if (reslayerkey.status == promptstatus.none) { promptselectionresult resmyset = ed.getselection(); polylineedit(resmyset,"huanyuan");//这里调用函数能正常运行 } else if (reslayerkey.stringresult=="l") { promptstringoptions laname = new promptstringoptions("\n请输入图层名称"); promptresult reslaname = ed.getstring(laname); if (reslaname.status == promptstatus.cancel) return; else { typedvalue[] ltflterlst ={ new typedvalue((int)dxfcode.layername, reslaname) }; selectionfilter ltflter = new selectionfilter(ltflterlst); promptselectionresult ressellt = ed.selectall(ltflter); polylineedit(ressellt, "huanyuan");//这里调用函数不能正常运行 } } break; } } } } } static public void polylineedit(promptselectionresult resmyset, string niheedit) { document doc = application.documentmanager.mdiactivedocument; editor ed = doc.editor; database db = hostapplicationservices.workingdatabase; using (transaction trans = db.transactionmanager.starttransaction()) { foreach (objectid id in resmyset.value.getobjectids()) { dbobject myent = trans.getobject(id, openmode.forwrite) as dbobject; if (myent != null) { switch (myent.gettype().name) { case "polyline2d": polyline2d mypl2d = (polyline2d)myent; polyline mypline = new polyline(); int index = 0; foreach (objectid vid in mypl2d) { if (niheedit == "huanyuan") { vertex2d v2d = trans.getobject(vid, openmode.forread) as vertex2d; if (v2d.vertextype != vertex2dtype.curvefitvertex && v2d.vertextype != vertex2dtype.splinecontrolvertex && v2d.vertextype != vertex2dtype.splinefitvertex) { mypline.addvertexat(index++, new point2d(v2d.position.x, v2d.position.y), 0, 0, 0); } } } mypline.elevation = mypl2d.elevation; mypline.layer = mypl2d.layer; mypline.color = mypl2d.color; mypline.constantwidth = mypl2d.defaultstartwidth; mypline.linetype = mypl2d.linetype; mypline.closed = mypl2d.closed; mypl2d.erase(true); objectid myplid = objectid.null; myplid = mypoly.appendentity(mypline); break; } } } trans.commit(); } }
已经解决,是我粗心造成的,没有注意到。呵呵
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



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


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