沈阳航空工业学院 王霞
flb3Iih GWP"i77y0s 摘 要:AutoCAD是机械设计人员最常用的绘图工具,功能非常强大,但常因缺乏常用结构图形库而影响绘图效率,为此,论文提出在AutoCAD环境下采用AutoCADVBA 方式对机械图形中的常用结构进行参数化设计的解决方案。由于常用结构的开发方式类似,便以轴类零件中键槽结构的主视图和剖面图为例,讲述了Access 数据库的构建方法、利用ADO 方式来开发数据库的过程和编程实现最终图形的过程。
J-X5n 3I& 关键词:AutoCAD,常用结构,参数化设计
A.<X78!^ ',O@0L]L AutoCAD作为应用最广泛的绘图软件,它的功能非常强大,基于AutoCAD环境下的二次开发也很方便。但是,在AutoCAD绘图软件的各种版本中,均无现成的常用结构图形库。本文采用AutoCADVBA(Visual Basic for Applications),针对各类零件特点的常用结构,如轴类零件的键槽、带轮槽、密封圈槽、移出剖面图和局部放大图等,实现了对常用结构的参数化绘图[1]。绘图人员只要输入要求的参数,就可以自动生成对应图形,简单方便实用。由于常用结构的编程过程非常相似,下面就以键槽为例,讲述标准结构参数化设计及绘图过程。
Mzb_o2^( S
- 7JDE> 1 参数选择
#XmN&83_ 8YYY *> 键槽是轴类零件上常见的结构,通过对图1和图2 的比较可见,只要图2 中5 个参数给定,就可将键槽的主视图和剖面图确定下来[2]。而且,根据标准机械设计手册,参数中的b、t 是由轴径d决定的,那么,绘图过程需要的参数只有三个:d、l、a。而另外两个参数b、t 可作为数据库内容通过d 来查询,这部分任务通过程序来完成。因此,经过分析可知,绘图人员只要输入参数d、l、a 的数值就能快速简洁地完成(图2)了。
AM Rj N; [N$@nA-d
Jl^oDW 8#oF7eE
4P`\fz dxASU|Yo9 2 编程思路
[;X YT +)7NWR\ 2. 1 建立Access 数据库
s&fU|Jk8 qi/%&)GZ 普通平键及键槽尺寸如图3 所示。
yp :yS B8IfE`
4wNxn
lP WxXVL" Access 是开发小型数据库应用系统的理想工具,功能灵活,易于学习和操作[3]。本软件便采用Access 来建立数据库。表的结构非常简单,只是对机械手册相关表格中部分字段的选取。对于键槽来说,则采用如表1 的表格形式(表1 只选取完整表格的一部分)。
mCq*@1Lp9 33u7 2. 2 数据库操作部分
c 9ghR0WM C-2n2OM. 本软件对数据库的操作使用ADO(ActiveXData Objects)方式[3]。
Gn_v}31d% ltD:w{PO] 其中,打开数据库的语句如下:
2_Pe/ sH&8"5BT% Public Const DATABASE As String = " 常用
Z:n33xh=< 结构. mdb"
h@Hmo^!9J Private cnn As ADODB. Connection
WcUeWGC> Set cnn = New ADODB. Connection
|kVxrq cnn. ConnectionString = " Provider = Microsoft.
q#WqU8~Y Jet. OLEDB. 4. 0;Data Source = " - + App. path +
cb
UVeh7Q " " + DATABASE + " ;"
MD1,KH+O cnn. Open
{'X "9@ HX
<;=m 对数据库中的数据,本软件最常用的是查询功能。例如:根据所给轴的直径d 查询键槽的相关尺寸b、t 的查询语句如下:
pkM32v- -><_J4 SELECT b,t FROM 普通平键及键槽尺寸表
/\\C&Px WHERE d > dmin and d < = dmax.
Xt~/8)& IjrTM{f 其他对数据库的操作与查询类似,不再赘述。
"#JoB X@yE &V2G<gm0 2. 3 绘图部分
q?t>!1c %M^b Z? 对于键槽结构来说,图形分为两部分:主视图和剖面图。线条比较简单,主要采用画直线和圆弧的命令,尺寸标注也主要采用线性型尺寸标准方式,它的基本命令为:
?9PNCd3$d t8^*s<O ThisDrawing. ModelSpace. AddDimAligned( startPoint,
RP(FV<ot endPoint,location)。
|Z"hq [S9n F 下面以绘直线为例,表明作图过程[4]:
#u2PAZ@qd ?Ts
Z_ startPoin(t 0) = ArcCenPointX +(d/ 2# - t)
=+"XV8Fi, startPoin(t 1) = ArcCenPointY + b / 2
[hiOFmMJZ- startPoin(t 2) = 0#
___+5r21\ endPoin(t 0) = ArcCenPointX +(d / 2# - t)
5
WAsEP endPoin(t 1) = ArcCenPointY - b / 2
dkVVvK endPoin(t 2) = 0#
xbmOch}j6 Set lineObj =
R'80 { ThisDrawing. ModelSpace. AddLine( startPoint,
y\%4Dir endPoint)
2<J82(4j AM }OLHj 当然,绘图部分实现最终的图形显示,在程序中难免有相当多的数据的传输调用。本文采用的是全局变量的形式。例如轴径:Public d As Double。
t>b^S, @D7cv"
与AutoCAD的接口可以使用菜单方式,也可以采用命令方式,都非常方便简单。
3+#bkG {wMCo, 3 结束语
^^%*2^ 7*4F-5G/ 本文所实现的对常用结构的参数化设计,是在AutoCAD环境下,利用VBA 这种编程语言完成的。界面简洁,简单易用,减少了绘图人员的查阅标准时间,减轻了绘图工作量,提高了出图速度,并且可以避免在绘图和查表的交错进行中产生的失误,具有一定的实用价值。
p<J/J.E m\k$L7O 参考文献:
"+AeqrYYm5 [1]董玉德,谭建荣,赵韩,等. AutoCAD系统开发技术-程序实现
#:{u1sq; 与实例[M]. 合肥:中国科学技术大学出版社,2001
8.A ;
I< [2]西北工业大学工程制图教研室. 画法几何及机械制图( 下)
'<@ PgO~ [M]. 西安:陕西科学技术出版社,2000
MZ+"Arzb [3]启明工作室. Visual Basic Access 数据库应用系统开发与实例
g|T' oK [M]. 北京:人民邮电出版社,2004
(d~'H{q [4]张帆,郑立楷,王华杰. AutoCADVBA 开发精彩实例教程
KT|$vw2b [M]. 北京:清华大学出版社,2004