< 返回
teamcenter engineering中清单汇总功能的二次功能实现

1前言

美国ugs公司的teamcenter engineering是一套成熟的商品化PDM软件系统,该系统采用了c/s结构,其客户端及服务器端均能够进行二次开发以满足用户的特殊需求。其中,客户端是用java语言开发的用户界面层,同样它的二次开发也使用java语言;服务器端的二次开发则要利用itk工具包及c语言,itk实质上就是一套经过封装的c语言程序集[1]。由于teamcenter engineering版本的升级可能导致所开发程序需要改写并重新编译,所以二次开发的原则是尽可能利用teamcenter engineering已有的功能,减少二次开发量。基于此,二次开发的重心应放在客户端,而服务器端的已有功能则应尽量利用。

我公司在实施teamcenter engineering之前,曾应用金蝶的k3系统管理零件编码(零件模型或图纸数据直接置于共享服务器上)。实施teamcenter engineering之后,发现新系统中找不到k3所具有的清单汇总功能,即对整机bom或多个组件bom按照零件编码进行单层或所有层的汇总显示方式。而在标准机基础上做客户化设计人员在做差异bom校对时,对这一功能尤为倚重。另外,teamcenter engineering在bom输出或打印方面,均没有非常合适的格式。

所以,尽管teamcenter engineering中pse程序处理bom方面功能非常强大,但上述特殊需求的欠缺引起了少部分设计员应用中的抵触情绪,也影响了系统推广。为此,我们力图通过客户端二次开发的方法来解决这些特定需求,本文对这些功能的开发过程进行了详细阐述。本文的开发基于我公司目前应用的teamcenter engineering v9.1版本,对其它版本的开发同样具有借鉴意义。

2客户端开发环境搭建

2.1注册程序(registry)

teamcenter engineering客户端(portal)的二次开发分为注册程序与开发程序两个阶段。对portal开发而言,注册程序是一个至关重要的环节。所谓注册程序,就是要在teamcenter engineering的程序组内增添程序入口,用于启动新开发的程序。不论是二次开发,还是portal自身的原开发,都是通过这一注册机制调用属性文件来定义应用程序的实现类(classes)、启动图标、本地化标题、搜索优先权等。

注册程序的具体实现步骤如下:

① 运行实用程序(utilities)组内的应用程序向导(application wizard),然后输入应用程序名称cllctbom;

② 通过点击选择的方法确定将程序装入iman组,即,使客户程序的按钮加入到该组(如有需要,也可在portal_user.properties中增加新组);

③ 输入客户程序的包名“com.haitian.technology.research.yechar”,系统将在选定目录下自动建立与包名对应的子目录,并在该子目录下自动生成六个空壳源文件:cllctbom.properties、cllctbom_user.properties、cllctbomapp.java、cllctbomappmenubar.java、cllctbomapppanel.java、cllctbomapptoolbar.java。这些源文件正是后续开发程序阶段的起点,其中前两个文件是程序注册文件,在这两个文件内容发生冲突情况下,cllctbom_user.properties拥有更高的优先权;后四个应用类所处的层次及调用关系如下图1所示。

图1. 二次开发程序类所处层次与调用关系示意图

④ 上述过程完毕后,系统会在portal_user.properties中自动添加新程序的名称(title)、图标(icon)、会话(session)等界面信息,此时可根据需要进行人工修改,如将名称改成中文“清单汇总”等。

2.2开发工具及环境搭建

经过注册之后的新程序只是一个框架,并不能执行任何功能。程序开发阶段就是对前述空壳源文件进行代码编写、调试、编译的过程。所需要用的工具就是java语言的编译环境,包括jdk或jbuilder这样的java集成开发环境(ide)等。本文直接运用jdk1.3.1进行开发。

1)环境变量设置

因为没有使用ide工具,所以要先设置一些环境变量。如在命令行环境下运行:set java_home=d:jdk1.3.1_08,用以表达jdk的安装路径。同样,portal_root定义成teamcenter engineering portal 的安装路径等等。

2)用%java_home%injavac命令编译客户程序。

3)用%java_home%injar命令打包java类、图标文件、属性文件等。

4)编辑portal.bat文件,将客户程序(如bomcollect.jar)包含到portal.jar之前,如下:

set java_command_line= %java_command% %java_heap_size% -classpath "%ipr%;… %ipr%omcollect.jar; … %ipr%portal.jar; … %classpath%"

运行teamcenter engineering portal后,就可调用新的“请单汇总”程序。

3清单汇总程序开发

3.1界面设计

由于清单汇总涉及到父物料与子物料的多行并存显示,所以采用窗体分割方式加以总体处理,整个程序界面如图2所示。其主要特点如下:

① 为满足我公司的实际需要,全新设计表格模式ht_parttablemodel,用以表达零件属性;

② 用jcombobox 切换“单层汇总”和“所有层汇总”两种模式,方便地实现了单bom的所有层汇总、多bom的单层汇总、多bom的所有层汇总;

③ 用jtabbedpane表达“子物料清单”和“汇总信息”两部分,其中“汇总信息”一屏用以显示差异bom与母bom汇总后的回收子物料(数量为负的子物料)、零子物料(数量为0的子物料)的统计信息和具体零件编码,免除了设计人员的人工校对。

图2. 清单汇总功能的程序界面及应用实例

3.2系统流程

系统运行后的整个流程如下图3所示:其中“物料类型”一项是我公司的自定义零件属性之一,用“普通”来表达需要进出仓的实际零部件,“虚项”表达只用于指导装配的虚拟组件(无须进出仓)。所以在所有层汇总过程中,“虚项”类型的零件本身不被汇总,而它下面挂的子物料则要被搜索出来加以汇总,这一过程叠代进行,直至最底层全为“普通”类型为止。

图3. 系统流程图

3.3辅助功能开发

在实际应用中,往往需要将bom表输出或加以打印。然而,teamcenter engineering中pse应用程序自带的html、文本或图形等几种输出或打印方式,效果均不理想。所以在“清单汇总”功能中,开发了拷贝bom行(excel格式)功能,即:点击该功能按钮后,整个bom按照特定格式进入系列剪贴板,可以被粘贴到excel文件或其它文本中。同时也开发了“打印bom”功能,可以将bom按照“所见即所得”方式打印出来。

图4. bom输出等辅助功能的调用

另外,针对单个子物料的属性输出,还开发了“点击即拷贝”功能。也就是说,单击某一物料的“物料编码”、“物料名称”等各属性项,就可以将相应表格中的数据直接粘贴到其它文档中;单击零件的“序号” 项,可以将相应零件所有的属性项粘贴到其它文档中。上述辅助功能的开发为提高工作效率、避免文字输入出错带来了很大的便利。

4结论

本文通过对teamcenter engineering v9.1系统的客户端进行二次开发,实现了清单汇总及一些辅助功能。这些功能在我公司均已得到一年多的实际应用,满足了设计人员的特殊需求,为PDM系统在公司设计部门的全面推广铺平了道路;同时也是对teamcenter engineering原有功能的一个有力补充。文中提供的实施思路和方法已得到实践验证,能为其它用户进行客户化开发时所借鉴。