几何尺寸与公差论坛------致力于产品几何量公差标准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-29, 05:35 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】新手练习作品2:jig动态变换图元。 - 精华帖集合

新手练习作品2:jig动态变换图元。 - 精华帖集合
www.dimcax.com
新手练习作品2:jig动态变换图元。
, ,
using system;
using autodesk.autocad.applicationservices;
using autodesk.autocad.runtime;
using autodesk.autocad.databaseservices;
using autodesk.autocad.editorinput;
using autodesk.autocad.geometry;
using system.collections.generic;
namespace fsxm.acad
{
//jig动态变换图元
public class fsxm : drawjig
{
database db = hostapplicationservices.workingdatabase;
editor ed = application.documentmanager.mdiactivedocument.editor;
selectionset ss;
blockreference insert;
point3d minpt, oldpt;
double width, higth;
[commandmethod("trans", commandflags.usepickset)]
public void trans()
{
blocktable bt;
promptselectionoptions sop = new promptselectionoptions();
sop.messageforadding = "选择你要变换的东东";
sop.rejectobjectsonlockedlayers = true;
promptselectionresult srt = ed.getselection(sop);
if (srt.status != promptstatus.ok) return;
ss = srt.value;
using (transaction trans = db.transactionmanager.starttransaction())
{
//做块
blocktablerecord btr;
btr = new blocktablerecord();
btr.name = "*u";
//btr.origin = prt.value;
bt = (blocktable)trans.getobject(db.blocktableid, openmode.forwrite);
bt.add(btr);
trans.addnewlycreateddbobject(btr, true);
//块中图元
foreach (selectedobject sobj in ss)
{
entity ent = (entity)trans.getobject(sobj.objectid, openmode.forread);
entity copy = (entity)ent.clone();
btr.appendentity(copy);
trans.addnewlycreateddbobject(copy, true);
ent.highlight();//高亮要托动的东东
}
//算出块大小
insert = new blockreference(new point3d(), btr.id);
extents3d box = insert.geometricextents;
vector3d v = box.maxpoint.getvectorto(box.minpoint);
width = v.x;
higth = v.y;
//改下块原点
btr.origin = minpt = box.minpoint;
insert.position = minpt;
//递交
trans.commit();
}
//开始托动
promptresult var = ed.drag(this);
if (var.status != promptstatus.ok)
{
//去高亮
using (transaction trans = db.transactionmanager.starttransaction())
{
foreach (selectedobject obj in ss)
{
entity ent = (entity)trans.getobject(obj.objectid, openmode.forwrite);
ent.unhighlight();
}
}
return;
}
using (transaction trans = db.transactionmanager.starttransaction())
{
//插入打散的块
blocktablerecord mspace = (blocktablerecord)trans.getobject(bt["*model_space"], openmode.forwrite);
dbobjectcollection exs = new dbobjectcollection();
insert.explode(exs);
foreach (dbobject obj in exs)
{
mspace.appendentity((entity)obj);
trans.addnewlycreateddbobject(obj, true);
}
//删除老线
foreach (selectedobject obj in ss)
{
entity ent = (entity)trans.getobject(obj.objectid, openmode.forwrite);
ent.erase();
}
//递交
trans.commit();
}
}
protected override bool worlddraw(autodesk.autocad.graphicsinterface.worlddraw draw)
{
draw.geometry.draw(insert);
return true;
}
protected override samplerstatus sampler(jigprompts prompts)
{
point3d cur = prompts.acquirepoint("拾取变形目标点").value;
if (oldpt == cur)
return samplerstatus.nochange;
oldpt = cur;
vector3d v = cur.getvectorto(minpt);
double scx = v.x / width;
double scy = v.y / higth;
insert.scalefactors = new scale3d(scx, scy, 1);
return samplerstatus.ok;
}
}
}
复制代码
[ ]
不错啊!
路漫漫其修远兮,吾将上下而求索!
都是牛人啊.佩服!
学习
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



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


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