几何尺寸与公差论坛------致力于产品几何量公差标准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-17, 10:25 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】学习arx,编个初组的命令,呵呵

学习arx,编个初组的命令,呵呵
三点画弧arx源代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59acdbblocktablerecord *getmodelspace(acdb:penmode mode){
acdbdatabase *pdwg = acdbhostapplicationservices()->workingdatabase();
acdbblocktable *pblocktable;
acdbblocktablerecord *pmodelspace;
pdwg->getsymboltable(pblocktable, acdb::kforread);
pblocktable->getat(acdb_model_space, pmodelspace, mode);
pblocktable->close();
return pmodelspace;
}
//功能:三点画弧
//编程:包达勇
//时间:
我也发发,最简单的jig
class crectjig ublic acedjig
{
public:
crectjig()
{
pline = 0;
ncolor = 1;
}
~crectjig()
{
if (pline)
{
delete pline;
pline = 0;
}
}
void setcolor(int color){ncolor = color;}
bool doit()
{
if(!pline)
pline = new acdbpolyline;

ads_point pt1;

if(ads_getpoint(null,str,pt1)!=rtnorm)
{
return false;
}
pts = transucs2wcs(aspnt3d(pt1),false);
pte = acgepoint3d(pts.x+1,pts.y+1,0);
pline->addvertexat(0,acgepoint2d(pts.x,pts.y));
pline->addvertexat(1,acgepoint2d(pts.x,pte.y));
pline->addvertexat(2,acgepoint2d(pte.x,pte.y));
pline->addvertexat(3,acgepoint2d(pte.x,pts.y));
pline->setclosed(adesk::ktrue);
pline->setcolorindex(ncolor);
setdispprompt("一些描述");
acedjig::dragstatus stat = drag();
if (stat != acedjig::knormal)
return false;
return true;
}
dragstatus sampler()
{
dragstatus stat;
setuserinputcontrols((userinputcontrols)
(acedjig::kaccept3dcoordinates
| acedjig::knonegativeresponseaccepted
| acedjig::knozeroresponseaccepted));
acgepoint3d pt;
stat = acquirepoint(pt);
if (!pt.isequalto(pte))
pte = pt;
else if (stat == acedjig::knormal)
return acedjig::knochange;
return stat;
}
adesk::boolean update()
{
pline->setpointat(0,acgepoint2d(pts.x,pts.y));
pline->setpointat(1,acgepoint2d(pts.x,pte.y));
pline->setpointat(2,acgepoint2d(pte.x,pte.y));
pline->setpointat(3,acgepoint2d(pte.x,pts.y));
return adesk::ktrue;
}
acdbentity* entity() const
{
return pline;
}
public:
acdbpolyline * pline;
acgepoint3d pts,pte;
int ncolor;
};
transucs2wcs()是一个函数转换点的,ucs到世界坐标的
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
 


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

高级搜索
显示模式

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

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



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


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