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 4621 0

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

admin 楼主

2014-1-15 19:30:29

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

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

x

% g+ U  M9 G# z, N! TTeamcenter ITK二次开发源码分享: 创建一个工作流, `/ u4 [9 E" ]

- X4 W/ s/ z/ G! f
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    8 O) D% q* f7 L/ w$ T
  2. #include <stdlib.h>
    ; x) ]% e% f/ X" Y9 a) r. z/ Z
  3. #include <TCcore/aom.h>' _+ s, ?8 d* }. I4 [
  4. #include <tc/emh.h>9 [4 a2 Z( t# j% d8 K) k- \
  5. #include <epm/epm.h>
    + W0 P& K; z5 v; t: z
  6. #include <tc/tc.h>( K+ n# r4 N, t7 z
  7. #include <sa/tcfile.h>1 O& A" L- R- w
  8. #include <itk/mem.h>. ]7 }7 c4 w% D. p

  9. ) O4 N6 J' `8 e( ^
  10. #define EXIT_FAILURE 1
      b( _$ y9 G% Y+ P" B. @* Y
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))" E1 j4 E7 k& H2 ?
  12. static void report_error( char *file, int line, char *function, int return_code)
    3 ]1 d* F2 C- U
  13. {
    # Q( y+ Q3 n- U8 D9 @
  14.     if (return_code != ITK_ok)
    . R+ c" l  W% F! t! N0 P! y% K5 f
  15.     {
    / Y: ~8 ?1 E& S, h' c
  16.         char *error_message_string;
    9 M+ _5 A9 n9 p( t9 Z, h
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);" W- i/ t$ J5 r2 s- k( H& M; n2 X
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    + n. J( T, ?+ U
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);$ r% E8 e; I. U2 G1 ^5 G
  20.         if(error_message_string) MEM_free(error_message_string);  d" ^% R7 r% t% a
  21.         printf("\nExiting program!\n");5 q( c# U' @  V/ w- y# O$ A
  22.         exit (EXIT_FAILURE);   
    6 ^. h  B6 x1 @8 j+ x$ Y7 H
  23.     }
    7 \$ W5 O/ d+ y
  24. }
    # l& Y! |2 |; H1 C# ^% `- k# s2 q7 Q, C

  25. ; J2 k* K0 f1 Q& B8 ?( S7 E
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    & `# y0 K. B0 N% `! a5 D
  27. static void check_value( char *function, int value )
    + W! p9 R) m7 c( k- ]& T. S0 F
  28. {6 R1 e0 F, ^0 o: x9 I/ {9 v+ a. ?3 C
  29.     if (value == 0)' c" c, _5 C( i, d$ L! x4 A
  30.     {
    ; O/ f# o1 \1 o5 ]; m
  31.         printf ("\t%s is NULL\n", function);' y0 x& i: c( L" X0 S' \
  32.         printf("\nExiting program!\n");
    & h  X! a) Z' q2 L) T& n/ v
  33.         exit (EXIT_FAILURE);   
    5 U* [. f+ i6 U
  34.     }
    % r, t4 m) t8 s* C) m* C+ e
  35. }
    # U1 \( q0 ^! L" @2 V# F  X

  36. ! {* X* t$ C) p! F

  37. ; [# `# g# K0 K; U) ^. E" m
  38. static void do_it(void)
    ! l% n3 O  i* {
  39. {
    8 A1 l( P! t8 ]# x" w" k( z/ L  T
  40.     int
    ( D( m) ?2 \( Q0 @# }, \
  41.         attach_types[1] = {1};
    ( V/ d- Q& R* W$ G; H
  42.     tag_t
    2 B5 I' J" {# a1 Y+ @6 N$ \
  43.         rev = NULLTAG,
    ! U& h+ x% L* T' A
  44.         process_template = NULLTAG, / x/ b, M3 Z2 d; r
  45.         process = NULLTAG;
    " h9 w* ]/ I& b9 S( K
  46. 7 {) U) r5 T0 ?/ D' k6 W
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    % ]# {& s4 l4 V7 p, c+ [7 e& n
  48.     EXIT_IF_NULL( rev );% O' K9 D2 s3 ?" z% s, R) O  {
  49. " g- L  y( e+ }+ }$ M7 y7 z
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) ); 0 R! _+ e, Z9 _( v- E0 ]
  51.     EXIT_IF_NULL( process_template );/ i8 G! H$ J- J% L) l7 A

  52. # t  [1 [) N0 ?0 P5 U

  53. . W  P" L8 _. ^- p6 z
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    ! F) Y$ R1 U" t1 p# t! @+ A
  55.         attach_types, &process) );
    9 q# j: J" D: e( B7 F
  56. / X& q1 e+ y* S4 }* _
  57.     EXIT_IF_NULL( process );
    3 j1 V/ R6 ^$ P7 w$ K4 w7 H: b
  58. }
    , M3 k1 B2 X7 I

  59.   y% S! I/ Y8 b, V3 D% }
  60. int ITK_user_main(int argc, char* argv[])9 u! @* A2 w5 m8 C6 Q* K- j0 F. q0 |
  61. {# t# T' J! v# g, t0 d7 f
  62.     int
    + B+ J3 E- y' p+ n/ c
  63.         status = 0; 2 ]! I) P* M6 M# S1 f
  64.    / z7 {  R5 B1 N# x" d6 N$ X
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    % M  p5 H, i2 t
  66.     status = ITK_auto_login();/ e8 {3 b/ l; \8 K
  67.    ! L; f3 c, @. y  ?( S+ K! h
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    $ E9 @; u+ y5 a
  69.     else
    $ G) x( }5 {1 e2 b$ [! T8 d
  70.     {0 F0 L' x  Q8 n9 W! x& E! j) w6 E
  71.         printf("\nLogin successful!\n\n");
    / x5 m0 ~1 L  e+ i: R) K, ~; R% z4 c
  72.         ITK_set_journalling(TRUE);, q. r) d/ s7 l: ?' X: ]8 N; v
  73.         do_it();
    1 A1 t; h% k/ c) s% F1 d
  74.     }5 h. M$ H: {+ w  M& M, Q
  75.     ITK_exit_module(TRUE);0 J3 d3 G3 r& G' L" G) v, G" a+ o
  76.     return status;$ D4 `, |* }* r3 S4 ~
  77. }
复制代码
# f7 x; M, ~: ?+ s, X
! r( o. `& t5 m
, L  u# j/ ]! c3 X
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了