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

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

admin 楼主

2014-1-15 19:39:16

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

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

x
8 Y3 h5 E. N: ?4 ]2 A
Teamcenter ITK二次开发源码分享:创建测量单位unit of measures9 i6 h/ P9 B9 o! R

* c1 U2 I; n! r' Q! w
  1. #include <stdlib.h>
    $ |4 `2 o5 t/ }/ x" P
  2. #include <TC/tc.h>
    " C9 y7 x/ ^/ H1 N" o1 q) R
  3. #include <sa/tcfile.h>
    5 r' I! q% A5 e/ \
  4. #include <tccore/workspaceobject.h>
    6 T) B& H: G4 P& R$ i
  5. #include <ae/ae.h>
      H5 V8 Z$ x+ e: ~/ m6 x
  6. #include <tccore/item.h>
    6 b7 {% n$ f* m2 h: L, x
  7. ' B4 {: }8 J4 a: j3 u5 z
  8. #define ITK_CALL(x) {           \/ K0 r2 ^; V$ m; |! t% b  }
  9.     int stat;                     \
    + m% ?4 H& n  v9 K7 t0 W$ A( ?( j
  10.     char *err_string;             \
    5 D: J6 M) _3 [; g! ?' e( |+ E+ }
  11.     if( (stat = (x)) != ITK_ok)   \
    , c* T* c8 z+ Q4 v) h! q
  12.     {                             \
      A9 c, o4 \3 m6 i9 Z4 C- b: t
  13.     EMH_get_error_string (NULLTAG, stat, &err_string);                 \
    5 @, X6 Q$ D+ k, j% b
  14.     printf ("ERROR: %d ERROR MSG: %s.\n", stat, err_string);           \# T6 }+ w( F- s+ U, @7 d
  15.     printf ("FUNCTION: %s\nFILE: %s LINE: %d\n",#x, __FILE__, __LINE__); \
    % f) J. `+ y2 q8 b/ @$ Q
  16.     if(err_string) MEM_free(err_string);                                \
    3 R" g# j8 m2 ]: `% m
  17.     exit (EXIT_FAILURE);                                                   \4 d& H' q5 g" F2 {9 }/ O0 D
  18.     }                                                                    \. F0 C4 Z2 Q/ @; k" o1 g' c6 _+ g
  19. }! G& B2 S4 |/ @/ D
  20. #define EXIT_FAILURE 1
    : d) m4 F, [5 L
  21.         
    & c0 N2 y' G/ V) n0 j
  22. static void do_it(void)9 ?8 c& P1 ~6 s3 n6 ^
  23. {
    - |$ ~. C$ Q: W7 P' P( A6 U
  24.     int
    : z+ e' I1 E  k3 m, x0 f
  25.         n_uom,
    4 T  o1 m1 u  l+ [9 ]& Q
  26.         ii;  J$ F0 M& R' i  Y+ A; N* h% f
  27.     char" O8 H/ \( D% N# M6 ^
  28.         *name;6 b1 J: t! R' J! _* {- S/ L
  29.     tag_t
    1 ?* q. k1 M0 Z3 o. T$ ?0 ]' y
  30.         *uoms,/ E4 }2 k" ^8 ^& a/ p: X& w
  31.         new_uom;2 ]5 a2 d- ?: p& K" Y3 _" z
  32.    
    , }# P& P3 u. ~" N
  33.     printf("Before UOM was created...\n");    1 E/ c  d8 D; _1 m0 I
  34.     ITK_CALL(UOM_extent(&n_uom, &uoms));- L/ Q- d& ]. i. X- |% e- y3 s! B
  35.     for (ii = 0; ii < n_uom; ii++)
    : D1 R) H' _0 m
  36.     {
    ( j- s( B# I3 {! x7 k: f
  37.         ITK_CALL(AOM_ask_name(uoms[ii], &name));6 i& ?- A2 w# w' ~: o
  38.         printf("\t%s\n", name);7 E5 Q6 v% ^* m. n- I4 k$ }5 M
  39.         if (name) MEM_free(name);& Y0 H  l( }1 h0 a0 O- c# Z
  40.     }
    / p" i4 X. j* N! @5 x
  41.     if (uoms) MEM_free(uoms);
    . J; e' {; q, f& g
  42.     ; p4 w6 q' \, O1 B# [) s% ?9 ~
  43.     ITK_CALL(UOM_create("inches", "in", &new_uom));( {& f( W6 _( v+ c# {+ a
  44.     ITK_CALL(AOM_save(new_uom));
    . l# R3 i1 ^. X+ X% f
  45.     & c7 X6 H8 j; A/ D7 A' y
  46.     printf("\nAfter UOM was created...\n");   
      w) G. D  h* I  q$ @  {
  47.     ITK_CALL(UOM_extent(&n_uom, &uoms));4 z$ ^; v. x' t  a: S4 C& X0 ]
  48.     for (ii = 0; ii < n_uom; ii++)3 `& H0 @1 _* S: [0 A/ n8 z: u* H
  49.     {
    8 t! n+ `: \0 [( B' b
  50.         ITK_CALL(AOM_ask_name(uoms[ii], &name))
    0 H4 c, k& T! a( Y
  51.         printf("\t%s\n", name);/ r. y, z% K* `7 i* |
  52.         if (name) MEM_free(name);1 T" F: ~9 E5 m8 W0 f  M3 [4 C( F
  53.     }) X( C8 h8 K! \, ^' r
  54.     if (uoms) MEM_free(uoms);/ C3 l* E: U' V) ?) F
  55. }
    % T7 z" s  p& i, H

  56. , \/ K3 p* G: Z1 _' C
  57. int ITK_user_main(int argc, char* argv[])
    . P7 x8 p- N3 w8 G4 p
  58. {4 u5 S, c4 r' `( `% Q  u) R
  59.     int
    ! r7 P& o. c' s! P9 o0 T; T1 f
  60.         status = 0; : x2 x5 Q' b" o; |4 D- [+ t
  61.     char) ?3 h' ]9 \$ ~$ p/ [+ T7 U
  62.         *message;
    3 ^% X* s% q$ I2 _, S
  63.     / k& V; s/ D8 ?# x
  64.     ITK_initialize_text_services( 0 );$ H! O( l' d& ]: F  o" P
  65.     status = ITK_auto_login();* e$ R. _# `1 J% t3 g
  66.    ! Z, E: V6 T  s$ C
  67.     if (  (status != ITK_ok)) printf("iMAN login NOT successful.\n");  c2 |2 I7 P, _
  68.     else. B' q5 r% I' ?" F" H
  69.     {
      P/ e/ F& Z; p" y% i
  70.         printf("iMAN login successful.\n");" F$ N& h. L2 U1 @5 ?
  71.         ITK_set_journalling(TRUE);
    2 P1 Q  T# Z9 o7 G8 V
  72.         do_it();
    9 j# b0 k% N$ Y
  73.     }9 `3 Q/ q+ g4 E0 S9 ?0 |7 q2 W
  74.     ITK_exit_module(TRUE);9 ?2 P+ q3 v. h& l4 a8 i
  75.     return status;9 N) K# W6 y$ f# l3 o) o
  76. }
复制代码

' k1 d& w" }; Z1 ~7 ?8 r
& q. B6 O8 \( b' ]% V8 f% |5 r: K; P) H
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了