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二次开发源码分享:创建测量单位unit of measures

[复制链接]

2014-1-15 19:39:16 5334 0

admin 发表于 2014-1-15 19:39:16 |阅读模式

admin 楼主

2014-1-15 19:39:16

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

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

x

  Q5 W2 e8 W6 Q+ a8 `: M$ H9 T- \Teamcenter ITK二次开发源码分享:创建测量单位unit of measures, F( }0 U1 ^" T* l# x

' x' Z) H$ V2 ~* k8 g! @' w7 Q
  1. #include <stdlib.h>! r: E* a& S: h2 i8 v, ?7 |
  2. #include <TC/tc.h>* d( b9 E% W& L& Q
  3. #include <sa/tcfile.h>
    3 k! l. b2 h) R
  4. #include <tccore/workspaceobject.h>
    % W% J4 l+ a- t# B1 B; d; g
  5. #include <ae/ae.h>- a- f  A1 @& T3 p
  6. #include <tccore/item.h>
    . }2 X% O, y4 F! M! ?" Q

  7. 0 Z8 k* v* g- j+ X1 v$ Z
  8. #define ITK_CALL(x) {           \. c+ n1 S) _9 z# x1 [& v0 z
  9.     int stat;                     \
    4 F# l1 @: Y4 `2 t( c# n
  10.     char *err_string;             \2 s# B) N$ M& U% M. I
  11.     if( (stat = (x)) != ITK_ok)   \; x; X- B  `# J+ H+ Y  _) V
  12.     {                             \
    + c6 [" O3 r9 @- C
  13.     EMH_get_error_string (NULLTAG, stat, &err_string);                 \
      P3 R6 y8 T; B( L) T% e
  14.     printf ("ERROR: %d ERROR MSG: %s.\n", stat, err_string);           \  c! f* j0 S  i. x% f. B
  15.     printf ("FUNCTION: %s\nFILE: %s LINE: %d\n",#x, __FILE__, __LINE__); \
    : P# |) l, T5 ~% c/ l, K, P2 n
  16.     if(err_string) MEM_free(err_string);                                \
    4 u( ~' x3 r" J$ c/ ~* o/ Y
  17.     exit (EXIT_FAILURE);                                                   \3 J5 _9 L( ~) T
  18.     }                                                                    \
    2 b8 `: C6 m! }* Q/ ?! N1 m3 X8 u
  19. }6 P; ]+ |6 J3 W: q, d; [5 v
  20. #define EXIT_FAILURE 1 5 [6 Z1 f, s7 N' ?$ Z& U
  21.         
    : [, @: y) o2 v  g! e5 Z( J! B
  22. static void do_it(void)8 a) w0 y8 E. A
  23. {
    9 x$ i  I/ Q- ^& }& ?2 f7 c
  24.     int
      z, ?4 e; I6 I' i/ o- y
  25.         n_uom,
    ; T/ x* p  H& C, R
  26.         ii;# P8 b! A( V- ?
  27.     char: k2 x  p. q6 |3 i
  28.         *name;
    5 J4 r( |+ A7 `" [
  29.     tag_t8 V- k; T! P* h/ O5 L
  30.         *uoms,
    - j0 l  A. Z8 m( N3 J
  31.         new_uom;
    8 F9 h- r1 u: I& o$ U3 x" O# i  y
  32.     0 }$ L( t0 R/ O
  33.     printf("Before UOM was created...\n");   
    % F6 ^/ u! Q$ A2 U- H4 q6 x9 _' K
  34.     ITK_CALL(UOM_extent(&n_uom, &uoms));
    1 x& X) \7 h* {! t2 U
  35.     for (ii = 0; ii < n_uom; ii++)
    ! c$ O( T# \7 w# X; t
  36.     {
    1 O6 T$ D" X3 P4 v/ P3 g1 @7 a, R( @
  37.         ITK_CALL(AOM_ask_name(uoms[ii], &name));
    ( Y& ^2 i  Q$ p
  38.         printf("\t%s\n", name);0 C, O1 b' i: w! u8 T/ K( y, ^
  39.         if (name) MEM_free(name);
    0 Q) K/ o# I+ I$ B  U7 J+ k! v
  40.     }7 Z! o4 s0 k4 t: x( m& t+ L
  41.     if (uoms) MEM_free(uoms);
    : \( Y4 ^  A! k
  42.    
    * I5 ]/ B9 y3 \- ~! n* y# r
  43.     ITK_CALL(UOM_create("inches", "in", &new_uom));2 v, B. D) ^2 c. z
  44.     ITK_CALL(AOM_save(new_uom));+ ], {$ Z6 }& |' Y: n/ h) w' N
  45.     , ]5 X! j# A- w8 F! {0 ]* s, S' r
  46.     printf("\nAfter UOM was created...\n");   . |( ~% j$ {9 W$ X4 d- W8 \
  47.     ITK_CALL(UOM_extent(&n_uom, &uoms));
    0 u2 K# @; ~/ k; f4 U: H, V' Z
  48.     for (ii = 0; ii < n_uom; ii++)
    : Y: ]& ?5 [: ?) B$ G8 M9 h* V. r
  49.     {
    # g3 ]7 o1 ~; H5 g7 ^
  50.         ITK_CALL(AOM_ask_name(uoms[ii], &name)), R- }8 [3 u5 K" ^
  51.         printf("\t%s\n", name);( s; c. y7 j4 k+ y" M9 T
  52.         if (name) MEM_free(name);' e( p# _2 ^- A' m
  53.     }% W) x% i* x0 s  L5 F. L9 J
  54.     if (uoms) MEM_free(uoms);6 [1 D; a8 P( c3 o' R0 \
  55. }1 ^2 X. N4 S+ u" h
  56. ! d4 s* H  R' _2 n. s
  57. int ITK_user_main(int argc, char* argv[])
    3 R* {. P: ?, g
  58. {2 R& O& F0 o0 E
  59.     int
    3 m& T- I  d6 Z. Y: H
  60.         status = 0; 6 n; c9 H5 T2 \1 U) o- V1 x
  61.     char& K, H) \5 H! `1 t
  62.         *message;7 Y7 X: C7 N" p2 t
  63.     & B" ^% u/ R  r: }6 O3 w
  64.     ITK_initialize_text_services( 0 );
    % r6 X* D5 A% x7 n6 e! \0 ^+ B
  65.     status = ITK_auto_login();' u3 I6 s' v7 w7 ^
  66.    0 V/ c# }+ Y+ {/ l0 s& }+ W8 i2 M" N
  67.     if (  (status != ITK_ok)) printf("iMAN login NOT successful.\n");
    3 A1 j& A  [( v; w( g. A
  68.     else
    . Q2 k2 x9 ^! @" C: H; `
  69.     {
    4 n- f1 Q( x, z; \& D7 N" \
  70.         printf("iMAN login successful.\n");
    % H: }( G9 w9 o4 o4 Z
  71.         ITK_set_journalling(TRUE);$ C6 ~2 [( g  a' V( b. s4 B
  72.         do_it();( t. e/ D4 K3 I$ ?5 _# W+ P; B
  73.     }
    " |0 v- l* [9 \. _; y
  74.     ITK_exit_module(TRUE);
    ' A9 h/ T3 @- _, N4 p2 r
  75.     return status;
    7 @( ?% F# a, W8 I: w7 \
  76. }
复制代码
' F1 P/ E9 I! s9 K+ g: D

. D4 X% |. {) C: J, h: J0 W+ B* 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二次开发专题模块培训报名开始啦

    我知道了