请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
9 N3 B( v7 a" P# ?# y* f6 u8 l
NX二次开发中涉及到文件的时候,我们需要区分单机版本NX环境和集成版本NX Manager环境,分别要对文件进行处理。基于windows本地文件路径(此处讨论未涉及到Linux系统路径,如果需要这方面也可以在 PLM之家上面发帖咨询)和 Teamcenter数据库存储文件名称的不同,我们需要单独进行处理。此处提供些许常见方法,希望起到抛砖引玉。
4 D8 o0 D1 i: l% x1 ]1 NX单机版本二次开发文件处理方法 NX单机版本二次开发通过获取当前文件名通常是当前文件本地的存储路径包含.prt后缀的路径名,对于整个路径的字符串处理,可以用字符串快速进行获取想要的文件名,文件路径等。 NX的ufun函数 uf_cfi函数库也提供了相关的ufun函数,可以使用常见的方法uc4575(),uc4576(),uc4578(),可以快速通过当前的partname得到路径,得到文件名,合并和处理相关路径。 使用获取的路径C:\temp\plmhome.prt 举例说明:
' {1 H7 K" Y* q; I! h uc4576主要功能将当前的文件名进行拆解,生成dspec: C:\temp\ 和 fname: plmhome.prt (注意这里有后缀.prt),可以通过 9 ~: g' c/ U2 E9 `: J5 |9 ]
if (strrchr(temp_name, '.')) strcpy(strrchr(temp_name, '.'), ""); 快速进行去除.prt 后缀,这样就可以获取到plmhome整个文件名了。 (也可以配合uc4578()去除后缀的方法);使用uc4575()属于路径合并功能和uc4576()正好相反。 int uc4576(const char * fspec,int ftype,char dspec [ MAX_FSPEC_BUFSIZE ] ,char fname [ UF_CFI_MAX_FILE_NAME_BUFSIZE ]) int uc4578(const char * fspec,int ftype,char dspec [ MAX_FSPEC_BUFSIZE ]) int uc4575(const char * dspec,int ftype,const char * fname,char fspec [ MAX_FSPEC_BUFSIZE ]) 这里面NX提供了filetype的参数,基本上常见的类型都可以通过filetype自动生成相关的后缀或者通过filetype移除后缀名。 譬如,.prt的filetype的值是2,bat的filetype类型是243等。这里面比较有趣的是文件夹类型,也作为filetype进行处理定义,值为100,这样的话我们其实不需要区分文件,文件夹都可以使用这些方法进行处理,确实很好用。 当然如果使用NX Open C++的相关方法的话,也可以很快获取到全路径通过 FullPath()可以获取整个全路径,通过leaf()可以直接获取带后缀的文件名。通常情况我们可能需要通过同名的文件名去创建同名的log文件,因此比较常用这些分解和合并的方法。
% j3 Y4 _0 f4 I3 Q# E& _* N
/ T$ \: g' C+ [1 c( W: m9 x& C2 关于和Teamcenter集成NX Manager文件的处理方法' N, {) N! n7 m2 j) R9 J
NX集成环境下,数据全部存储在 TC数据库中的,内部数据库的方法可以使用 UF_PART_ask_part_name()方法获取文件名,但是此时的文件名是数据库内部的文件名长成这个样子: "% UGMGR=V3.2 PH=itemUid PRH= itemRevUid PN= item_id PRN=item_revision_id AN="dataset name" RT="relation type" AT="Dataset type" AUID=appuid" 如何得到我们想要的文件名呢,这里针对常见我们需要用到的情况来处理下。1 ^) P( \8 W8 ~& s. [8 n
(1)只是想获取文件编码,文件描述,文件版本等信息,通过! V1 c+ z1 V$ _, J
UF_UGMGR_decode_part_filename()就可以完成对这个字符串的分解 int UF_UGMGR_decode_part_file_name
! V: k: B/ \8 Z: W& A3 }- R1 s# P(* }9 Q- z* a' A1 S6 Q0 ~
const char * encoded_name,& _) O4 n2 l i# K
char part_number [ UF_UGMGR_PARTNO_BUFSIZE ] ,* e* \/ n: ^2 ~/ I3 ^6 t
char part_revision [ UF_UGMGR_PARTREV_BUFSIZE ] ,3 V" p4 A3 i4 X1 s
char part_file_type [ UF_UGMGR_FTYPE_BUFSIZE ] ,# p+ {- U% U7 A
char part_file_name [ UF_UGMGR_FNAME_BUFSIZE ]
4 a; A7 Q7 i9 m: f0 Z8 T% N ) (2)我们需要处理外部程序,输入@DB/PartName/Rev这种格式,完成相关外部命令的输入参数处理,这个时候我们可以使用UF_UGMGR_convert_file_name_to_cli()将上面的一串内部命令字符串转换成外部参数模式 int UF_UGMGR_convert_file_name_to_cli1 R" S+ Y$ {0 m* J. x- O3 a
(
: G# K" n9 A2 T9 E6 P, g8 t- w const char * internal_name,( d; t5 P3 O% v+ M
char * * cli_name
3 H* Z4 q1 u3 X, @ ) 简单的实现例子如下: 代码部分: 3 关于NX集成环境的判断
- d$ }8 V6 e. ^* P5 w" Y
这地方比较简单了,通过UF_is_ugmanager_active()就可以进行环境的判断。 logical is_ugmgr; UF_CALL(UF_is_ugmanager_active(&is_ugmgr)); if (!is_ugmgr) { //本地版本NX1 N- K4 G G- I b" J5 `
} _1 G* q1 v( {2 Y4 ~5 [
else { //集成环境 }
7 W% C9 D% u' S0 F; l1 M2 ?8 C 3 N8 y( d. R$ t& [% D. ^
d/ u. Y% k+ ?' ]2 \
7 T# M% u6 B( K+ f p$ b5 B1 q5 EEND PLM之家plmhome 4 f$ ~- p: n% m& k; U5 _2 ?
▲长按二维码“识别”关注
7 O1 ] I6 `0 a% m5 m4 u) V! `4 L0 x W5 v% |! m
* K) s6 n+ l/ m# C4 M6 b |