本段解说怎样去使用 C# 去包装到Pro/ENGINEER的连接。
一个简单异步模式程序不实现Pro/ENGINEER来的要求句柄的途径。因此,C#不能安插当在Pro/ENGINEER里发生事件而被通知的侦听。相应的,Pro/ENGINEER不能调用当你增加时必须提供的方法,例如,Pro/ENGINEER的菜单按钮。
由于这个限制,一个简单异步模式程序可以用来自动化Pro/ENGINEER里的进程。程序可能既启动或连接到一个存在的Pro/ENGINEER会话,也可能在交互或无图形,无交互模式访问Pro/ENGINEER。
当Pro/ENGINEER运行在图形情况下,它仍然有隔交互进程对用户可用。当你设计个简单异步模式下的C#程序,头脑中有下列观念:
当使用C#程序,下列方法用来启动和停止Pro/ENGINEER。
一个C#程序可以通过CcpfcAsyncConnection.Start()方法去产生并连接到一个Pro/ENGINEER进程。一旦方法返回异步连接对象,C#程序可以使用相应的API去调用Pro/ENGINEER进程。在交互模式,当它运行时,你还可以在你的计算机上访问Pro/ENGINEER会话。
当Pro/ENGINEER终止时,这个程序不会终止。当程序只是临时需要进行Pro/ENGINEER操作的时候很有用,因此在会话中,必须启动和停止Pro/ENGINEER一次以上。
在任何时候,只有一个Pro/ENGINEER会话可以被启动或连接。如果C#程序产生出第二个会话,对第一个会话的连接将丢失。
为终止任何程序连接的Pro/ENGINEER进程,调用IpfcAsyncConnection.End()方法。
你可以产生个既无交互又无图形的Pro/ENGINEER会话。在异步模式,在调用CcpfcAsyncConnection.Start()的Pro/ENGINEER启动/连接字符串中包含下列字符串:
CcpfcAsyncConnection ccAC = new CcpfcAsyncConnection();
aC = ccAC.Start("<pro> -g:no_graphics -i:rpc_input",<text_dir>);
这里 <pro> 是启动 Pro/ENGINEER的命令,<text_dir>是工作目录。
这个例子演示C#。方法异步启动Pro/ENGINEER,然后加载一个会话并在Pro/ENGINEER里打开一个模型。
public class pfcAsynchronousModeExamples
public void runProE(string exePath, string workDir)
行选项:-i 和 -g 标识使 Pro/ENGINEER 运行在无图形,无交互模式
IpfcAsyncConnection asyncConnection = null;
CCpfcAsyncConnection cAC = null;
cAC = new CCpfcAsyncConnection();
asyncConnection = cAC.Start(exePath + " -g:no_graphics -i:rpc_input", ".");
session = asyncConnection.Session as IpfcBaseSession;
session.ChangeDirectory(workDir);
IpfcModelDescriptor descModel ;
model = session.RetrieveModel(descModel);
MessageBox.Show(ex.Message.ToString());
if (asyncConnection.IsRunning())
- CcpfcAsyncConnection.Connect()
- CcpfcAsyncConnection.ConnectWS()
- CcpfcAsyncConnection.GetActiveConnection()
- IpfcAsyncConnection.Disconnect()
一个简单异步模式程序也可以连接到本地机器上已经运行的Pro/ENGINEER进程。CcpfcAsyncConnection.Connect()方法执行这个连接。如果多个Pro/ENGINEER会话运行,CcpfcAsyncConnection.Connect()失败。
如果几个版本Pro/ENGINEER在相同机器运行,试着通过指定用户和显示参数连接。然而,如果几个版本Pro/ENGINEER运行在相同用户和显示参数,可能不能连接。
CcpfcAsyncConnection.connectWS()把Pro/ENGINEER同Pro/INTRALINK3.x 连接起来。
CCpfcAsyncConnection.GetActiveConnection返回当前到Pro/ENGINEER会话的连接。
为了从Pro/ENGINEER进程解除连接,调用IpfcAsyncConnection.Disconnect()方法。
- IpfcAsyncConnection.GetConnectionId()
- IpfcConnectionId.ExternalRep
- CCpfcConnectionId.Create()
- CCpfcAsyncConnection.ConnectById()
每个Pro/ENGINEER进程管理一个通讯目的的唯一标识。 这个Id可以用来重新连接到个Pro/ENGINEER进程。
IpfcAsyncConnection.GetConnectionId()方法返回一个包含连接Id的数据结构。
如果连接Id必须传递给其它程序,IpfcConnectionId.ExternalRep提供了连接Id的字符串外部表示。
CCpfcConnectionId.Create()方法输入一个字符串表示后创建一个ConnectionId 数据对象。CCpfcAsyncConnection.ConnectById()方法通过指定连接Id连接到Pro/ENGINEER。
每个Pro/ENGINEER进程的连接Id是唯一,一旦Pro/ENGINEER退出就不维护了。
为发现一个Pro/ENGINEER进程是否运行,使用方法pfcAsyncConnectionAsyncConnection.IsRunning。
IpfcAsyncConnection.Session方法返回表示Pro/ENGINEER会话的会话对象。使用这个对象去访问Pro/ENGINEER会话的内容。更多信息见〈会话对象〉段。