沈阳航空工业学院 王霞
>HatbbA dzMlfJp 摘 要:AutoCAD是机械设计人员最常用的绘图工具,功能非常强大,但常因缺乏常用结构图形库而影响绘图效率,为此,论文提出在AutoCAD环境下采用AutoCADVBA 方式对机械图形中的常用结构进行参数化设计的解决方案。由于常用结构的开发方式类似,便以轴类零件中键槽结构的主视图和剖面图为例,讲述了Access 数据库的构建方法、利用ADO 方式来开发数据库的过程和编程实现最终图形的过程。
~:r:?PwWG 关键词:AutoCAD,常用结构,参数化设计
q]3bGO; Jg=[!j0( AutoCAD作为应用最广泛的绘图软件,它的功能非常强大,基于AutoCAD环境下的二次开发也很方便。但是,在AutoCAD绘图软件的各种版本中,均无现成的常用结构图形库。本文采用AutoCADVBA(Visual Basic for Applications),针对各类零件特点的常用结构,如轴类零件的键槽、带轮槽、密封圈槽、移出剖面图和局部放大图等,实现了对常用结构的参数化绘图[1]。绘图人员只要输入要求的参数,就可以自动生成对应图形,简单方便实用。由于常用结构的编程过程非常相似,下面就以键槽为例,讲述标准结构参数化设计及绘图过程。
v*'dA^Q ^ZX 71- 1 参数选择
59:Xu%Hp )J4XM( 键槽是轴类零件上常见的结构,通过对图1和图2 的比较可见,只要图2 中5 个参数给定,就可将键槽的主视图和剖面图确定下来[2]。而且,根据标准机械设计手册,参数中的b、t 是由轴径d决定的,那么,绘图过程需要的参数只有三个:d、l、a。而另外两个参数b、t 可作为数据库内容通过d 来查询,这部分任务通过程序来完成。因此,经过分析可知,绘图人员只要输入参数d、l、a 的数值就能快速简洁地完成(图2)了。
VfOm#Ue0q 8^CdE*a
oJJ2y s/+@o:
8%]o6'd4 d^sS{m\ 2 编程思路
;^nN!KDjR :@zz5MB5@ 2. 1 建立Access 数据库
I/D(gY06< iE$qq~% 普通平键及键槽尺寸如图3 所示。
bcFG$},k lAU`7uE
:,03)[u{8 2Z
4Ekq0@ Access 是开发小型数据库应用系统的理想工具,功能灵活,易于学习和操作[3]。本软件便采用Access 来建立数据库。表的结构非常简单,只是对机械手册相关表格中部分字段的选取。对于键槽来说,则采用如表1 的表格形式(表1 只选取完整表格的一部分)。
Su99A. w SW|{)L, 2. 2 数据库操作部分
1e.V%!Xk n}(/>?/ 本软件对数据库的操作使用ADO(ActiveXData Objects)方式[3]。
m[6?v;w VWqmqR% 其中,打开数据库的语句如下:
<eP`Lu" `,|"rn#S Public Const DATABASE As String = " 常用
"w.gP8` 结构. mdb"
e ?FjN 9 Private cnn As ADODB. Connection
4Cs
|F7R Set cnn = New ADODB. Connection
WPT0=Hqp7 cnn. ConnectionString = " Provider = Microsoft.
EYNi` Jet. OLEDB. 4. 0;Data Source = " - + App. path +
k^B<t' " " + DATABASE + " ;"
C&Rv$<qc cnn. Open
+~b@W{ *;7~aM 对数据库中的数据,本软件最常用的是查询功能。例如:根据所给轴的直径d 查询键槽的相关尺寸b、t 的查询语句如下:
b_2bg>|; g,Z8I;A^ SELECT b,t FROM 普通平键及键槽尺寸表
ha+)ZF WHERE d > dmin and d < = dmax.
*@`Sx'5! k I 其他对数据库的操作与查询类似,不再赘述。
KITC,@xE_O J{fTx@?( 2. 3 绘图部分
BEWDTOY[ RV^
N4q4 对于键槽结构来说,图形分为两部分:主视图和剖面图。线条比较简单,主要采用画直线和圆弧的命令,尺寸标注也主要采用线性型尺寸标准方式,它的基本命令为:
jd]Om
r! <4r3ZV;' ThisDrawing. ModelSpace. AddDimAligned( startPoint,
v4c*6(m endPoint,location)。
S"+X+Oxp7? OolYQU1_ 下面以绘直线为例,表明作图过程[4]:
SVKjhZK ,*_=w^;Rr startPoin(t 0) = ArcCenPointX +(d/ 2# - t)
SB"Uu2)wZ startPoin(t 1) = ArcCenPointY + b / 2
ZBYFQTEE startPoin(t 2) = 0#
<y4hK3wP endPoin(t 0) = ArcCenPointX +(d / 2# - t)
f@Oi$9CZn endPoin(t 1) = ArcCenPointY - b / 2
Fo\* Cr9D endPoin(t 2) = 0#
VZhtx) Set lineObj =
wD+4#=/j ThisDrawing. ModelSpace. AddLine( startPoint,
#Bu W endPoint)
;ED` 7 )LOV)z|} 当然,绘图部分实现最终的图形显示,在程序中难免有相当多的数据的传输调用。本文采用的是全局变量的形式。例如轴径:Public d As Double。
xZbiEDU ;1x(~pD*o 与AutoCAD的接口可以使用菜单方式,也可以采用命令方式,都非常方便简单。
eO7 )LM4 9BW"^$ 3 结束语
O7D aVlln >JOEp0J 本文所实现的对常用结构的参数化设计,是在AutoCAD环境下,利用VBA 这种编程语言完成的。界面简洁,简单易用,减少了绘图人员的查阅标准时间,减轻了绘图工作量,提高了出图速度,并且可以避免在绘图和查表的交错进行中产生的失误,具有一定的实用价值。
Q8d-yJs& JTg:3<L 参考文献:
E~]37!,\\9 [1]董玉德,谭建荣,赵韩,等. AutoCAD系统开发技术-程序实现
K"fr4xHq 与实例[M]. 合肥:中国科学技术大学出版社,2001
l-/fFy)T [2]西北工业大学工程制图教研室. 画法几何及机械制图( 下)
Zw@=WW[Q`p [M]. 西安:陕西科学技术出版社,2000
p;nRxi7' [3]启明工作室. Visual Basic Access 数据库应用系统开发与实例
^HiI [M]. 北京:人民邮电出版社,2004
EhWYFQ [4]张帆,郑立楷,王华杰. AutoCADVBA 开发精彩实例教程
b{
M'aV [M]. 北京:清华大学出版社,2004