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

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x

+ R; }3 `7 J5 H3 dTeamcenter ITK二次开发源码分享: 创建一个工作流
  C3 w' _, R4 P$ ~" q7 H# g
- _  x8 ]3 O6 p# b5 C4 [
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    3 Q! f" Y" g% W5 P
  2. #include <stdlib.h>
    ( h5 u0 e3 w* O  ^9 z/ }
  3. #include <TCcore/aom.h>+ o6 y( z7 Y% d5 W2 \! W) f
  4. #include <tc/emh.h>6 V. u' r5 O5 y0 P9 \) k# K0 q
  5. #include <epm/epm.h>
    - F2 M3 F! A6 p5 e
  6. #include <tc/tc.h>
    8 T  M2 U8 Q/ m6 ~# F& F
  7. #include <sa/tcfile.h>& F! Y3 @( }" a6 n8 y
  8. #include <itk/mem.h>
    , a% A0 m( Z7 r+ L3 o* T" L( D

  9. - a( }  ^" x% M$ V' e7 L
  10. #define EXIT_FAILURE 1
    2 M1 `' F* {) \
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))% c$ E# ^0 ]2 i
  12. static void report_error( char *file, int line, char *function, int return_code)
    + j' \  O9 c0 @7 l1 e0 D+ e! N/ b
  13. {
    # z( p  |1 P6 N* @3 n4 ]% ^
  14.     if (return_code != ITK_ok)
    ! ^7 ?5 X" [7 d6 E: N, @4 r* L
  15.     {
    * ]  T8 e. d, m8 d0 _' R
  16.         char *error_message_string;
    7 g8 L0 y# h' `" ^0 y; v
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);* j3 |8 p5 @7 E& ]4 s2 t
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);6 N2 `, a; e- l2 T, x! \
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    0 H* D! K; g4 f4 M/ R
  20.         if(error_message_string) MEM_free(error_message_string);8 V0 u' l1 z9 D4 U+ x0 [
  21.         printf("\nExiting program!\n");
    / Z# {* _. i9 ?9 n8 A: v7 m2 _
  22.         exit (EXIT_FAILURE);    & e) k0 P7 _& G
  23.     }
    + K' k! N. U5 U# \1 j
  24. }8 T' R. r0 i# Q5 y1 C; I& {  E

  25. ; r" B9 n# Q  |
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
      D# x: o8 S1 R+ D  p
  27. static void check_value( char *function, int value )
    4 c- U6 n- ~, Y$ E1 z
  28. {3 h& u' x& v/ [% P
  29.     if (value == 0)
    1 {. N4 P# V) _, |- W8 O/ F
  30.     {
    ' X0 M: E4 b" h' C: H" o. Q
  31.         printf ("\t%s is NULL\n", function);. V0 W+ B# G' F4 Q
  32.         printf("\nExiting program!\n");
    ( e. \) f% b  R, s0 \
  33.         exit (EXIT_FAILURE);    ) b! K6 X$ s9 U' g
  34.     }3 r0 d7 F: h; A
  35. }$ i5 o& |7 r, ]" _. X! X

  36. 5 q7 X8 b' u5 i* l

  37. 4 ^7 m6 j0 L. S; |+ d& W6 A
  38. static void do_it(void)
    1 j* A# @4 ?# [
  39. {# F8 ^0 f0 x: p6 h
  40.     int " u) t. m0 c* N3 @. {
  41.         attach_types[1] = {1};
    ! @' n& g) z9 o( O% P' h) }+ y- J
  42.     tag_t
    - i; a. o$ Q; R
  43.         rev = NULLTAG,
    , T$ r& r" @4 z, W
  44.         process_template = NULLTAG, " F8 z- ?; p3 C/ ^, d% `: a# Z- |; q
  45.         process = NULLTAG;
    4 S' S6 @4 r/ J( h$ z

  46. ) S4 N4 y& @5 w2 I
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    * r8 @- y0 n! b3 E+ {) g: R
  48.     EXIT_IF_NULL( rev );; @+ h, T5 b& {! U! k* K& Q
  49. & D6 P- |# }& \2 A! D$ U, Z
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    6 f4 K2 P4 X8 ]. F4 ^& Y7 a
  51.     EXIT_IF_NULL( process_template );' R  \; G' R, D

  52. 5 f5 S5 O+ `9 S8 n

  53. 3 n4 j0 U: \& i, q! L
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    3 t/ H, J8 h0 A4 \& s
  55.         attach_types, &process) );& F0 d" n4 ]  M3 o# j8 _, r

  56.   {7 F6 P" s$ r
  57.     EXIT_IF_NULL( process );
    " h5 E) s7 v$ o0 y; z
  58. }. F- ], {, g3 A, Y
  59. - x$ }9 v; ~* _9 R6 ]& J
  60. int ITK_user_main(int argc, char* argv[])
    8 M, [5 l, w* G# f/ k  y6 U
  61. {
    ; F9 E7 Q0 j+ m5 P
  62.     int9 o* h! k" A; {4 z
  63.         status = 0; ( Q6 m! S. [  _, M, u7 G* U
  64.    
    # t7 `. k5 N3 ^' L2 R
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );2 x: K2 o; m4 E, k
  66.     status = ITK_auto_login();
    4 L2 F% i' q! c- p& R8 D% ]1 ^
  67.    3 J( V6 s- J) n2 r2 c" C" r+ k& p
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");1 S) ?) g" c5 Y' D' U
  69.     else/ s( I+ Z: J  U
  70.     {
    2 H. U$ F3 b! [! x3 Q( \1 M
  71.         printf("\nLogin successful!\n\n");
    9 D$ S) L$ t+ [% O
  72.         ITK_set_journalling(TRUE);
    ' H$ J$ T, }; I6 ~; r8 Z
  73.         do_it();" l  o' v* [) t. p
  74.     }( h2 F" J* {$ w5 U
  75.     ITK_exit_module(TRUE);2 D* Q  I2 q; v8 k8 q  B
  76.     return status;7 S. ^' S0 }/ Y1 h$ Q9 Z3 m8 v' v
  77. }
复制代码

! H- D- v6 ^( }
# k- f# b6 Q3 u: Y1 ~, P' f/ h! {' M% ]  z' P
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了