PLM之家PLMHome-工业软件与AI结合践行者

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
( \7 H1 y: M9 S( @: h4 b
Teamcenter ITK二次开发源码分享: 创建一个工作流$ z, \1 N6 X% c- E5 Q! o
' f- U& g; X! q0 i" L6 v6 H: B9 ]
  1. /*HEAD CREATE_A_PROCESS CCC ITK */. z( V# o& w6 Y* ]0 S; Z, K* b
  2. #include <stdlib.h>
    2 k5 b) J' A4 r* E$ w
  3. #include <TCcore/aom.h>: n. Z6 c3 |8 n3 z& O
  4. #include <tc/emh.h>  y7 d& b- M' v' S7 F5 G# b9 J0 f
  5. #include <epm/epm.h>
    ; Q+ J5 X, x  H; B1 Q1 q" e
  6. #include <tc/tc.h>) l7 G) C5 L: N0 {2 a' a; ~. e0 [
  7. #include <sa/tcfile.h>/ ?4 x$ \0 e$ C1 Q9 J) g, f" a
  8. #include <itk/mem.h>
    1 `$ K2 G$ ~/ m4 P) S0 w! ]

  9. 5 n+ |4 f2 u4 ]" U4 k' ]
  10. #define EXIT_FAILURE 1 5 L; K( S( m. g
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))! y. g/ c. c' Q9 y7 M$ W
  12. static void report_error( char *file, int line, char *function, int return_code)
    ) [$ U% e& |4 q5 c& X
  13. {' D9 x6 Z" U9 n0 V) a
  14.     if (return_code != ITK_ok)9 E! Y1 m5 b" |# X5 H3 B/ e
  15.     {
    8 m. \9 ?9 q( _0 {; g
  16.         char *error_message_string;
    + w3 d  U* a; w" k9 j+ d
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    ) R  b9 [2 W9 t, x: Y6 m# P0 @
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    8 a1 |) b/ ^# L/ D. ]
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    ' P6 B" s( ^9 Y& Y
  20.         if(error_message_string) MEM_free(error_message_string);+ r( I0 \0 a: N% k, f
  21.         printf("\nExiting program!\n");+ R, @- N' u( }) Q& U1 {
  22.         exit (EXIT_FAILURE);    3 x8 z. T: l' A' i( [2 M
  23.     }
    ) r) }" y' Z/ f6 h! `4 ?
  24. }4 a' u! z5 g6 C: B& W" Z9 |! H

  25. + {# G$ G/ u4 A! o+ S( W
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))* x: P1 W0 F* Q% ~: c" u! e  X
  27. static void check_value( char *function, int value )
    3 S. |- Q5 h- O1 F" O1 X( ?$ h0 y8 g
  28. {$ m/ f& \( P1 m
  29.     if (value == 0)
    " y& z4 {. X0 ^; t. I
  30.     {! h; T; u0 B5 ~  g8 a
  31.         printf ("\t%s is NULL\n", function);, l; H6 y- |" E! W2 M/ R/ J
  32.         printf("\nExiting program!\n");- N0 d* D9 Y' S4 R/ a* }) z
  33.         exit (EXIT_FAILURE);   
    ; ~6 b. T, Q! ?2 D
  34.     }
    * t% s2 a1 D8 {. E
  35. }
    : u( w  K7 M3 Q& O; o
  36. : [; z* l' t+ ~, n7 Y: E, a
  37. 0 d7 u, G/ L$ ?
  38. static void do_it(void)
    ; [8 H" o- e4 I+ G
  39. {6 }0 C7 p5 B, m; t8 s
  40.     int 7 h% ]7 {# Q; f3 v4 a) }% {
  41.         attach_types[1] = {1};; G( P5 a) E# y/ i4 [
  42.     tag_t - X+ ^0 w! o" \4 i9 ^9 O3 j
  43.         rev = NULLTAG,
    4 }  t  K! P: R; a6 G4 [' m6 A. M' L
  44.         process_template = NULLTAG,   a  f3 Y1 x& N+ ^' S- p
  45.         process = NULLTAG;4 o3 ?; ^; x2 H5 O
  46. ! _4 q7 V* ?. r$ I4 h( ~3 X( F1 }
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );# h: M. }$ w& U: Y; l! ?
  48.     EXIT_IF_NULL( rev );
    9 T, i& C0 S4 i3 }2 `4 t

  49. ( l: Q) N4 N* O- L0 t. @* s
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    7 M  Q, h/ E0 A* t+ L: V
  51.     EXIT_IF_NULL( process_template );) ?& l  v6 j8 R8 T- b- z" j2 P- m; p

  52. ; V% I, I; r& z4 d: @; D

  53. ! H  ~" K7 C1 H4 T& h
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    9 y5 a7 C0 i& u4 q; ?
  55.         attach_types, &process) );
    ! q$ R1 ], X1 K4 P6 }1 G
  56. 9 B9 _4 b" T; z, g6 ?
  57.     EXIT_IF_NULL( process );3 N3 N5 X5 u' C2 y7 W! W) @! t
  58. }
    ) J* \9 l/ g7 U0 a

  59. - X2 q  E# m- [! i8 b* L% j
  60. int ITK_user_main(int argc, char* argv[])1 t, h5 A7 x' g2 s9 L  |
  61. {
    2 B3 |7 V! ~: O( c" ^) Z7 q
  62.     int
    1 r8 E3 ]; p6 _. C
  63.         status = 0;
    6 b8 G* x9 Y; p" o' H
  64.    ' Y6 [9 U- e2 ]% x1 [+ o( s# D
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    3 j1 ~. \) m- ]9 K' \0 y. x. m
  66.     status = ITK_auto_login();* P( z+ X, Y* O% o' G3 G
  67.    9 h5 W- }6 \5 c2 ^5 h% |
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");2 |* R) [7 I' b3 b+ x. d4 C
  69.     else' n; G. P8 t1 n. _, \/ J
  70.     {  _3 S( c# e5 v" f8 s, l+ M9 ~/ t
  71.         printf("\nLogin successful!\n\n");
    9 _4 o4 l! n. z! T; a
  72.         ITK_set_journalling(TRUE);/ Z( T& I2 F* N* C( h7 ^
  73.         do_it();5 k$ _  ^: q' @- T# L0 K/ z
  74.     }
    ! M7 P6 a% i; L7 B- G
  75.     ITK_exit_module(TRUE);% j% s( j, _" a  c( ~( x
  76.     return status;. `' h# V# o7 Z# S  O  b6 p
  77. }
复制代码
7 O# v+ b5 j. X( m- x+ e& L
4 z7 c* S/ A0 M6 v; g' N8 [
; c; G9 u& m( m% |! T1 k
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了