找回密码
 注册会员

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 624|回复: 0

研究应用VBA实现CAD与PDM信息集成的技术方案

[复制链接]
发表于 2010-9-13 22:24:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转磨削论坛

您需要 登录 才可以下载或查看,没有账号?注册会员

×
目前很多企业使用各种软件系统,以实现产品设计、-工艺设计、生产计划、加工制造、供应管理、销售管理和质量管理等环节的计算机网络信息链的先进管理。但是如何在这些产品设计(CAD)、工艺设计(CAPP)与产品数据管理(PDM)、企业资源计划(ERP)等软件平台之间实现信息集成,一直是企业构建全面信息化管理系统所关心的核心问题。 0 B: ]( G( J1 K/ J+ f5 y

   1 Auto CAD开发技术基础

3 c# y7 ]! e* y6 ?. B7 X2 m

    许多制造企业使用了Auto CAD作为辅助设计的主导软件,如何进一步发挥Auto CAD的功能,建立与数据库之间的数据传递关系,使之与产品设计有关的数据信息能为PDM系统方便、快捷、准确地获得,是Auto CAD系统高级开发的重要任务。

; {) f4 O) a8 t7 H

    1.1 Auto CAD编程接口

. |9 H% X1 J7 R) A5 f# O7 L

    Auto CAD提供了应用程序编程接口(API),开发人员可用此接口控制图形和数据库。所使用的接口类型由应用程序的需要决定。

" s! a" k" A$ A' u; l

    1)ActiveX Automation:是Microsoft基于部件对象模型(COM)体系结构开发的一项技术。可以用来自定义Auto CAD,与其他应用程序共享图形数据并自动完成任务。

M3 ~5 C: O; P; W: B* [

    2)Auto CAD VBA:是一个基于对象的编程环境,能提供丰富的开发功能。VBA和VB(Visual Basic 6)的主要区别在于:VBA与Auto CAD在同一进程空间运行,提供具有Auto CAD智能的、快速的编程环境。

+ C( Y7 |. |# d9 I n0 n

    3)Auto LISP和Visual LISP:是基于功能强大的LISP的编程语言。由于Auto CAD内置了LISP解释器,可以在命令行中输入Auto LISP代码,或从外部文件中加载Auto LISP代码。VISual LISP(VLISP)是为加速Auto LISP程序开发而设计的软件工具。

5 R1 \' V& T1 s2 A! h1 p: t

    在Auto CAD中使用ActiveX接口具有下列两个优点:(1)可以在多种编程环境中编程访问Auto CAD图形。在ActiveX Automation出现之前,开发者只能用Auto LISP或C++接口访问Auto CAD图形。(2)更易于与其他Windows应用程序(例如Microsoft Excel和Microsoft Word)共享数据。

9 Z+ }5 E) X, D/ L; X% W5 n. Y

    1.2 用Auto CAD VBA开发程序

; i, c3 V/ v" J

    VBA通过Auto CAD、ActiveX Automation接口向Auto CAD发送信息。Auto CAD VBA允许Visual Bas.ic环境与Auto CAD同时运行,并通过ActiveX Auto—mation接口提供对Auto CAD的编程控制。这样就把Auto CAD、ActiveX Automation和VBA紧密连结在一起,提供一个非常强大的接口。它不仅能控制AutoCAD对象,也能向其他应用程序发送数据或从中提取数据。

+ m( @7 F0 l l3 {- I, b

    把VBA集成到Auto CAD,为自定义Auto CAD提供了一种易于使用的可视化T具。例如,用户可以创建一个应用程序,用于自动提取属性信息,把结果直接插入Excel电子数据表或其他数据库中,可执行所需的任意数据转换。

0 V. k+ k$ C s) a1 |' p

    事实上Auto CAD具有非常完善的二次开发功能,它提供了应用程序编程接口(API),多种应用程序可通过该接口控制图形和数据库,并可从用作Auto.mation 控制程序的任何应用程序中创建和操纵AutoCAD对象。Automation使编制跨应用程序执行的宏成为现实。

/ I$ Q8 o, v. F) G* X

    1.3 产品零/部件编码的设计

# _9 G5 q; Q/ |9 \1 _0 Q2 g: z

    实现对产品及零/部件信息准确、方便识别的编码处理,是实现CAD与PDM信息集成的基础。产品零件编码设计原则应使编码有利于PDM生成产品的各种BOM,便于CAPP等系统继承设计数据,引导生产计划和生产制造。

% R& p' T4 e) Y0 D3 A

    因此,零/部件编码既要考虑便于工程人员理解和使用,符合规范,又要充分、准确地描述PDM所要求的信息。对要求反映产品结构逻辑关系的,应该采用树式结构,它反映产品的逻辑隶属关系,可以自动集成CAD与PDM产品信息的零/部件编码。而对于生成各种物料清单(BOM)的影部件编码,则应结合成组技术,采用分类编码方式。代码的结构一般采用链式与树式的混合结构。

$ @0 J! j3 J( b# ^) }2 F. D

    在CAD与PDM信息集成的系统中,要求产品影部件编码既要有反映产品逻辑结构的信息,又要有反映零部件特征的信息。这样的产品编码位数较多,而不同的用途仅需要编码的部分位数信息。为方便使用,可以将零/部件编码拆分成两个编码项,一项是零/部件逻辑关系编码,即代号编码,另一项是零/部件几何物理特性编码,即特征编码。代号编码采用树式结构(分级结构),而特征编码采用链式与树式的混合结构。无论是代号编码还是特征编码,都应采用分段编码的方式。同一零/部件两种编码是一对一的关联。不同的企业应该根据自身的实际需要来制定产品编码规则,也可以借鉴国内外通用的编码标准资料,并结合成组技术(GT)来完成产品设计编码。

- ~1 A' N5 T; y

    1.4 图形和数据库信息交换

0 Y0 F! T2 A' Q7 |, c" |: i: R

    Auto CAD图形与数据库之间数据交换是实现Auto CAD与PDM系统信息集成的前提。Auto CAD图形与数据库之间的数据交换可以有两种形式:一种是属性链接方式;一种是新数据链接方式,即建立链接样板。对于Auto CAD与PDM系统的集成要求而言,实现设计图样中诸如标题栏、明细栏等有关数据自动传递至Auto CAD系统之外的数据库系统之中,尽量不再需要人为地二次建立数据库和输入数据。鉴于上述原因,采用属性链接方式更为灵活便利,符合工程设计人员的要求。

7 ]7 }+ R) x7 m1 v: [; r) r _

    1)Auto CAD与数据库链接:Auto CAD内嵌VBA开发环境,通过编程操作Automation对象,实现对Auto CAD的操作,VBA工程中的宏(macro)与Auto CAD其他操作在同一进程中完成对图形的操作。与此同时VBA可以与VB一样跨应用程序操作数据库系统,通过配置DB Engine数据库引擎(Jet),实现数据库链接操作。

; R' s7 P# T4 x1 O

    2)属性定义与提取:创建标题栏、明细栏图形块(BLOCK),将零/部件代号、编码、名称和材料等信息设定为相应图块的属性值。属性定义和属性提取均由VBA程序创建,过程如下:

$ ^$ x( |/ m0 U+ T) p

    (1)属性定义:完成属性图形块创建,包含标题栏、明细栏所有信息的属性设定。

# }( M% m: J* j1 I

    (2)标题栏、明细栏信息添加:实现属性图块调用,属性值添加,图块插入等操作。

% e* p& l2 k, r1 v! T0 v

    (3)数据库操作:自动创建数据库文件,建立数据表、数据字段,并在新记录添加过程中对数据库、表以及对应记录进行判别和反馈,防止记录重复和遗漏。

1 S4 f" i w `8 v" z6 [1 w" j

    (4)属性提取:取出命名图块的各项属性值,添加至数据库,成为数据表中的对应记录。

7 ] q; W* J! y1 z/ X. {3 M! D( ~

    2 产品设计图中基本设计信息数据库的创建

6 a/ @! x( Q8 p" @9 \ j0 x4 P

    通过对产品及其影部件等基本设计信息的处理,能够体现m组成产品的各项基本状况。1)体现产品逻辑结构——产品结构树。一个产品及其零/部件的代号编码可以建立产品结构的树状结构的逻辑组成。它是PDM的重要内容。2)体现整个产品所有材料的组成、零/部件种类和数量,即材料清单(BOM)。3)体现设计签名、设计审批等资料信息的管理,为产品设计管理提供设计流程信息。4)体现工艺设计信息。与CAPP信息集成,为计算机辅助工艺设计提供了可直接利用的基础设计信息。

3 H ~7 A+ C1 y, e

    总之,产品基本设计信息数据库的自动建立,为PDM和CAPP提供了信息集成的基础数据库,是CAD/CAPP/PDM信息集成的重要环节。

0 y* A" o# s! S& l+ B! |7 E$ g

    2.1标题栏、明细栏詹眭图块的建立

! r9 Z: X: U9 ^8 E* F

    1)创建图块:制作标题栏、明细栏图块可以采用交互式绘图的方式,也可以采用编程的方式实现。

2 j4 R$ ~" k9 ^9 P) Q8 v

    2)属性定义:标题栏图块定义的属性值有零件代号、零件名称、零件编码、材料、总量、绘图比例与图幅信息,还有用于设计批签的设计员与日期、审核员与日期、工艺审核与日期、标准化与日期和批准与日期。明细栏定义的属性值有代号、名称、材料、数量和属性。

& x/ {3 d3 ]# }& w+ J" f4 Q

    3)输出块图形文件:定义好的属性图块应作为全局块输出图形文件,并将其保存于特定的路径与文件夹。

$ u4 A! `: `8 v! W

    2.2产品设计图中编辑标题栏与明细栏

% I' ?/ A D' Q5 A z9 [7 a: y

    产品图样设计过程中要编辑标题栏、明细栏信息,这一过程就是图形文件的属性添加过程。添加属性的方法有多种多样,如何以最合适的方式进行编辑、符合工程设计人员的操作习惯等要求都是保证数据正确性必须考虑的凶素。Auto CAD VBA是面向对象的程序设计技术,可以通过运行VBA窗体模块程序,完成对标题栏与明细栏的属性添加工作。

) f: D' E5 B# x% M9 M1 a+ P

    2.3标题栏、明细栏信息数据提取与建库

+ B6 \* K& H4 V) S

    图档中标题栏、明细栏属性的提取有两种方式,一种是在编辑标题栏、明细栏的同时,将其属性值添加到数据表的记录中,如果修改标题栏或明细表,那么程序同时修改数据表记录;另一种是标题栏、明细表编辑完成后,执行便利图档中插入的具有特定名称的图块,将属性一一取出,追加至数据库中。

, q* N1 I' U7 b

    3 通过VBA应用程序实现数据交换和信息集成

* L1 Y/ W- z0 v2 A

    Auto CAD VBA工程是在VBA集成开发环境(VBA IDE)下创建编辑的。VBA工程可以是内嵌VBA工程,也可以是独立的全局VBA工程。全局VBA工程具有比较多的功能,可以在Auto CAD图形中运行,也可以在工程中打开和关闭Auto CAD图形。全局工程比较容易和其他用户共享,而且可以制作共享的宏资源库,当使用VBA开发通用应用程序时,应将其保存为全局工程。全局工程不会自动加载,必须单独加载该丁程,才能执行其中的宏。

# u4 c, u1 C' y+ G

    Auto CAD VBA工程可以采用Auto CAD界面菜单或命令(VBALOAD)方式加载,也可以采用通过编程控制方式加载。比较通用的方式是制作启动菜单文件,利用菜单控制加载各种VBA应用程序,并执行VBA工程中的宏。创建和编辑下拉菜单群组,通常可以利用Auto LISP语言编辑原Auto CAD文件,也可以采用VBA开发新的菜单群组文件,并将VBA工程中的宏在Auto CAD启动时自动运行即可。

& G6 j+ r- `$ R$ d- ~

    4 结语

- R s) j2 [# }6 E

    Auto CAD VBA作为Auto CAD的二次开发工具,可以与Auto CAD图形操作同进程运行,通过ActiveXAutomation可以操纵几乎所有Auto CAD对象。同时它具有大多数的VB语言功能,可以操纵各种数据库软件,进行数据库编程操作,从而能够在Auto CAD系统中跨应用程序操作数据库,与数据库进行数据交换。同时VBA与Auto LISP程序设计语言结合运用使得开发Auto CAD与PDM集成接口变得更加便捷。这种集成Auto CAD与PDM的开发方式是实现企业信息化系统技术集成的有效模式,非常适用于中小型机械制造企业信息化系统的开发实现。

f4 m2 u3 q0 j b& I) ~, t5 z
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

中国磨床技术论坛
论 坛 声 明 郑重声明:本论坛属技术交流,非盈利性论坛。本论坛言论纯属发表者个人意见,与“中国磨削技术论坛”立场无关。 涉及政治言论一律删除,请所有会员注意.论坛资源由会员从网上收集整理所得,版权属于原作者. 论坛所有资源是进行学习和科研测试之用,请在下载后24小时删除, 本站出于学习和科研的目的进行交流和讨论,如有侵犯原作者的版权, 请来信告知,我们将立即做出整改,并给予相应的答复,谢谢合作!

中国磨削网

QQ|Archiver|手机版|小黑屋|磨削技术网 ( 苏ICP备12056899号-1 )

GMT+8, 2024-11-16 10:16 , Processed in 0.172441 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表