沈阳航空工业学院 王霞
'je=.{[lWt Z4U8~i 摘 要:AutoCAD是机械设计人员最常用的绘图工具,功能非常强大,但常因缺乏常用结构图形库而影响绘图效率,为此,论文提出在AutoCAD环境下采用AutoCADVBA 方式对机械图形中的常用结构进行参数化设计的解决方案。由于常用结构的开发方式类似,便以轴类零件中键槽结构的主视图和剖面图为例,讲述了Access 数据库的构建方法、利用ADO 方式来开发数据库的过程和编程实现最终图形的过程。
,z6&k 关键词:AutoCAD,常用结构,参数化设计
1b)^5U ; Y<X,(\iEHP AutoCAD作为应用最广泛的绘图软件,它的功能非常强大,基于AutoCAD环境下的二次开发也很方便。但是,在AutoCAD绘图软件的各种版本中,均无现成的常用结构图形库。本文采用AutoCADVBA(Visual Basic for Applications),针对各类零件特点的常用结构,如轴类零件的键槽、带轮槽、密封圈槽、移出剖面图和局部放大图等,实现了对常用结构的参数化绘图[1]。绘图人员只要输入要求的参数,就可以自动生成对应图形,简单方便实用。由于常用结构的编程过程非常相似,下面就以键槽为例,讲述标准结构参数化设计及绘图过程。
_<?lP$Xr ;U6z|O7L 1 参数选择
GT|=Kx$; F<wwuCbF 键槽是轴类零件上常见的结构,通过对图1和图2 的比较可见,只要图2 中5 个参数给定,就可将键槽的主视图和剖面图确定下来[2]。而且,根据标准机械设计手册,参数中的b、t 是由轴径d决定的,那么,绘图过程需要的参数只有三个:d、l、a。而另外两个参数b、t 可作为数据库内容通过d 来查询,这部分任务通过程序来完成。因此,经过分析可知,绘图人员只要输入参数d、l、a 的数值就能快速简洁地完成(图2)了。
vh8{*9+ $<jI<vD+:
52-Gk2dp cC'{+j8-a
b"-eQb _h#SP+> 2 编程思路
0)}bJ,5/ =i jGB~ 2. 1 建立Access 数据库
!MNo
8dC; 8$ dJh]\Y 普通平键及键槽尺寸如图3 所示。
2"
(vjnfH ?(Dk{-:T'
'2+Rb7V i*`; /x'+ Access 是开发小型数据库应用系统的理想工具,功能灵活,易于学习和操作[3]。本软件便采用Access 来建立数据库。表的结构非常简单,只是对机械手册相关表格中部分字段的选取。对于键槽来说,则采用如表1 的表格形式(表1 只选取完整表格的一部分)。
qV57P6< 9OYsI 2. 2 数据库操作部分
T7eo_Mn ]HoQ6R\E b 本软件对数据库的操作使用ADO(ActiveXData Objects)方式[3]。
KD]8n]c Yc+0OBH[ 其中,打开数据库的语句如下:
#8.%YG 0(fN Public Const DATABASE As String = " 常用
!Kv.v7'N/k 结构. mdb"
,@2d<d] Private cnn As ADODB. Connection
}5#<`8 Set cnn = New ADODB. Connection
I>X _j) cnn. ConnectionString = " Provider = Microsoft.
- P+( =U Jet. OLEDB. 4. 0;Data Source = " - + App. path +
^Xjh ?+WM " " + DATABASE + " ;"
q|)8VmVV cnn. Open
Fxwe, ?YR/'Vq97 对数据库中的数据,本软件最常用的是查询功能。例如:根据所给轴的直径d 查询键槽的相关尺寸b、t 的查询语句如下:
$0rSb0[ a@_.uD SELECT b,t FROM 普通平键及键槽尺寸表
SJhcmx+ WHERE d > dmin and d < = dmax.
(Sc]dH "i$Avm 其他对数据库的操作与查询类似,不再赘述。
U[9`:aV; Hf
P2o5- 2. 3 绘图部分
Qn>0s >/;V_(
对于键槽结构来说,图形分为两部分:主视图和剖面图。线条比较简单,主要采用画直线和圆弧的命令,尺寸标注也主要采用线性型尺寸标准方式,它的基本命令为:
2[i:bksjW V6'"J ThisDrawing. ModelSpace. AddDimAligned( startPoint,
v*}r<}j endPoint,location)。
@D%H-X &-#!]T-P:E 下面以绘直线为例,表明作图过程[4]:
aaf\% ~ <TmMUA)`} startPoin(t 0) = ArcCenPointX +(d/ 2# - t)
3P C'P2 startPoin(t 1) = ArcCenPointY + b / 2
F Vkb9(WW startPoin(t 2) = 0#
mjUln8Jc endPoin(t 0) = ArcCenPointX +(d / 2# - t)
E.kGBA;a? endPoin(t 1) = ArcCenPointY - b / 2
TqK`X#Zq endPoin(t 2) = 0#
O)|{B>2r Set lineObj =
i,>yIPBU! ThisDrawing. ModelSpace. AddLine( startPoint,
(Nd5VuI endPoint)
gE^
{@^ '6*^s&H~ 当然,绘图部分实现最终的图形显示,在程序中难免有相当多的数据的传输调用。本文采用的是全局变量的形式。例如轴径:Public d As Double。
;RNU`Ip 9(k5Irv"'h 与AutoCAD的接口可以使用菜单方式,也可以采用命令方式,都非常方便简单。
X
$LX;Lv 8:c[_3w 3 结束语
w[Ee#Yaj.- iTi]D2jC 本文所实现的对常用结构的参数化设计,是在AutoCAD环境下,利用VBA 这种编程语言完成的。界面简洁,简单易用,减少了绘图人员的查阅标准时间,减轻了绘图工作量,提高了出图速度,并且可以避免在绘图和查表的交错进行中产生的失误,具有一定的实用价值。
FCxLL")) C5;=!B 参考文献:
!MoJb#B3^] [1]董玉德,谭建荣,赵韩,等. AutoCAD系统开发技术-程序实现
dM"Suw 与实例[M]. 合肥:中国科学技术大学出版社,2001
!kZ9Ox9^ [2]西北工业大学工程制图教研室. 画法几何及机械制图( 下)
Ndq|Hkd [M]. 西安:陕西科学技术出版社,2000
o*H j E [3]启明工作室. Visual Basic Access 数据库应用系统开发与实例
8/X#thG [M]. 北京:人民邮电出版社,2004
mZsftby} [4]张帆,郑立楷,王华杰. AutoCADVBA 开发精彩实例教程
]MJyBz+k [M]. 北京:清华大学出版社,2004