机械专业外文翻译--Pro ENGINEER 软件二次开发技术
《机械专业外文翻译--Pro ENGINEER 软件二次开发技术》由会员分享,可在线阅读,更多相关《机械专业外文翻译--Pro ENGINEER 软件二次开发技术(11页珍藏版)》请在装配图网上搜索。
1、附录 THE TECHNOLOGY OF THE PROGRAM REDEVELOP ON PRO/ENGIN EER 0 Introduction Pro/ ENGINEER developed by Technology Corporation U SA is CAD / CAE / CAM software system. It integrates 3D solid modeling, designing, machining, analysis and drawing, famous for convenience, parametric feature modeling
2、and system relativity. At present, Pro/ENGINEER has extensive used in various fields in m any countries. Although Pro/E is general utility, it has some shortages in a few facets. Furthermore its design standard differ form our county’s standard. It is an important work to redevelop application
3、to adapt requirement of designer in various fields based on commercial CAD/CAM software platform. Most CAD/ CAM software support interface to redevelop, Pro/TOOLKIT is the redevelopment interface in Pro/E software. 1 Introduction to Pro/TOOLKIT Pro/ TOOLKIT is the customization toolkit for Pro/E
4、NGINEER from Parametric Technology Corporation (PTC). It gives customers and third parties the ability to expand Pro/ENGINEER capabilities by writing programming language code and then seamlessly integrating the resulting application in to Pro/ENGINEER. Pro/TOOLKIT provides a large library of functi
5、ons to provide the external application safe and controlled access to the Pro/ENGINEER database and applications. Pro/TOOLKIT is the PTC application programmer′s interface (A P I). Pro/TOOLKIT uses an object oriented programming style. Data structures for the transfer information between Pro/ENGINE
6、ER and the application are not directly visible to the application. These data structures are accessible only with Pro/TOOLKIT functions. The most basic Pro/TOOLKIT concepts are objects and actions. Each Pro/TOOLKIT library function performs an action on a specific type of object. The Pro/TOOLKIT co
7、nvention for function names is the prefix "Pro" the name of the object type, and the name of the action it performs. A Pro/TOOLKIT object is a well defined and self contained structure used to perform actions relevant to that object. Most objects are items in the Pro/ENGINEER database, such as featu
8、res and surfaces. Others, however, are more abstract or transient, such as the information resulting from a select action. 2 The technology of develop by Pro/TOOLKIT 2. 1 The method of work by Pro/TOOLKIT 2. 1. 1 Synchronous Mode Depending on how your synchronous application from Pro/ENGINEER, y
9、our application can be classified as either "DLL Mode" or "Spawned Mode" The following sectins describe DLL and Spawned synchronous mode. DLL Mode The standard method by which Pro/TOOLKIT application code is integrated in to Pro/ENGINEER is through the use of dynamically linked libraries (DLL s).
10、When you compile your Pro/TOOLKIT application code and link it with the Pro/TOOLKIT library, you create an object library file designed to be linked in to the Pro/ENGINEER executable when Pro/ENGINEER starts up. This method is referred to as "DLL mode." Spawned Mode Pro/TOOLKIT also supports a sec
11、ond method of integration: the "multi process" o r spawned mode. In this mode, the Pro/TOOLKIT application code is compiled and linked to form a separate executable. This executable is designed to be spawned by Pro/ENGINEER and runs as a child process of the Pro/ENGINEER session. In DLL mode, the ex
12、changes between the Pro/TOOLKIT application and Pro/ENGINEER are made through direct function calls. In multi process mode, the same effect is created by an inter process messaging system that simulates direct function calls by passing the information necessary to identify the function and its argum
13、ent values between the two processes. Multi process mode involves more communications overhead than DLL mode, especially when the Pro/TOOLKIT application makes frequent calls to Pro/TOOLKIT library functions, because of the more complex method of implementing those calls. However, it offers the foll
14、owing advantage: it enables you to run the Pro/TOOLKIT application with a source-code debugger without also loading the whole Pro/ENGINEER executable in to the debugger. If you use multi process mode during development of your application to debug more easily, you should switch to DLL mode when you
15、 install the application for your end users because the performance is better in that mode. However, take care to test your application thoroughly in DLL mode before you deliver it. Any programming errors in your application that cause corruption to memory used by Pro/ENGINEER or Pro/TOOLKIT are lik
16、ely to show quite different symptoms in each mode, so new bugs may emerge when you switch to DLL mode. 2. 1. 2 A synchronous Mode DLL and spawned modes are synchronous modes in the sense that the Pro/TOOLKIT application and Pro/ENGINEER do not perform operations concurrently. In spawn mode, each p
17、rocess can send a message to the other to ask for some operation to occur, but each waits for a returning message that reports that the operation is complete. Control alternates between the two processes, one of which is always in a wait state. A synchronous mode is a multi process code in which th
18、e Pro/TOOLKIT application and Pro/ENGINEER can perform concurrent operations. Unlike the synchronous modes, asynchronous mode uses remote procedure calls (.rpc) as the means of communication between the application and Pro/ENGINEER. Simple Asynchronous Mode In asynchronous mode, the application (c
19、ontaining its own main () function) is started independently of Pro/ENGINEER and subsequently either starts or connects to a Pro/ENGINEER process .A simple asynchronous application can spawn and connect to a Pro/ENGINEER process via the function Pro/Engineer Start (). During this startup, Pro/ENGINE
20、ER calls user initialize () if it is present in the application. The Pro/ENGINEER process "listens" for requests from the application and acts on the requests at suitable break points normally between commands. Full Asynchronous Mode In full asynchronous mode, the application implements a control
21、loop that "listens" for messages that arrive from Pro/ENGINEER. As a result, Pro/ENGINEER can call functions in the application, including callback functions for menu buttons and notifications. It is often necessary for your full asynchronous application to be notified of the termination of the Pro/
22、ENGINEER process. In particular, your control loop need not continue to listen for Pro/ENGINEER messages if Pro/ENGINEER is no longer running. In full asynchronous mode must contain a call to the function Pro/Event Process (), which takes no arguments. This function responds to Pro/ENGINEER messages
23、 in a manner similar to synchronous mode. 2. 2 The steps of Developing a Pro/TOOLKIT Application An asynchronous Pro/TOOLKIT application is fundamentally different in its architecture from a synchronous mode application, so we should choose between these methods before writing any application co
24、de. As a general rule, synchronous mode should be the default choice un less there is some unavoidable reason to use asynchronous mode, because the latter mode is more complex to use. 2. 2. 1 Writing application code A Pro/TOOLKIT application must always contain the functions user initialize () an
25、d user CD#3 2〗terminate ( ). These functions have the prefix "user " because they are written by the Pro/TOOLKIT application developer, but they are called from with in Pro/ENGINEER at the start and end of the session. The function user initialize () is called after the Pro/ENGINEER application has
26、been initialized and the Graphics Window has been created. This function should contain any initializations that your Pro/TOOLKIT application needs, including any modification of Pro/ENGINEER menus. The initialization function must return 0 to indicate that the Pro/TOOLKIT application was initialize
27、d successfully. Any other return value will be interpreted as a failure, and the system will notify the Pro/ENGINEER user that the Pro/TOOLKIT application failed. The function user terminate () is called at the end of the Pro/ENGINEER session, after the user selects "Yes" on the Exit confirmation di
28、alog box. Its return type is void. 2. 2. 2 Compiling and Linking a Pro/TOOLKIT Application The compiler options and system libraries needed to compile and link a Pro/TOOLKIT application are generally different on each platform. To ensure that the make file you use for building your Pro/TOOLKIT app
29、lication uses the correct options, you should base your make file on one of the make files located under the Pro/TOOLKIT load point. These are designed for building the various Pro/TOOLKIT applications whose source is included in the Pro/TOOLKIT installation. 2. 2. 3 Registering a Pro/TOOLKIT Appli
30、cation Registering a Pro/TOOLKIT application means providing information to Pro/ENGINEER about the files that form the Pro/TOOLKIT application. To do this, create a small text file, called the Pro/TOOLKIT "registry file," that Pro/ENGINEER will find and read. Pro/ENGINEER searches for the registry
31、file in the following locations, in this order: 1. A file called PROTK.DAT or PRODEV. DAT in the current directory 2. A file named in a "PROTK.DAT", "PRODEVDAT", or "TOOLKIT _ REGISTRY_ FILE" statement in the Pro/ENGINEER configuration file 3. A file called PROTK.DAT or PRODEV. DAT in the directo
32、ry
33、rectory (such as sgi_elf2 or i486_nt) < LANGUAGE> The name of the Pro/ENGINEER language the Pro/TOOLKIT application will be used with (such as "Usascii" (English), "German", or "Japanese") The registry file is a simple text file, where each line consists of one of a predefined set of keywords, fol
34、lowed by a value. The standard form of the registry file in DLL mode is as follows: name Your Application Name startup dll exec_file $LOADDIR/$MACHINE_TYPE/obj_filename. dll text_dir $LOADD IR revision 3 end The statements in the registry file are as
35、follow s: name ——Assigns a unique name to this Pro/TOOLKIT application. This is used to identify the application if there is more than one. Startup—— Specifies the method Pro/ENGINEER should use to communicate with the Pro/TOOLKIT application. This example specifies DLL mode. Exec_ file—— Specifi
36、es the name of the file produced by compiling and linking the Pro/TOOLKIT application. In DLL mode, this is a dynamically linkable library; in multi process mode, it is the executable of a complete program. Text_ dir—— Specifies the directory that contains the menu and message files used by the Pro
37、/TOOLKIT application. These files allow multi language support for menu buttons and messages used in the Pro/TOOLKIT application. Revision——Specifies the version of Pro/TOOLKIT against which you built the application. Use the name for the current release of Pro/TOOLKIT (for example, 2001, 2000i, 20
38、00i2, 2001). End—— Indicates the end of the descript ion of this Pro/TOOLKIT application. 2. 2. 4 Stopping and Restarting a Pro/TOOLKIT Application Pro/TOOLKIT supports the ability to stop and restart a synchronous application with in a single session of Pro/ENGINEER. This is particularly useful
39、during development of an application because it enables you to make changes to your source code and retest it without having to restart Pro/ENGINEER and reload your test models. Use the Auxiliary Applications dialog box to stop and restart applications .To make this option available, the registry fi
40、le (default name PROTK. DAT) should contain one of the following lines: Multi process mode: startup spawn DLL mode: startup DLL If you want to be able to stop and restart your Pro/TOOLKIT application with in Pro/ENGINEER, you must also add the following statement to the definition of the applic
41、ation in the registry file: Allowed stop TRUE If you use the allow stop option, you might also set Pro/ENGINEER to not start the Pro/TOOLKIT application until you explicitly request it. To do this, you must add the following statement in your registry file: delay start TRUE 2. 2. 5 Unlocking a Pr
42、o/TOOLKIT Application Before you distribute your application executable to the end user, you must unlock it. This enables the end user (your customer) to run your application without having Pro/TOOLKIT as an option. To unlock your application, enter the following command: < Pro/ENGINEER>/ bin/prot
43、k unlock file name 3 Conclusions Pro/TOOLKIT application extends the 3D modeling and library of the standard part, and increase some functions of the graphics information′s label, product data management. In this way, we can improve the function of Pro/ENGINEER and accelerate the development of
44、CAD/CAM software. References: [1 ] Parametric Techno logy Corporation. Pro/TOOLKIT User′s Guide [Z ]. U SA. 2001. [2 ] LA I Chao2an, L IZhen2nan. The Key Techno logy about Application Development of Pro/E [J ]. computer applications 2001. 9 译文 Pro/ ENGINEER 软件二次开发技术 ——李其其格, 武建新, 贺向新 0 简介 Pr
45、o/ENGINEER是由美国PTC(Parametric Technology Corporation—参数技术公司)开发的CAD/CAM/CAE集成软件系统。它是集成化的三维实体造型、设计、运动仿真、结构分析、绘制工程图软件,特别以方便的参数化特征造型和系统相对性而闻名。目前,Pro/ENGINEER的使用已经延伸到许多国家的各个领域了。 尽管Pro/E是一个一般化的公共程序,但是它在某些方面还是存在一定的不足。此外,它自身的实际标准和我国的国标有所不同。因此,二次开发适应各种不同的领域设计者基于商业的CAD/CAM的软件平台的需求的申请是一项很重要的工作。许多CAD/CAM软件都支持接口
46、的二次开发,Pro/TOOLKIT是Pro/E的二次开发接口。 1 Pro/ TOOLKIT简介 Pro/E用Pro/ TOOLKIT从美国技术参数公司(PTC)设定工具箱。这使用户可以通过编写程序源代码来提高Pro/E的能力,然后在Pro/E中得心应手地使用产生的申请。Pro/ TOOLKIT提供了一个很大的功能图书馆来保存外部的保存,并控制Pro/E的数据库的存取以及申请。Pro/ TOOLKIT是PTC程序申请的接口。 Pro/TOOLKIT用一种客观的定向规画风格,Pro/E和申请之间传递的数据并不是直接可以看的见的,而只能在Pro/TOOLKIT的功能图书馆中存取。最基本的Pr
47、o/TOOLKIT概念就是实体和造型,每一个Pro/TOOLKIT功能图书馆都在一个特殊的实体上运行一个造型。Pro/TOOLKIT功能图书馆中每一个实体都有一个前缀名“Pro”,并用这个名字代表所做的造型,每一个实体都经过定义,并自动连接到相关的实体造型中。大部分实体都存在于Pro/E数据库中,比如特征和曲面。其他的,都以摘录或者暂态形式存储,例如一个造型产生的信息。 2 Pro/TOOLKIT发展的技术 2.1 Pro/TOOLKIT的工作方式 2.1.1 同步模型 根据你如何从Pro/E中申请同步模型,你的申请可以分为“DLL模型”或“Spawned模型”。接下来为您详细介绍DL
48、L和Spawned同步模型。 DLL模型 把Pro/TOOLKIT申请整合到Pro/E中的标准方法是通过动态地连接到Pro/TOOLKIT图书馆中(DLLs)。在Pro/E运行的时候,当你编译一个Pro/TOOLKIT文件代码并将其导入Pro/TOOLKIT图书馆中,你便创建了一个连接到Pro/E运行器中的实体文件。这就是“DLL模型” Spawned模型 Pro/TOOLKIT也支持第二种整合方法:“multi 程序”或者Spawned模型。在这个模型中,Pro/TOOLKIT申请代码被编译并连接到一个独立的运行器中,这个运行器被设计用来形成Pro/E的产物并作为它的一个子程序来运行
49、。在DLL模型中,Pro/TOOLKIT和Pro/E之间的数据转换是通过直接的功能响应来实现的;而在multi 程序模型中,则是通过一个内部程序信息系统来完成的,这个系统是通过模拟信息在两个程序中的转换所必须的功能并通过辨别此功能值来确定功能响应的。Multi 程序模型比DLL模型包含更多的交流信息,特别是当Pro/TOOLKIT更加频繁地访问Pro/TOOLKIT图书馆功能的时候,因为实现这些功能响应需要更复杂的方法。然而它有以下几方面的优点:它可以用一个源代码纠正直接运行Pro/TOOLKIT而不用下载整个Pro/E纠正运行器。 在你改进你的申请使之更容易纠错是,如果你用Multi 程序
50、模型,那么在安装你的终端用户申请时你必须转变为DLL模型,因为DLL模型的表现比较好。然而,在你投递你的申请时,注意在你的DLL模型上彻底地测试。你程序里的任何错误都会引起Pro/E使用记录的乱码,或者Pro/TOOLKIT会给你一个完全不同的结果,这样的话,在你转换你的DLL模型时就会产生新的错误了。 2.1.2 非同步模型 DLL模型和Spawned模型都是同步模型,所以Pro/E和Pro/TOOLKIT不会同时产生操作。在Spawned模型中,每一个程序都可以给另一个发送信息来要求某些操作,但是每一个程序都得等待一个操作已经完成的反馈信息才能进行。两个程序中的控制代理器总有一个通常处
51、于等待状态。 非同步模型是Pro/TOOLKIT申请和Pro/E可以同时操作的一种复合程序模型。与同步模型不同的是,非同步模型用的是远程程序呼叫(.rpc),即Pro/TOOLKIT申请和Pro/E可以相互交流。 简易非同步模型 在非同步模型中,Pro/TOOLKIT申请(包括其自身的main()动作)是独立于Pro/E启动的,然后再启动或者连接到Pro/E程序中的。一个简易的非同步模型经由Pro/Engineer Start ()可以产生或者连接到一个Pro/E程序。在这个启动过程中,如果user initialize ()存在于申请中,那么Pro/E程序就呼叫这个程序。Pro/E程序
52、“听”来自申请的要求并在适当的休息点对指令之间正常地执行动作。 完全的非同步模型 在完全的非同步模型中,申请实施一个“听从”来自于Pro/E程序的信息的控制循环,因此,Pro/E程序可以调用申请里的动作,包括收回菜单按钮和通知的动作。通常,你的完全的非同步申请必须听从来自Pro/E程序的终止程序。有一种特殊情况就是当Pro/E程序不再运行的时候,你的控制循环就不需要听从Pro/E程序的命令了。完全的非同步模型必须要有一个无条件呼叫Pro/Event Process ()的动作。这个动作以和同步模型相似的信息反馈方式反馈给Pro/E程序。 2.2 发展一个Pro/TOOLKIT申请
53、的步骤 一个非同步的Pro/TOOLKIT申请在发展步骤上和同步申请基本上是不同的,所以,在写一个申请代码之前,我们必须先考虑好用适当的方法。通常有一条规则,同步模型必须预先选择,除非有不可避免的原因才选择非同步模型,因为后者使用起来很复杂。 2.2.1编写申请代码 一个Pro/TOOLKIT申请必须包含user initialize () 和 user CD#terminate ( )两个动作,这些动作都有一个前缀“user”,因为它们都是由Pro/TOOLKIT申请扩展器编写的,但是它们分别在Pro/E的启动和关闭期间被呼叫。user initialize ()是在Pro/E申请设定
54、并且图形窗口也创建之后才能使用的,这个动作必须包含任何Pro/TOOLKIT所需要的以及Pro/E菜单修改的设定初值,这个设定初值必须回零来指出Pro/TOOLKIT的初值设定成功。任何其他初值都会被认为是一个错误,系统就会通知Pro/E用户Pro/TOOLKIT申请失败。user CD#terminate ( )是在Pro/E关闭的时候,在用户选择证实退出对话框“Yes”之后被呼叫的,它的回行类型是空的。 2.2.2 编译和连接一个Pro/TOOLKIT申请 编译者的选择和系统图书馆需要的编译和连接的Pro/TOOLKIT申请在各自的平台上是不同的。为了保证你用来建立Pro/TOOLKI
55、T申请的文件使用正确的选择,你必须使你的建立文件基于一个Pro/TOOLKIT建立文件的下载点上,这些文件是设计用来建立各种基于包括Pro/TOOLKIT安装来源的Pro/TOOLKIT申请。 2.2.3 登记一个Pro/TOOLKIT申请 登记一个Pro/TOOLKIT申请就是提供来自Pro/TOOLKIT申请文件的信息到Pro/E上。为此,我们要先创建一个名为Pro/TOOLKIT“登记文件”的文本文件,使得Pro/E可以找到和读取。Pro/E在以下位置搜索该登记文件,并通过如下顺序: 1 在当前目录下寻找PROTK. DAT 或者 PRODEV. DAT的文件 2 在Pro/E的
56、结构文件中,一个以"PROTK.DAT " , "PRODEVDA T " , 或者 "TOOLKIT _ REGISTRY_ FILE"命名的报表文件 3 在目录< Pro/ENGINEER> /< MACHINE> /text/< LANGUAGE>下名为PROTK. DAT 或者 PRODEV. DAT的文件 4在目录< Pro/ENGINEER> /< MACHINE> /text下名为PROTK. DAT 或者 PRODEV. DAT的文件 后两者中的变量如下: < Pro/ENGINEER>是Pro/ENGINEER负荷点(而不是Pro/TOOLKIT负荷点) < MAC
57、HINE>机器制造的特性子目录(例如sgi_elf2 or i486_ nt) < LANGUAGE>Pro/TOOLKIT申请所用的Pro/E语言(比如英语、德语或者日语) 登记文件是一个简单的文本文件,每一行都由预先定义的关键词组成,然后写入变量值 名字 你的申请的名字 启动方式 DLL 管理文件 LOADDIR/$MACHINE_TYPE/obj_filename. dll 文本DIR LOADDIR 校验次数 3 回车(结束) 登记文件里的变量称述如下: 文件名——为你的Pro
58、/TOOLKIT申请分配一个单一的文件名,这是为了确定你的申请是独一无二的。 启动模式——选择Pro/ENGINEER和Pro/TOOLKIT申请信息交流的方式,本例选择DLL模式 Exec_ file(管理文件)——选择由编译和连接到Pro/TOOLKIT申请所产生的文件名,在DLL模型中是一个动态的可连接的图书馆,而在Multi程序模型中则是一个完整程序的运行器 Text_ dir——Pro/TOOLKIT申请所用的包括目录和信息文件的目录,这些文件使Multi文件支持Pro/TOOLKIT申请所用的目录和信息文件 校验次数——选择相对于你所建立的Pro/TOOLKIT申请的版本,
59、使用你当前所用的Pro/TOOLKIT申请的版本的名字(例如2001、2000i、2000) 回车(结束)——指出所用的Pro/TOOLKIT申请的结束。 2.2.4 停止并重新启动一个新的Pro/TOOLKIT申请 Pro/TOOLKIT支持在Pro/ENGINEER单一期间中停止和重新启动一个同步模型申请,在建立一个申请时,这是非常有用的,因为这让你可以不需要重新启动Pro/ENGINEER以及重新下载你的模型测试就直接改变申请源代码并进行测试,可使用非同步模型对话框来停止和重新启动申请。 为了得到这个选项,登记文件(失败文件名为PRODK.DAT)必须包含以下几条的其中一条:
60、Multi程序模式:重起spawm DLL模型:重起DLL 如果你想在Pro/ENGINEER中停止和重起你的Pro/TOOLKIT申请,你必须在你的登记文件的定义中加入以下的条件: 允许停止“TRUE” 如果你用了允许停止选项,你也可以在不启动Pro/TOOLKIT申请时启动Pro/ENGINEER直到你明确地提出了你的申请。为此,你必须把以下条件加入你的登记文件 延迟启动“TRUE” 2.2.5 开启一个Pro/TOOLKIT申请 在你分配你的申请运行器到终端用户之前,你必须启动Pro/TOOLKIT申请,这使得你的终端用户(你的顾客)在运行申请之前选择启不启动Pro/TOOLKIT。输入以下命令来启动你的申请:< Pro/ENGINEER>/ bin/protk unlock file name 3 结论 Pro/TOOLKIT扩充了3D模型和标准零件库,也增加了一些图形信息分类的功能以及产品数据管理,从而,我们可以提高Pro/ENGINEER的功能并加速CAD/CAM软件的发展。 参考文献 [1]PTC用户指导.[Z].U.S.A.2001 [2]赖超安、李震南.关于Pro/E二次开发的主要技术.[J].计算机申请.2001.9.
- 温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。