沈阳航空工业学院 王霞
9nFL70 ZHTi4JY 摘 要:AutoCAD是机械设计人员最常用的绘图工具,功能非常强大,但常因缺乏常用结构图形库而影响绘图效率,为此,论文提出在AutoCAD环境下采用AutoCADVBA 方式对机械图形中的常用结构进行参数化设计的解决方案。由于常用结构的开发方式类似,便以轴类零件中键槽结构的主视图和剖面图为例,讲述了Access 数据库的构建方法、利用ADO 方式来开发数据库的过程和编程实现最终图形的过程。
)re<NE&M 关键词:AutoCAD,常用结构,参数化设计
A@V$~&JCL5 NLy4Z:&{ AutoCAD作为应用最广泛的绘图软件,它的功能非常强大,基于AutoCAD环境下的二次开发也很方便。但是,在AutoCAD绘图软件的各种版本中,均无现成的常用结构图形库。本文采用AutoCADVBA(Visual Basic for Applications),针对各类零件特点的常用结构,如轴类零件的键槽、带轮槽、密封圈槽、移出剖面图和局部放大图等,实现了对常用结构的参数化绘图[1]。绘图人员只要输入要求的参数,就可以自动生成对应图形,简单方便实用。由于常用结构的编程过程非常相似,下面就以键槽为例,讲述标准结构参数化设计及绘图过程。
M9iX_4 <h -)zI 1 参数选择
\U:OQ.e E ;Z(v 键槽是轴类零件上常见的结构,通过对图1和图2 的比较可见,只要图2 中5 个参数给定,就可将键槽的主视图和剖面图确定下来[2]。而且,根据标准机械设计手册,参数中的b、t 是由轴径d决定的,那么,绘图过程需要的参数只有三个:d、l、a。而另外两个参数b、t 可作为数据库内容通过d 来查询,这部分任务通过程序来完成。因此,经过分析可知,绘图人员只要输入参数d、l、a 的数值就能快速简洁地完成(图2)了。
^4`aONydl 6KddHyFz ;,77|]<XE _dKMBcl)E DTO_IP T]th3* 2 编程思路
XvI~"} >7W)iwF 2. 1 建立Access 数据库
<^YvgQ,m -06G.;W\^ 普通平键及键槽尺寸如图3 所示。
n]g"H Q.N!b7r7 [Hh*lKg 9]eG|LFD Access 是开发小型数据库应用系统的理想工具,功能灵活,易于学习和操作[3]。本软件便采用Access 来建立数据库。表的结构非常简单,只是对机械手册相关表格中部分字段的选取。对于键槽来说,则采用如表1 的表格形式(表1 只选取完整表格的一部分)。
oJa}NH
^yW['H6V 2. 2 数据库操作部分
5]&sXs "rBB&l 本软件对数据库的操作使用ADO(ActiveXData Objects)方式[3]。
coXg]bUKo ZID- ~
6 其中,打开数据库的语句如下:
B_[efM<R$ O#D{:H_dD> Public Const DATABASE As String = " 常用
/@\`Ibe 结构. mdb"
O>L,G)g Private cnn As ADODB. Connection
J _rrc;F Set cnn = New ADODB. Connection
'KH+e#?Ar cnn. ConnectionString = " Provider = Microsoft.
_Q+c'q Zkl Jet. OLEDB. 4. 0;Data Source = " - + App. path +
iq' PeVo " " + DATABASE + " ;"
r^m&<)Ca cnn. Open
LK} g<!o( g+B7~Z5, 对数据库中的数据,本软件最常用的是查询功能。例如:根据所给轴的直径d 查询键槽的相关尺寸b、t 的查询语句如下:
0OO[@Ht t=B1yvE" SELECT b,t FROM 普通平键及键槽尺寸表
v~ >Bbe WHERE d > dmin and d < = dmax.
F^GNOD3J P*KIk~J 其他对数据库的操作与查询类似,不再赘述。
Lg<h54X 7(}'jZ 2. 3 绘图部分
-Cyo2wk '~Y@HRVL@| 对于键槽结构来说,图形分为两部分:主视图和剖面图。线条比较简单,主要采用画直线和圆弧的命令,尺寸标注也主要采用线性型尺寸标准方式,它的基本命令为:
BL&AZv/T C:Jfrg` ThisDrawing. ModelSpace. AddDimAligned( startPoint,
].Yz
=: endPoint,location)。
yeiIP a,w|r#x] 下面以绘直线为例,表明作图过程[4]:
7<su8*? \Y!#Y#c startPoin(t 0) = ArcCenPointX +(d/ 2# - t)
Hs)Cf)8u startPoin(t 1) = ArcCenPointY + b / 2
wG49|!l6T startPoin(t 2) = 0#
(RFH.iX endPoin(t 0) = ArcCenPointX +(d / 2# - t)
$
64up! endPoin(t 1) = ArcCenPointY - b / 2
b? o endPoin(t 2) = 0#
j!agD_J Set lineObj =
i D 9 */ ThisDrawing. ModelSpace. AddLine( startPoint,
<|l}@\iRX endPoint)
i.^ytbH jJIP $ 当然,绘图部分实现最终的图形显示,在程序中难免有相当多的数据的传输调用。本文采用的是全局变量的形式。例如轴径:Public d As Double。
{wC*61@1 opH!sa@U 与AutoCAD的接口可以使用菜单方式,也可以采用命令方式,都非常方便简单。
@eJ8wf] {dZ]+2Z~+ 3 结束语
;qaPK2a8 @<P2di 本文所实现的对常用结构的参数化设计,是在AutoCAD环境下,利用VBA 这种编程语言完成的。界面简洁,简单易用,减少了绘图人员的查阅标准时间,减轻了绘图工作量,提高了出图速度,并且可以避免在绘图和查表的交错进行中产生的失误,具有一定的实用价值。
H^|TV]^;N F` 7v 参考文献:
8xENzTR [1]董玉德,谭建荣,赵韩,等. AutoCAD系统开发技术-程序实现
x/?ET1iGt 与实例[M]. 合肥:中国科学技术大学出版社,2001
Wxj_DTi[1" [2]西北工业大学工程制图教研室. 画法几何及机械制图( 下)
=p_*lC%N [M]. 西安:陕西科学技术出版社,2000
-gvfz&Lz [3]启明工作室. Visual Basic Access 数据库应用系统开发与实例
5QiQDQT}5 [M]. 北京:人民邮电出版社,2004
9)7$U QY [4]张帆,郑立楷,王华杰. AutoCADVBA 开发精彩实例教程
l_}d Q&R [M]. 北京:清华大学出版社,2004