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

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

admin 楼主

2014-1-15 19:30:29

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

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

x

* u2 N; r' e5 |; V/ K4 hTeamcenter ITK二次开发源码分享: 创建一个工作流
+ x. b7 f7 o5 t: A. C9 }$ J; o5 [& N
  1. /*HEAD CREATE_A_PROCESS CCC ITK */1 d  i+ h1 d9 j9 K
  2. #include <stdlib.h>
    3 C2 z8 A2 I  K' r" {
  3. #include <TCcore/aom.h>
    * u( b# D9 ]$ V
  4. #include <tc/emh.h>
    0 z" l# F' C0 v7 h$ U
  5. #include <epm/epm.h>
    $ C& R' K* ~5 V  B9 h+ c) H
  6. #include <tc/tc.h>
    4 T% J* N" E. I
  7. #include <sa/tcfile.h>& g, C: ]' ?" ~6 M0 s; P
  8. #include <itk/mem.h>& L6 Y1 C& G3 I* q  i) V

  9. - A; c, a2 s. h  S
  10. #define EXIT_FAILURE 1
    + ^7 p1 A* B# X0 ^$ P9 V5 v
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    % V1 T. E4 Z2 C( W
  12. static void report_error( char *file, int line, char *function, int return_code)
    / u' ~+ d* ]8 P
  13. {
    3 L; }7 ]9 V) h
  14.     if (return_code != ITK_ok)
    2 C6 B: K0 ^3 R: ~- U$ Y" t& L
  15.     {
    7 M7 g! w% F& t& g& m9 j
  16.         char *error_message_string;# v3 c1 r: z0 `; P) N
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    7 T5 z- Q( W; `/ w" g! y
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);& E" s. [5 c* R/ z0 j2 M: t7 k: W" O
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);) a  |- g( x8 r1 A1 g+ Y
  20.         if(error_message_string) MEM_free(error_message_string);
    * Q% T6 X7 v0 W: V0 K* k7 [! ]# m! X
  21.         printf("\nExiting program!\n");
    ) z1 b& Q0 S9 |: [- q# M
  22.         exit (EXIT_FAILURE);    5 X7 r& E' Z* }
  23.     }
    8 ~6 y. E7 w6 R7 C" [/ {
  24. }, _" m2 @4 Q9 y, D' h! J
  25. $ o( b* P2 @/ L4 ?5 q
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))3 w( W4 n. q: \, V9 X) K  X
  27. static void check_value( char *function, int value )
    : o/ @9 Q: X1 n, b
  28. {% S+ q& ~9 R; C( k. Y3 ~+ f
  29.     if (value == 0): f/ Y* y1 j7 P. I
  30.     {
    . c* W7 P& B2 H8 \
  31.         printf ("\t%s is NULL\n", function);
    ) C- |! u9 K2 ^6 D, I" L  T
  32.         printf("\nExiting program!\n");* Z" S$ h8 f* W: @) B8 g* r
  33.         exit (EXIT_FAILURE);   
    # D2 N, G, i  |) H  e( p6 ^1 x
  34.     }
    ' i; z0 R1 l$ ^7 k; G( b
  35. }7 @" o; y) q8 L

  36. 0 O- E* a: X( z4 h" H
  37. 6 P' M( `2 p# b) z9 I1 ^; [
  38. static void do_it(void)& P: H  f" v' y* |, W. m
  39. {6 ~  n# o0 W9 S2 y  t/ t( `' X
  40.     int
    2 `7 K" n" Y+ \3 }( P  I( T
  41.         attach_types[1] = {1};
    , _3 @0 n* J% l; H3 a
  42.     tag_t
      _7 a! W. D0 C" n' M0 U
  43.         rev = NULLTAG, " i2 T& U( J, [& s' ]. [( O4 X
  44.         process_template = NULLTAG, " z+ A2 k  H9 m, P% ~) Z
  45.         process = NULLTAG;
    & a7 M+ u4 A% b0 _- ~& w

  46. " u3 q8 c( ?( |' Z5 F
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );% Q) h2 s2 B1 X7 [/ ?
  48.     EXIT_IF_NULL( rev );
    6 o' m  t! F9 k

  49. 3 j" I7 k; L' w* x/ b
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) );
    9 @  ~( p+ ?( [$ a
  51.     EXIT_IF_NULL( process_template );
    * y1 J+ N6 [2 a) X% d1 C$ y

  52. : s$ G9 Y  p; Y" Q

  53. ' W4 t  I! C8 q
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev, ( F5 O) \5 v  h% P& X
  55.         attach_types, &process) );% D1 ^& {! e! R6 d6 L- m9 B1 o* Y
  56. 5 _. ~5 M" }5 ^2 N' G4 K( S. p
  57.     EXIT_IF_NULL( process );, Z6 b( t4 b+ p8 B
  58. }9 t7 R1 F6 f; q
  59. 1 Q2 X" Z4 i( ]1 f5 i0 [* G
  60. int ITK_user_main(int argc, char* argv[])
    % A) V- w0 D, K' }6 O0 N
  61. {
    . D  j# \4 o" S5 U% y
  62.     int
    ' g! z. Q# ?5 [0 q4 R. I' ]
  63.         status = 0;
    + \$ M& C) Q3 J9 q2 J
  64.    * c& n9 t' R; V; Q. `: a
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );6 Y) J5 S- Z  N5 D' g- y& c
  66.     status = ITK_auto_login();$ M& O7 E! \6 I7 K: O+ G( ~, U
  67.    
    ( G( i7 F: x* d1 j/ B
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");& H4 m. U" `# F+ j/ {' t' c5 M
  69.     else8 S8 v) L# B+ D% v
  70.     {
    ( y6 T! n# b. w
  71.         printf("\nLogin successful!\n\n");
    ' P4 T6 E; E$ V0 f7 q
  72.         ITK_set_journalling(TRUE);
    # ~( f& g7 u8 ]
  73.         do_it();  f# R2 d0 q5 ^6 A( |5 F7 U( |
  74.     }
    & [  }. G) D1 `' N+ J) i
  75.     ITK_exit_module(TRUE);' e9 A& ?& f  D( c2 v9 E
  76.     return status;# |" _! l9 }9 Y% E5 ?
  77. }
复制代码

2 c) j7 ~/ q0 ]6 Z& k
) S, w2 ]# J! i5 A9 @8 M' n, S: j, \" I% _$ y8 m1 P0 l; J
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了