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

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

admin 楼主

2014-1-15 19:30:29

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

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

x

5 [( ~1 t% U* R3 L" O2 X" K3 D, zTeamcenter ITK二次开发源码分享: 创建一个工作流0 \+ v$ [4 W% ]5 W
/ ~* E6 M6 K4 f
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    ! c* e9 E! O7 S3 r% V9 r7 N
  2. #include <stdlib.h>
    8 K' i& _0 y- n
  3. #include <TCcore/aom.h>- O0 |- g+ x9 _- c
  4. #include <tc/emh.h>
    % J8 [; l6 s1 s0 y
  5. #include <epm/epm.h>! J6 X8 O8 x; T( V( I  n* V
  6. #include <tc/tc.h>: u  y# D: d+ Y/ B. o& V
  7. #include <sa/tcfile.h>
    % b6 W3 {* p1 `" A7 O1 b
  8. #include <itk/mem.h>* b5 Q& _9 n" E6 D' K1 ~8 _
  9. ! w: e7 D% t) d5 {" w& w4 `
  10. #define EXIT_FAILURE 1
    . J9 O8 A$ F$ z" |, D( f
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))3 ^5 q7 z& q, P; t2 Y
  12. static void report_error( char *file, int line, char *function, int return_code)
    4 L2 }% c3 w: P7 I& [2 i- l* Q
  13. {
    4 m1 b8 ?, [& j/ P$ L) ?  l+ k4 \
  14.     if (return_code != ITK_ok)
    3 O, I9 a( ^; j/ n+ q' a2 f
  15.     {
    : r& E' O+ ]" R7 w
  16.         char *error_message_string;; g! i- z3 X  I; _2 `( e; f/ w
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    $ b! D: D* i% \
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    . t1 _6 {# k! @( l0 H7 g+ v
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);: l" ~& a3 c; L+ i- \+ B: f
  20.         if(error_message_string) MEM_free(error_message_string);
    3 q" V! }5 V0 ?  Q2 d
  21.         printf("\nExiting program!\n");
    5 ]& m; Q% ]! U1 q: x4 ~6 q, s. v3 A4 ^  w
  22.         exit (EXIT_FAILURE);   
    , Q6 Y8 B* V$ ]2 b, s! |
  23.     }
    . q# L3 _4 z7 _) |
  24. }
    ) C8 S% b/ I. I& u4 z; l
  25. : g" o0 Y! G: j& F7 [3 Z
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))" u# k. N9 ~7 s) Y; ~4 t# L
  27. static void check_value( char *function, int value )
    3 |# b' [  U+ ?; ]1 O& r0 I8 {
  28. {- R; ~  @0 [! o+ L& e0 z) e
  29.     if (value == 0)
    ' F7 U2 p9 V/ K2 [: I
  30.     {
    . p* i% m1 e0 \& Z5 K' P, v2 C
  31.         printf ("\t%s is NULL\n", function);: U5 u% @! m+ ]4 g
  32.         printf("\nExiting program!\n");
    % Y  H# a' M; u# `+ F) d7 V( E
  33.         exit (EXIT_FAILURE);   
    0 y  j" ?& B" S& _
  34.     }' S0 h; b$ u- \$ o, i
  35. }# y) h6 b: y* v0 y' j5 A  v

  36. $ O  u7 N& K. L- h% W7 b

  37. # @& V* E, E, l9 T* |3 B+ k) y$ V) E
  38. static void do_it(void)' z, O  S( F+ c9 G; c
  39. {) B# I4 W: n, |
  40.     int
    0 X" U& \+ y: f, u" Y1 \# K
  41.         attach_types[1] = {1};
    2 l. X+ C% ~# `  v% `
  42.     tag_t / L* G: h  J0 D
  43.         rev = NULLTAG,
    / N, t) V9 J, L2 }* t
  44.         process_template = NULLTAG,
    0 m& O# v. g' D' O
  45.         process = NULLTAG;
    6 K3 R4 m# C5 U5 a! f; k

  46. ( J6 i0 Q# y8 _1 C- O8 A2 n1 h
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );
    ) }" T5 s- ]" R+ f. V- n; m0 c: B
  48.     EXIT_IF_NULL( rev );
    ' y& y8 f: j7 y$ ^/ l2 Q7 F
  49. ' u. H2 \; N- n' q
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    $ u0 N! J8 r3 V: K0 x
  51.     EXIT_IF_NULL( process_template );
    1 _- K" u& Q& {& I3 h  J. y% _
  52. * C7 {/ _. r% e5 f: e6 L8 R% D
  53. 8 h- W3 G% O1 W9 M% p! J
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    - \5 _5 F" g9 O, }* o0 W
  55.         attach_types, &process) );9 A- @3 ?+ p, p2 b

  56. 4 t1 u% v3 {8 v' p0 A: n
  57.     EXIT_IF_NULL( process );
    : |5 c6 T- F8 q  z/ Z8 r
  58. }( x) C( \) K5 {3 w* G

  59. 6 P. I6 T$ d7 L6 O
  60. int ITK_user_main(int argc, char* argv[])/ R0 _- j: f- r# V% v$ L, K! l" W
  61. {
    ! ]) m" h6 x! t% I* {( o# d( U
  62.     int
    $ ?& v5 v4 V4 R  v  U9 o; e
  63.         status = 0;
    6 T+ N+ p9 ^- a0 q
  64.    
    : {0 ~5 I5 z: u* D
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    : W, I7 f. S# |2 Q
  66.     status = ITK_auto_login();
    ! v7 ]7 t: S/ R9 t
  67.    : e, M% n6 H3 X+ r
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    ; L) f& y+ o) P: h8 w- F* D
  69.     else5 W0 J( n* U% P
  70.     {# q( D/ W' B& l: t
  71.         printf("\nLogin successful!\n\n");
    ! G8 x) o3 H! ~/ r% N
  72.         ITK_set_journalling(TRUE);) w+ U. h& f0 h% D( p: I0 d) n
  73.         do_it();& t: y4 G7 ^; c! G
  74.     }
    & l# J0 ^8 r- s! u
  75.     ITK_exit_module(TRUE);
    ' N. T: n& u6 n! A% u
  76.     return status;
    : J1 L6 S8 F6 Q6 T
  77. }
复制代码

! D5 z1 _8 `  H7 H# ~5 Z2 ^& R, B/ c# l% d# R

9 z, v0 S( }1 t6 D
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了