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

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
/ P7 M7 d, Z, C5 u4 m# `
Teamcenter ITK二次开发源码分享: 创建一个工作流
& f- E: d' J8 c5 Q2 @! Z- M
" o6 {* E1 ?; j% q, f; w
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    & |6 f  T8 g* V- G
  2. #include <stdlib.h>
    3 y* [) @! Z/ s; V: T2 V- C& }: w5 m
  3. #include <TCcore/aom.h>$ J9 b9 H& O. g$ O, W# x8 Y3 p
  4. #include <tc/emh.h>! t/ ?; r7 P& j& r8 Q; l3 Y2 `
  5. #include <epm/epm.h>
    4 G: [) G* K- g
  6. #include <tc/tc.h>8 C5 i" u: F$ m5 k# X0 E" H
  7. #include <sa/tcfile.h>- t* {3 X3 P2 J- I0 q5 o
  8. #include <itk/mem.h>& L$ r* O% B: B! K9 ~6 f/ D2 n

  9. 2 `; I3 Q/ d3 }' e% j
  10. #define EXIT_FAILURE 1 6 q8 v" P  k8 E/ [- E9 m
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))" v8 w( }. u2 p( u5 ^
  12. static void report_error( char *file, int line, char *function, int return_code)5 L- D, D8 h, W+ k' M( y0 b5 a
  13. {8 N/ m* M& C) y1 Q* r6 W
  14.     if (return_code != ITK_ok): H8 ]8 t  g0 @# {+ B4 ~- I3 E0 e
  15.     {" R4 D* c; [& G5 f- [
  16.         char *error_message_string;
    ( ?3 q; A! E' U) F) v% u
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    & @7 R! d" w) J( ^! z% |7 [& _
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    0 n6 E8 T+ G; k4 U0 B' y7 U( P" C$ C
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    1 D3 Q7 s, t; F+ M
  20.         if(error_message_string) MEM_free(error_message_string);
    ( L7 x" B, M( Y5 B" Q& |0 _# y+ f4 A
  21.         printf("\nExiting program!\n");, j  r4 S+ b+ _  n  G8 a- O% y
  22.         exit (EXIT_FAILURE);    9 U. G7 b+ ~9 C5 x- `+ Y
  23.     }) M9 T" G3 d  G: f5 @2 M
  24. }
    % ~9 j! a* n7 {% B

  25. ( h1 g9 u# F& X5 ]! B3 z8 _
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    ) y9 y& Z8 }* g) Z0 ]9 s
  27. static void check_value( char *function, int value ). W+ L1 G7 J7 I8 X! q
  28. {% ~. Q8 j( F8 Q! B5 |
  29.     if (value == 0)7 y  F. k: ]: K0 [9 Q% F0 [
  30.     {8 F" W. A6 O  y. s' b+ Q- r; x: d6 O
  31.         printf ("\t%s is NULL\n", function);& e. O% Z% @0 S- ~, t
  32.         printf("\nExiting program!\n");) H' d' ]& k1 u$ e! w- h. g
  33.         exit (EXIT_FAILURE);   
    6 f: R4 Q% ]' a/ v# G1 Q* r) Q
  34.     }
    8 Z, |5 k, h9 ~. X+ d( z
  35. }" W: Y- l( @  T3 I

  36. $ |6 ~, n( `7 ^3 x: B* c8 Y

  37. # W0 e$ H# f7 M1 E, d3 Z3 F0 f" l
  38. static void do_it(void), v+ r/ {% A% T) g/ D
  39. {
    - @: f, v4 J8 C3 O, A2 l% [! f
  40.     int
    ! r6 `; o) T! Z& `* x2 b# ~
  41.         attach_types[1] = {1};8 h( J3 e- z+ d6 y3 |7 q
  42.     tag_t % |1 c, y# w; c/ D  s" \  c
  43.         rev = NULLTAG, 5 d& @. C' G2 {' J1 `
  44.         process_template = NULLTAG,
    / _# d) ]1 |# F; g, x; z
  45.         process = NULLTAG;% g/ I: I; {+ I% P7 Y

  46. . h+ s# [0 j4 O/ q1 m
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );$ r, x+ u6 h* T5 o
  48.     EXIT_IF_NULL( rev );+ S9 {1 W- N9 }
  49. - L" X' {; F" j; s) A7 ^; V
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    ( s, f7 z7 |2 o) d- m8 m' {
  51.     EXIT_IF_NULL( process_template );
    4 E/ `: Z9 y9 v$ Y3 b
  52. 8 |5 ?9 @, X6 J0 Z
  53. $ |5 g# m2 x: G3 a8 g! u# s6 A
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev, 5 d  q% y. y) y6 |5 o5 O; G5 _
  55.         attach_types, &process) );0 v' B3 j- Y, N
  56. 2 }* ?5 X! K  ^( q
  57.     EXIT_IF_NULL( process );
    - R4 z! u8 C* ^* e1 B
  58. }
    ; W) z9 u9 S$ i
  59. 2 r. d" d0 j4 H+ G7 K+ R& H6 Y
  60. int ITK_user_main(int argc, char* argv[]); J9 p! a  T6 Y
  61. {, r/ S& @, j0 A) q
  62.     int
    4 L6 ?1 y- O* ]4 v8 l  h; l- X3 Z
  63.         status = 0; # X, u( a6 p) t; h: E9 k+ ]
  64.    5 ]( x3 a4 [) k4 P1 h' C+ R) p
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    0 w! b$ q% x3 {. M" |
  66.     status = ITK_auto_login();) M! J  a' e8 h9 u7 E1 z4 h( X
  67.    - v+ r' U- g1 o/ p/ A
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    ( @/ v* d' S( p# D. \0 r: `# V
  69.     else
    6 f! R2 N  }$ }: O" {2 p
  70.     {7 C+ S  r$ G9 A1 f: P# ?9 Y/ l
  71.         printf("\nLogin successful!\n\n");
    1 v$ c3 G; b) v1 z
  72.         ITK_set_journalling(TRUE);
    ( p5 s2 B8 f! v+ E, _+ p0 L% D
  73.         do_it();2 E- k: h* O; ~0 S3 U2 i
  74.     }0 H1 L2 t1 o7 F2 I2 i" S: d
  75.     ITK_exit_module(TRUE);
    " \/ k8 }" m. q5 P" J
  76.     return status;+ \4 p/ ~0 X  ?+ _1 Y' T$ ]! E. i) [4 }* s
  77. }
复制代码

9 o; L0 Y! c! b# `: f
) C/ T  ?. c6 d- [1 |4 D( w; u4 P. w  \- o) [6 k- e6 n" g* e' }
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了