几何尺寸与公差论坛------致力于产品几何量公差标准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-20, 06:05 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】交互问题

交互问题
www.dimcax.com
交互问题
我想做一个用户交互的巷道生成过程,点走到哪巷道就拉到哪可是交互这没做好,起始点总是同一点,请大家帮忙 using system; using system.collections; using autodesk.autocad.runtime; using autodesk.autocad.databaseservices; using autodesk.autocad.geometry; using autodesk.autocad.applicationservices; using autodesk.autocad.editorinput; using autodesk.autocad.colors; using dbtransman = autodesk.autocad.databaseservices.transactionmanager; [assembly: commandclass(typeof(巷道.commands))] namespace 巷道 { /// /// summary description for commands. /// public class commands { public commands() { // // todo: add constructor logic here // } // define command "asdkcmd1" [commandmethod("hd")] static public void test() { database db=hostapplicationservices.workingdatabase; editor ed=application.documentmanager.mdiactivedocument.editor; promptpointoptions ppo1 = new promptpointoptions("请选择点"); promptpointresult ppr1 = ed.getpoint(ppo1); point3d pt1 = ppr1.value; nextpoint: promptpointoptions ppo2 = new promptpointoptions("请选择下一点"); promptpointresult ppr2 = ed.getpoint(ppo2); if (ppr2.status == promptstatus.cancel) return; ppo2.usebasepoint = true; point3d pt2 = ppr2.value; if(ppo2.basepoint.x==0) ppo2.basepoint = pt1; vector3d vvv = ppo2.basepoint.getvectorto(pt2); line line = new line(ppo2.basepoint, pt2); region region = re(vvv, ppo2.basepoint); solid3d land = new solid3d(); land.extrudealongpath((region)region,line,0); appendentity(land); point3d pt3 = new point3d(); pt3 = pt2; ppo2.basepoint = pt3; goto nextpoint; } public static objectid appendentity(entity ent) { database db = hostapplicationservices.workingdatabase; objectid entid; using (transaction trans = db.transactionmanager.starttransaction()) { blocktable bt = (blocktable)trans.getobject(db.blocktableid, openmode.forread); blocktablerecord btr = (blocktablerecord)trans.getobject(bt[blocktablerecord.modelspace], openmode.forwrite); entid = btr.appendentity(ent); trans.addnewlycreateddbobject(ent, true); trans.commit(); } return entid; } //创建巷道面域 public static region re(vector3d vv, point3d pt) { arc arc=new arc(pt,vv,5,math.pi,0.75*math.pi); point3d pts=new point3d(); point3d pte=new point3d(); pte=arc.startpoint; pts=arc.endpoint; line line=new line(pts,pte); dbobjectcollection ent = new dbobjectcollection(); ent.add(arc); ent.add(line); dbobjectcollection egion = region.createfromcurves(ent); region region = (region)egion[0]; return region; } } }
在学习编程前,应该先好好学学语文!
逻辑上比较混乱. 我觉的最好不要用pt1 pt2 pt3 之类的命名方法,把自己都搞糊涂了吧. basepoint是以前一个点为基点,你可以设置一个point3d ptprev,ptcurrent, 表示前一个点和要输入的点,可以设置basepoint为ptprev,但要注意随时注意更新它的值
总能把手机放到我自己找不到的地方...
难以说清楚就贴个截图下来看看
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



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


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