本段解说怎样去使用 C# 去包装到Pro/ENGINEER的连接。
启动和停止Pro/ENGINEER
连接到一个Pro/ENGINEER的进程
完整异步模式
C# 程序疑难解答
当Pro/ENGINEER运行在图形情况下,它仍然有隔交互进程对用户可用。当你设计个简单异步模式下的C#程序,头脑中有下列观念:
- Pro/ENGINEER进程和程序同时执行操作。
- 没有一个程序的侦听方法可以被Pro/ENGINEER调用。
当使用C#程序,下列方法用来启动和停止Pro/ENGINEER。
- CcpfcAsyncConnection.Start()
- IpfcAsyncConnection.End()
当Pro/ENGINEER终止时,这个程序不会终止。当程序只是临时需要进行Pro/ENGINEER操作的时候很有用,因此在会话中,必须启动和停止Pro/ENGINEER一次以上。
在任何时候,只有一个Pro/ENGINEER会话可以被启动或连接。如果C#程序产生出第二个会话,对第一个会话的连接将丢失。
为终止任何程序连接的Pro/ENGINEER进程,调用IpfcAsyncConnection.End()方法。
你可以产生个既无交互又无图形的Pro/ENGINEER会话。在异步模式,在调用CcpfcAsyncConnection.Start()的Pro/ENGINEER启动/连接字符串中包含下列字符串:
- -g:no_graphics —— 关闭图形显示;
-
这些参数都需要,但是顺序不重要
IpfcAsyncConnection aC;
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里打开一个模型。
using pfcls;
public class pfcAsynchronousModeExamples
{
public void runProE(string exePath, string workDir)
/*
第一个参数 : Pro/ENGINEER 执行命令的路径
行选项:-i 和 -g 标识使 Pro/ENGINEER 运行在无图形,无交互模式
第二个参数:菜单和消息文件的字符串路径
*/
{
IpfcAsyncConnection asyncConnection = null;
CCpfcAsyncConnection cAC = null;
IpfcBaseSession session;
try
{
cAC = new CCpfcAsyncConnection();
asyncConnection = cAC.Start(exePath + " -g:no_graphics -i:rpc_input", ".");
session = asyncConnection.Session as IpfcBaseSession;
// 设置工作目录
session.ChangeDirectory(workDir);
// C#进程调用和其它将进行的其它进程
IpfcModelDescriptor descModel ;
IpfcModel model;
// 载入工作目录下的 "prt0001.prt" 文件
descModel = (new CCpfcModelDescriptor()).Create((int)EpfcModelType.EpfcMDL_PART, "prt0001.prt", null);
model = session.RetrieveModel(descModel);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message.ToString());
}
// 当完成,结束 Pro/ENGINEER 会话
finally
{
if (asyncConnection != null)
if (asyncConnection.IsRunning())
asyncConnection.End();
}
}
}
方法介绍:
- CcpfcAsyncConnection.Connect()
- CcpfcAsyncConnection.ConnectWS()
- CcpfcAsyncConnection.GetActiveConnection()
- IpfcAsyncConnection.Disconnect()
如果几个版本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会话的内容。更多信息见〈会话对象〉段。