摘要 本文阐述了在液压cad系统中,针对autocad r13 for windows二次开发环境下,利用其内部asi接口技术进行程序设计,实现与visual foxpro 3.0之间进行数据交换的 方法 。
关键词:autocad 二次开发 接口 数据交换
1 引言
数据交换是cad的核心技术,可以说没有数据的有效交换,就没有cad优越性的充分发挥。在autocad环境下进行cad软件二次开发时,如何实现各模块间数据的有效交换,如何解决各类不同软件间的接口 问题 以及如何实现图形实体与非图形实体数据的联系,是二次开发cad系统解决的关键问题。
本文着重讨论了autocad r13 c4 for windows环境下与visual foxpro 3.0之间进行的数据交换的asi (autocad sql interface)程序设计方法,并具体 应用 于液压系统的cad软件中。
2 autocad的开发与数据库的访问
象其他流行软件一样,autodesk公司在autocad r13内部提供了与外部数据库相互联系的机制。autocad本身含有asi(autocad sql interface)、ase(autocad sql extension)和dbms(database manager system)驱动程序几部分。autocad与数据库文件之间进行数据交换的示意图如图所示。
autocad与数据库文件之间数据交换示意图
asi遵循ansi/isosql标准,是用于从autocad中访问外部数据库的函数集。用asi建立的应用程序,均可通过autocad的开发应用系统;c语言开发的ads,visual c++4.0开发的arx或其内部所自带的autolisp语言连接到autocad系统中,同时可以在不同的数据库驱动程序支持下对不同的数据库进行数据的存取交换。
ase是一组命令集,可将sql连接到atuocad系统中。其实质就是利用asi建立的ads/arx的应用程序。使用ase可以在autocad内部对外部数据库中的数据文件的记录和字段进行查询和修改等操作,可以将数据关联到图形实体和非图形实体(如哑图中尺寸参数替换和明细表等)上,实现图形和数据间的双向查询,并可以实现在图形中动态跟踪显示数据。
autocad本身包含一组数据库驱动程序,其中每一个驱动程序都支持自己所连接的一种外部dbms。其中用ads/arx或autolisp建立的应用程序,不必考虑dbms专用的代码应用程序,是用asi编程还是用ase命令编程,其实质都是遵循通用sql标准的。
autocad支持的开发语言有turbo c,visual basic 5.0,visual c/c++4.0和内部拥有autolisp语言,其中c,vb通过建立生成ads的函数,vc生成的是arx函数,与autocad信息相联系。
ase作为autocad内部的一组命令,可用编程方式执行。ase作为autocad访问数据库的核心具有更直接访问数据库的能力,允许应用程序对多种dbms,dbms内的多个数据库,库内的多张表进行数据访问。ase和asi可根据需要单独或同时使用。ase方法在显示属性、编辑、列表框、基于查询等功能方面显得容易实现,但对于复杂的应用程序,就要使用asi方式编程实现功能。
3 asi方法的使用
3.1 asi的支持文件与开发环境
autocad r13 for windows所支持的asi编程的文件都存放在缺省的\acad\win\ase目录中。有asi目标库(文件后缀为.lib)如asiatm80.lib;asi头文件(asi.h含asi的通用定义)、(asierr.h包含返回出错代码值的含义)、(asiappl.h含主要的autocad sql结构查询语言的头文件)、(asisdata.h含c++的用户接口定义)。
用asi编制的应用程序,可用的编译器有:borland c/c++4.0、microsoft c/c++7.0、microsoft visual c++4.0以上版本等。
3.2 利用asi与数据库交互处理的实现过程步骤
连通数据库:通过asi-initsql,ads-initdrv,asi-connect分别对asi指定的dbms驱动程序进行初始化,登录到所指定的数据库。
打开一个通讯句柄:这可通过调用asi-compile函数来实现。在asi程序中,每条sql语句都通过一个通讯句柄来进行处理。
编译sql语句:通过调用asi-compile函数来实现。
执行sql语句:用asi-iexecute函数执行sql语句。
查询和处理数据:逐行查询结果,选取当前行,进行数据处理。所需的函数有:asi-fetch获得光标所在的当前行;asi-coldsc获得一列的说明;asi-delete删除当前行;asi-update更换当前行,等函数。
关闭通讯句柄:用asi-chandle函数关闭语句处理的句柄,并释放句柄。
断开与数据库的连接:调用asi-disconnect函数,断开登录的数据库;调用asi-temdrv函数,终止驱动程序;调用asi-temrsql函数,终止程序接口。
上述每一过程可用asi的出错代码处理函数进行错误信息处理,用asi-err获得一条出错代码,用asi-errmsg函数获得一条出错信息。
4 实例说明
本例给出一个由visual foxpro3.0环境下,建立起来的液压系统软件包设计中的顺序阀数据库文件sxflib.dbf,其数据结构如下表所示。
name
type
diameter
pressure
flux
scale
顺序阀
x-f*10d3-p-*
10.0
20.0
40.0
0.5
顺序阀
2x-f*10d3-ab/ba-*
10.0
20.0
40.0
1.0
单向顺序阀
xa-f*10d3-b-*
10.0
20.0
40.0
0.7
单向顺序阀
xa-f*10d3-b(a)-*
10.0
20.0
40.0
0.5
编制asi 应用 程序,实现所需功能:
(1)编制ins-rowvalue命令,实现将autocad图形上的数据和名称做一标记插入到数据库的记录中。
(2)编制get-rowvalue命令,实现从数据库选定行中读取数据,在软件的对话框中显示出来,并按数据所提供的比例画出图形。
(3)编制fetch-dallue命令,实现从数据库中读取所有记录,在对话框的列表框内显示出来,以便用户调用,插入图形中。
由于autocad可通过asi/ase、dbms访问数据库,所以使许多应用项目的设计思路大为开阔,节省了设计者的工作时间,提高了工作效率,降低了投入成本,有利于集成系统的实现。