PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

PLM之家PLMHome-国产软件践行者

teamcenter ITK二次开发源码分享: 创建一个工作流

[复制链接]

2014-1-15 19:30:29 4806 0

admin 发表于 2014-1-15 19:30:29 |阅读模式

admin 楼主

2014-1-15 19:30:29

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x

  [% H  {& |# L% E6 MTeamcenter ITK二次开发源码分享: 创建一个工作流  a9 R8 d$ C" |  F' J3 I! j
8 q- Y. \, t/ q4 e2 p
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    9 E  I( B* @/ N; W
  2. #include <stdlib.h>
    8 `, Q# S$ h4 m% q6 `% x
  3. #include <TCcore/aom.h>
    . ^: {1 Q: D' U5 M2 D; d
  4. #include <tc/emh.h>
    1 i2 z$ p( Y1 q3 h' }- k9 V
  5. #include <epm/epm.h>
    # V; e1 c" m7 p( B
  6. #include <tc/tc.h>
    % g) k5 O# E& F5 e1 X* Z  |
  7. #include <sa/tcfile.h>
    2 W5 H  D/ ?6 a6 S
  8. #include <itk/mem.h>
    . u. _; Y! x0 A
  9. & Y4 \- ]* d+ @& s
  10. #define EXIT_FAILURE 1
    - X1 d; p7 O4 V5 N% R+ p
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))" b  B6 w9 Y1 N+ C3 j
  12. static void report_error( char *file, int line, char *function, int return_code)) k) x- i* H# {, `; N: K* t0 H* B
  13. {
    7 A0 }% y$ c" N' G, \
  14.     if (return_code != ITK_ok)% L0 `5 E' H, R: R
  15.     {
    ' }1 t  u% e  Q# }, R
  16.         char *error_message_string;8 e9 ]/ r# }  E' k. F% v+ m% ~5 m
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    , H% V# |) S. F" B
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    8 R3 V- m: ]! t
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);0 l- E: H4 y6 k4 O+ D/ m% c
  20.         if(error_message_string) MEM_free(error_message_string);0 p/ u0 W" q& ^) i* |$ C; F9 F3 o
  21.         printf("\nExiting program!\n");# c0 J$ R1 M0 A. m) v
  22.         exit (EXIT_FAILURE);    4 u( k" _1 [. ?9 Q3 c' N
  23.     }( ~) H1 V6 n8 o# {2 q: V5 r
  24. }
    & b9 b5 S9 ]* f; o

  25. 4 i/ e2 _7 c( R; N
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))2 f! e' Y, C3 c3 y, o# M
  27. static void check_value( char *function, int value )) g# O- p- ^" ]9 {2 p
  28. {! [  R, e" `, ]8 w$ {% D" k
  29.     if (value == 0)
    8 p3 q% D2 s/ f. u
  30.     {
    + B: M) X& s4 A& ]( X! |
  31.         printf ("\t%s is NULL\n", function);
    : _, @- t& W8 x$ n7 h
  32.         printf("\nExiting program!\n");/ U7 D! M# K( m1 O# [' I: J( P
  33.         exit (EXIT_FAILURE);   
    $ W; ]' T* d) V; q+ Q, @# q. R
  34.     }
    * Y5 w) I; n* a3 b2 I* K
  35. }- e. i* C/ u# t  n9 g  |2 v
  36. ; ^; e0 r- k6 D; ?) e& R
  37. 3 g" d5 U2 n) D
  38. static void do_it(void)
    4 L1 I, u. a# q8 u& x0 M
  39. {
    8 E: ]5 @2 D9 e! F8 ?
  40.     int
    2 E  k8 G1 b7 M2 A" b9 s; r( v+ m
  41.         attach_types[1] = {1};
    8 `! ^) r5 I. k0 Z0 K1 F- }$ p
  42.     tag_t
    4 z: D: I4 u+ {0 L
  43.         rev = NULLTAG, % B! N* ]% @1 r  G- e: p9 p
  44.         process_template = NULLTAG,
    5 m5 `9 S- h, a% m# F! S
  45.         process = NULLTAG;3 k' f' Z+ ~, N& J) `
  46. ( h! t' k3 |; v9 r, v" w
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    : ~9 k1 A# U. s4 L6 P- o
  48.     EXIT_IF_NULL( rev );
    6 Q4 b; x  Q6 _2 R* Z) ]3 j: d" B
  49. : _! E' |- U6 z7 e
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    . C: v5 B5 ~% O% H( ?* S
  51.     EXIT_IF_NULL( process_template );
    , j3 q. H- r# f6 h, p1 L5 `4 x& G) P

  52. ) m5 O( n+ K, P( x! x/ T

  53. 7 `4 B, _  T, E+ o8 E
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    & U/ C- K1 Y3 j: F, Z5 C
  55.         attach_types, &process) );0 z1 j- s, @# W; k
  56. 5 g4 Z* u- z3 J, }- h- R
  57.     EXIT_IF_NULL( process );7 }# H5 C' D9 T' W6 l
  58. }
    5 m- m( P' I2 g

  59. : C! y' W/ f% _3 j$ {. A. G
  60. int ITK_user_main(int argc, char* argv[])6 m) n3 t6 N/ W5 c. |3 A' y% l
  61. {) K- v6 G9 Y& h4 ^1 ~) L# v
  62.     int1 J: H; s* I6 I( Y9 A
  63.         status = 0;
    % |7 r  K# x1 R6 |8 D3 J
  64.    
      Q4 W1 u5 N4 L: h
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );8 T: ?7 u& \/ t0 Z# S' J7 x
  66.     status = ITK_auto_login();: g5 L, f' ^7 S# `
  67.    
    2 B4 e# }4 n3 P% K; D
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");: {2 V1 k! M  g. i2 r  J
  69.     else2 u/ ~4 k/ r& j; t, m4 D; m
  70.     {1 q. v" a1 ~4 v! e1 }
  71.         printf("\nLogin successful!\n\n");
    / Q2 f2 a# u. l4 Z) Z
  72.         ITK_set_journalling(TRUE);
    8 L6 c( Z% ?" |# g: n$ F
  73.         do_it();1 I. U% H9 E. _6 P
  74.     }
    # ^% b) G1 x$ O) q7 O' f5 l
  75.     ITK_exit_module(TRUE);. O# d' F( U$ Q% m
  76.     return status;
    % K% I; F& v% V* {5 M2 p
  77. }
复制代码

( n6 b6 L0 p# g$ c( K
' ]6 k' ?0 Q( N4 ^1 l" ^/ _9 [; F0 S
7 Q, q) i3 N  l! R4 o
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了