PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

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

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
; e6 q5 Q3 Q5 L! P3 `: }: X
Teamcenter ITK二次开发源码分享: 创建一个工作流4 U+ D2 u$ w/ A
+ V5 N& x7 w& Z5 E# N
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    , s, Q: ^! D6 k: l5 O, o* i: X! Q+ t
  2. #include <stdlib.h>! h8 Y' j# b* [: \' p- ]& L$ B
  3. #include <TCcore/aom.h>
    - v3 [( Z  Y: R$ b2 C4 |
  4. #include <tc/emh.h>
    4 c  }5 q* I" G0 m$ E% W
  5. #include <epm/epm.h>( ]' T- R7 |5 @
  6. #include <tc/tc.h>
    & t$ I& z, N, {1 z- ~+ o; k
  7. #include <sa/tcfile.h>
    9 r* [+ a$ W% ^7 u0 H, F# `' F
  8. #include <itk/mem.h>  y# s: e$ r* M$ e
  9. " [" Q/ m) a, m# T. d4 U
  10. #define EXIT_FAILURE 1
    . s' C9 z, X0 J8 \- Z( x. p* q
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    4 c3 l, p' `& H' q% B. E& E9 J
  12. static void report_error( char *file, int line, char *function, int return_code)
    4 M- y- ~- R' Z1 {+ S6 X- B
  13. {
    # ~1 r% o: C% ]2 D3 Y3 h
  14.     if (return_code != ITK_ok)
      J7 i9 H5 w9 ]* P
  15.     {' s4 N5 _% E/ t1 v$ f% j
  16.         char *error_message_string;6 _6 s' m) A4 p+ f5 y
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    " }" G2 ?6 B2 Y* D9 P9 i7 [
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);( ]9 s5 Q) G2 ?  [1 Q5 V
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    + J4 U  P4 ^5 `8 Z% C
  20.         if(error_message_string) MEM_free(error_message_string);
    9 B1 @3 L- Q5 C0 ~1 d/ O8 s! G
  21.         printf("\nExiting program!\n");  O, A; h5 q  V' [: a- {; Z
  22.         exit (EXIT_FAILURE);    6 C; }) j7 m' q1 I" v8 h! L
  23.     }
    ) J: _. D$ @5 B1 Z# k
  24. }
    . j( ?9 z: _) ?" K1 W
  25. - Y% o3 c& J. ~7 [0 z* G
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))- y# m! ^& g* R; C& k9 ]
  27. static void check_value( char *function, int value )8 a; r4 J6 c6 X7 _5 Q. C! Z* I
  28. {( H4 ^* g" A" Y% h  H( |$ Y
  29.     if (value == 0)
    - e& k6 E, d' \, e# t: K
  30.     {4 @& b7 F& f$ |  Q
  31.         printf ("\t%s is NULL\n", function);
    9 t% {& o1 p# i6 z7 s: [! w  G$ ?# U
  32.         printf("\nExiting program!\n");2 }% w" |3 n, d; e
  33.         exit (EXIT_FAILURE);   
    , l# _0 t1 S# X* \- j
  34.     }
    & i! B% T; x1 B1 J: \! l- q
  35. }$ F- p5 o; u+ L  X

  36. ( b/ P: Y5 y7 Q1 b1 [

  37. ) ~& P3 K8 d6 Y" l
  38. static void do_it(void): }  ~5 x; j* d/ @" B1 H1 ^
  39. {
    # [" S. `# T* _* K& ]% R( y
  40.     int
    % c' {" y  Q/ K: ~! v
  41.         attach_types[1] = {1};
    8 F% m+ l- P$ z5 `1 T' b( r, m
  42.     tag_t
    ; \$ Z: Q6 H* e' E1 A
  43.         rev = NULLTAG,
    5 S7 }/ J$ ?2 h2 H6 q3 X, ]( |
  44.         process_template = NULLTAG,
    $ i, ~4 B( X+ ^/ N
  45.         process = NULLTAG;, g3 W0 f, S2 ?; m3 Z& D
  46. 8 b2 r, Q% ?; `  T$ r* |2 }4 b, `
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    . d/ Y8 F9 W3 w/ Q( R* q3 E& g# b
  48.     EXIT_IF_NULL( rev );1 U, l! s* W) o: c& u

  49.   H5 b& R& y2 x/ _$ w% n* q/ ^1 |
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) ); + L: ^' a5 _/ ~
  51.     EXIT_IF_NULL( process_template );! ~% f) F/ e& d' \( H- l" ~2 ^7 ?
  52. ! Z8 ~+ |/ m4 s3 T( j# y
  53. 4 X' n7 A) g5 r
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    " ]( ]0 n; J; h1 ?5 e# x
  55.         attach_types, &process) );9 k+ v2 c$ V) b% E0 }: n7 G

  56. + |6 T- l1 G0 \2 O& u
  57.     EXIT_IF_NULL( process );
    4 m9 t/ m; m2 z1 l
  58. }
    / _/ e4 s! h& P5 k% ?
  59. " a3 y. m2 h& v9 T) a9 Y: n
  60. int ITK_user_main(int argc, char* argv[])
    * j" p+ \' y9 T, v
  61. {
    : Y7 u: J3 z7 q+ D9 t2 w
  62.     int
    " Q2 v" C  S4 n0 }! ~- [  e7 a
  63.         status = 0;
    + _; O7 x/ N* K. f
  64.    
    4 j; T3 F! |! k! T4 M9 E7 h
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    + M' o( y- C% W* j
  66.     status = ITK_auto_login();: i) k$ b( S% p$ d
  67.    
    3 w4 j9 A8 @& K5 J' A* P# W
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    ( R+ p  e# f2 F
  69.     else
    - x) I! R; y* C) ^' [# e) `
  70.     {5 C* i8 v& Y. v+ d' W
  71.         printf("\nLogin successful!\n\n");
    + J) V& f5 D( C1 v+ ~
  72.         ITK_set_journalling(TRUE);4 j8 P/ |# Y/ a4 ?. B8 ?+ j& }
  73.         do_it();( T/ A* h* O6 `* u4 [' n
  74.     }% [. K. U* o( O$ x7 M
  75.     ITK_exit_module(TRUE);
    5 _9 c+ Z9 i, z2 ]7 D
  76.     return status;" `2 |6 t" d1 Z! [4 O
  77. }
复制代码

! w4 X, y% N' c8 H: @8 F1 X8 M% ?, m  R; B( U* C# P' a

$ }) S0 ^+ |1 ~0 f8 {6 W
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了