PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

PLM之家PLMHome-国产软件践行者

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

[复制链接]

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

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

admin 楼主

2014-1-15 19:30:29

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

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

x
8 l1 @2 B  x+ E& m4 N+ H* V% b
Teamcenter ITK二次开发源码分享: 创建一个工作流
$ i+ R2 S% a: j
. z/ ~4 _$ n& P" S
  1. /*HEAD CREATE_A_PROCESS CCC ITK */
    2 K6 E: H6 J8 l5 o
  2. #include <stdlib.h>8 l; S, I7 F2 k: e1 q
  3. #include <TCcore/aom.h>
    8 a* b3 P6 A/ {7 r
  4. #include <tc/emh.h>9 c( U; d# `9 U2 S. \1 t; {" Z' B+ B
  5. #include <epm/epm.h>
    ! z' O/ }7 p) P; [6 o
  6. #include <tc/tc.h>4 W5 l" ^2 R( x; M9 ^
  7. #include <sa/tcfile.h>
    % _: D% W' V' H; \; i1 O, Y
  8. #include <itk/mem.h>. u3 L( n6 E3 b2 w. u0 y2 R

  9. ; _9 V  I! ^" ?$ ~
  10. #define EXIT_FAILURE 1 " G# C" i+ ^% d% ?
  11. #define ERROR_CHECK(X) (report_error( __FILE__, __LINE__, #X, (X)))
    8 ]4 S- ]. ?$ c; j) n& @
  12. static void report_error( char *file, int line, char *function, int return_code): x2 }/ h# p! t
  13. {
      V7 f/ l* n5 p" F! _" N# T' U
  14.     if (return_code != ITK_ok)2 r6 O) n) V5 E, N2 `
  15.     {
    ) Y- P& K- s1 s1 U! v5 T1 ]! f1 d6 L
  16.         char *error_message_string;
    7 n! j: f0 V; d5 f8 z
  17.         EMH_get_error_string (NULLTAG, return_code, &error_message_string);
    ' q5 f5 ^* r: u, ~' T! d
  18.         printf ("ERROR: %d ERROR MSG: %s.\n", return_code, error_message_string);
    - l2 Z! A) J9 ]/ W+ r
  19.         printf ("FUNCTION: %s\nFILE: %s LINE: %d\n", function, file, line);8 H( J4 m' @) `+ {
  20.         if(error_message_string) MEM_free(error_message_string);3 s; O& d# g* C; H) ]' r6 a" _: Y
  21.         printf("\nExiting program!\n");$ E$ c) Q( ^% C/ ^
  22.         exit (EXIT_FAILURE);   
    " K9 p/ p1 E& d+ q$ v5 W
  23.     }( J: ]8 Y, f3 ^7 t
  24. }+ B( Y% Z/ R& F1 t4 F1 J1 y  E2 i

  25. 6 ?- T+ F9 C' b. r# E9 U! P
  26. #define EXIT_IF_NULL(X) (check_value(#X, (X)))
    & U% y; b2 c! F/ t
  27. static void check_value( char *function, int value )0 Y- [, f" f5 m7 Y
  28. {
    , I  Q3 z, E/ D
  29.     if (value == 0)- u3 J) K1 H* ?+ ]
  30.     {
    ; n1 k- ]2 f1 `5 d) V1 }* Z
  31.         printf ("\t%s is NULL\n", function);  A2 E5 E8 S7 _1 R
  32.         printf("\nExiting program!\n");3 \5 N- D5 h- p% T: j! H& R  l
  33.         exit (EXIT_FAILURE);   
      b# K- o8 T. R# q. `3 ~+ ]
  34.     }' z4 V4 `% p& y( j
  35. }
    : N0 b3 }1 `: q5 Q5 E
  36. & u, W$ a6 K& N4 j0 H  i% r

  37. 2 {( ~9 }! b! _) j
  38. static void do_it(void)
    # e& w0 y# ?3 |0 {. B' H3 }; X' `* @
  39. {: |- Y0 |' M* R( u4 |
  40.     int
    3 w5 L% N, B3 h' X) g7 L8 @
  41.         attach_types[1] = {1};
    % h( u/ a! E0 E5 }1 j2 n+ [
  42.     tag_t
    5 V! e( O# ~6 z' [
  43.         rev = NULLTAG, 0 }  @, ]+ o) s  r9 x
  44.         process_template = NULLTAG, # e0 N6 i" K9 h4 A3 A
  45.         process = NULLTAG;2 r/ n0 K* Y9 }$ y3 ]5 |! C1 ?
  46. 8 v7 s1 E9 V5 R
  47.     ERROR_CHECK( ITEM_find_rev("000206", "A", &rev) );( @9 d# [' m: n  Y3 ]2 h6 V
  48.     EXIT_IF_NULL( rev );0 D6 W, |5 ]* a$ w) ], ]9 a

  49. 8 n- R1 M: ^9 _* Y3 |
  50.     ERROR_CHECK( EPM_find_process_template("oneStepWithStatus", &process_template) ); : R# }8 s$ I; v! W1 j
  51.     EXIT_IF_NULL( process_template );
    : J( B1 p9 m  ^8 ~* e

  52. " ?- m" I) }; C: a
  53. / E$ y4 ~+ E( G" e/ O
  54.     ERROR_CHECK( EPM_create_process("5421377", "desc", process_template, 1, &rev,
    9 Z) W7 W# U3 t) f. |. s+ _
  55.         attach_types, &process) );
    ( w6 D' M, X- m& y

  56. 5 W' y* O. k. [5 K" A0 r1 h8 H* K
  57.     EXIT_IF_NULL( process );
    7 W# O; g0 G/ B( j( [1 y
  58. }7 I8 `* V) G; \; N8 u/ a

  59.   ?0 F0 ?9 a' p- V" |. a! X5 X$ a
  60. int ITK_user_main(int argc, char* argv[])% d) P' y& T" G- @5 d9 M
  61. {6 x; }8 J2 J5 }" {( N
  62.     int
    2 j! K* l* I9 R7 f
  63.         status = 0;
    . p$ Q/ E& n1 a4 {+ J7 T! P5 f
  64.    
    + m3 `+ Y- A- s7 D4 j. _2 k+ o# \1 z
  65.     ITK_initialize_text_services( ITK_BATCH_TEXT_MODE );
    " h, E& x/ E) K* M4 y
  66.     status = ITK_auto_login();
    3 R/ f0 ]+ u7 s
  67.    
    5 |7 W  S( M' P! I0 c
  68.     if (  (status != ITK_ok)) printf("\nLogin Failed!\n\n");
    ( T3 O$ D4 N- F/ T1 L
  69.     else2 t' _* r3 }0 D3 m8 P( f
  70.     {( t! M; {/ P/ s* z. |7 \4 A5 ]
  71.         printf("\nLogin successful!\n\n");
    , O* M% ~! _0 b$ \
  72.         ITK_set_journalling(TRUE);
    % u& ~3 ^5 K% z7 I* H& L
  73.         do_it();
    1 g9 I7 O2 _! l+ [% u
  74.     }
    " L9 u1 U( C* g- n/ K" Y1 @
  75.     ITK_exit_module(TRUE);
    " k$ ?: F9 I3 a! Z. l2 C* e
  76.     return status;" w' D5 r* g, }( ^
  77. }
复制代码
5 S/ }5 g2 C9 f( b$ J
  n8 U- U" A# f" k# Z

/ i2 F) X4 E: ~" E- V  W* C, @
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了