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

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

admin 楼主

2014-1-15 19:30:29

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

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

x

5 Z: n( P  U4 Y) zTeamcenter ITK二次开发源码分享: 创建一个工作流- o' A: P7 B2 \" }: I5 h
1 s. |* G* G+ H! g2 v1 X# m
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    3 X& |, _0 [! B- r- p. `
  2. #include <stdlib.h>
    1 e+ j( E( K! H  x
  3. #include <TCcore/aom.h>0 Y9 x# U4 Y( `8 F
  4. #include <tc/emh.h>; @; E; ]8 C; Z' _
  5. #include <epm/epm.h>+ m0 b; y, N/ m( l( w( u
  6. #include <tc/tc.h>
    ' Z6 W9 u, }3 K  y$ i) Y
  7. #include <sa/tcfile.h>
    7 |( f; L+ P9 H
  8. #include <itk/mem.h>9 z% _+ T8 n6 X$ z  ~& ^! m$ [+ P
  9. 0 N/ Z7 K% q/ s) q  n2 c5 h: {" f1 X
  10. #define EXIT_FAILURE 1
    $ h# |8 @# G, n6 X: a$ R, h
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    . U! W) ?- k  E" v
  12. static void report_error( char *file, int line, char *function, int return_code)
    % q: W& G+ W+ A
  13. {8 a" }1 g, p& h) M2 T% `3 J( \7 K' p: o
  14.     if (return_code != ITK_ok)
    , O, ~+ x6 U% s" o7 L8 j
  15.     {
    ( }+ S, u0 S7 W1 Q# @
  16.         char *error_message_string;
    : f5 H! V; G. Q8 y7 S1 U
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);( N8 h! H: W1 u* Z
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);7 B) H+ }/ Y8 g* K) R
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);
    : g6 U7 _% k& b' d
  20.         if(error_message_string) MEM_free(error_message_string);& b) L5 o5 p% j% T1 I: W& W
  21.         printf("\nExiting program!\n");
    / P8 z. g7 _% D' t, V6 a! `
  22.         exit (EXIT_FAILURE);   
    2 }9 d/ b; j* u
  23.     }
    # ~" f1 ^& J) N
  24. }3 X2 m4 T" Z% ?8 [- ]3 g" o9 g

  25. 3 ^8 v9 Y2 b  x* V9 |6 j
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    ; w) r4 y# q; t& F1 Q* s' R
  27. static void check_value( char *function, int value ), n; M/ P  _% h% C" L6 H1 ]
  28. {1 F9 J& Y% U1 r  f& Q) p
  29.     if (value == 0). K5 I( F5 S& ^- ]7 v
  30.     {& W* W' E( G" X# E; R
  31.         printf ("\t%s is NULL\n", function);2 n) |5 v, A3 _  J. y/ z" l
  32.         printf("\nExiting program!\n");
    - f( v) c, p' i- b- I6 ^3 X1 ^  i1 U
  33.         exit (EXIT_FAILURE);    . e( R4 k' J# |0 [9 y3 |" ]* V
  34.     }# b: Y- R' |. z; m+ t6 m9 \
  35. }9 {( ~9 g% L& Y& U0 e1 i8 F# J! O. s
  36. + u6 ?/ ~) y/ F( A4 t1 `3 [
  37. 9 L  Z5 ]1 c) v  n( s
  38. static void do_it(void)
    8 K5 g; `2 z9 m( X" l8 x
  39. {
    : U& s5 y1 V# @
  40.     int
      O" L1 L4 k# H5 _) [, A( _! _
  41.         attach_types[1] = {1};
    ; p8 H8 z2 t6 H/ G
  42.     tag_t ( k5 y! ]! Q, x6 c) m) A+ v2 z4 C+ h: }
  43.         rev = NULLTAG,
    / X2 ]' r- ~/ }
  44.         process_template = NULLTAG, & _5 s+ r: v& y  W6 G
  45.         process = NULLTAG;
    " r* N3 F7 X6 T/ V# `
  46. ( H2 R) Q5 `; x
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    ; E' [* w! e& e' Y7 a" j; P
  48.     EXIT_IF_NULL( rev );
    3 [, c9 b% h0 g4 p( e: }4 Z

  49.   r0 {$ e- D8 J' L: c. g
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    0 f) H" r4 T# y9 J: y
  51.     EXIT_IF_NULL( process_template );2 R* i+ [& k# ~: U8 P0 ]$ i" G, J# G

  52. $ z) G# m* P2 {

  53. % j9 e$ U, X1 V1 d
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    & Q/ O; _& Z  \
  55.         attach_types, &process) );3 k# P& [/ b8 R& N/ y+ y( ]

  56. ' b/ y6 s7 ]! |4 M
  57.     EXIT_IF_NULL( process );
    6 ?/ h: W* Z# r" @% j* S
  58. }: O  n$ x- {7 ?% i1 X! o; L" F
  59. 2 T- k' b' J: S" E! Y# r
  60. int ITK_user_main(int argc, char* argv[])* y& W/ o$ _5 b) t
  61. {( H; S' t& }, c# Y( f* v
  62.     int
    / T/ a  m& h: B" v
  63.         status = 0; , Q- C. ?+ w' ~5 }2 b, ?% |6 O
  64.    9 j" Y3 [4 k( f0 k
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    / A# p, q; @( h# M: n
  66.     status = ITK_auto_login();% ?1 K& \. g; S0 O0 k
  67.    " t# p" _' f/ y, H# L9 r+ p% E$ j
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");/ ^1 N% |* F3 c; x3 {
  69.     else- z/ ~1 P5 e' W3 n2 e& S( b
  70.     {0 k' S5 X; T; @* h
  71.         printf("\nLogin successful!\n\n");
    + L: p1 ?9 _0 M4 p: C/ j
  72.         ITK_set_journalling(TRUE);
    $ E# N( V5 @* \) H9 t
  73.         do_it();
    ! }  w$ \) Z3 ^, a% f
  74.     }; m$ b* a8 O) L7 l% V' r  z+ }
  75.     ITK_exit_module(TRUE);4 V) u7 j1 }! O1 S& d1 K( |9 n
  76.     return status;
    6 S+ D0 \- T! H& A6 S' W
  77. }
复制代码
5 Y7 Z8 j+ d1 w7 x; `

: h1 u. f4 t. z, l
+ W' w% B7 z, R4 q- g8 C, p
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了