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

[复制链接]

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

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

admin 楼主

2014-1-15 19:39:16

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

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

x
  y; E7 r$ D9 m0 s4 W+ _: l6 E
Teamcenter ITK二次开发源码分享:创建测量单位unit of measures' j( r% e+ e! T, Z+ D

2 N0 T' l* o1 [1 I9 K
  1. #include <stdlib.h>' }, L7 t: T1 P' }4 M* o
  2. #include <TC/tc.h>! ~9 h# @- J0 u, h1 C* I3 G
  3. #include <sa/tcfile.h># n8 l3 G9 K1 H- L: P  B6 Q
  4. #include <tccore/workspaceobject.h>
    + `! `( k) r0 Y9 I6 V
  5. #include <ae/ae.h>
    ) w6 y: U: _; b- h+ K: g! }2 k
  6. #include <tccore/item.h>( X! B- i$ e! e, y; H: f# g

  7. 0 W7 w% M. T+ R1 i. }
  8. #define ITK_CALL(x) {           \3 n6 c7 h) Q) g2 T
  9.     int stat;                     \
    , E& Z' J! y( l
  10.     char *err_string;             \
    6 \. c- s: }0 `: H
  11.     if( (stat = (x)) != ITK_ok)   \! O8 s8 {+ ?3 ^3 ~2 c& T. ?5 K
  12.     {                             \9 x, g& B! D6 f; C* J1 I
  13.     EMH_get_error_string (NULLTAG, stat, &err_string);                 \, c7 Q( k5 ]$ C9 }7 [# }
  14.     printf ("ERROR: %d ERROR MSG: %s.\n", stat, err_string);           \. w% M& j# y1 `7 ?/ [
  15.     printf ("FUNCTION: %s\nFILE: %s LINE: %d\n",#x, __FILE__, __LINE__); \
    9 m  N0 s% X3 d& o9 x  u7 W; B
  16.     if(err_string) MEM_free(err_string);                                \6 g. ?6 x, b8 E5 c
  17.     exit (EXIT_FAILURE);                                                   \
      n6 S6 t) e. W
  18.     }                                                                    \
    2 U' Q  ^6 }' F/ G5 H) m( M2 W
  19. }
    8 S# i& Y9 S9 u) }3 _
  20. #define EXIT_FAILURE 1 . P0 ]* n- u: `/ v
  21.         ( L) V4 u" {4 ?5 E" n3 W
  22. static void do_it(void)
    & m2 y" Z! f6 G- T; b% a; `+ X& O
  23. {
    8 R2 a6 O, J, W# K; Q
  24.     int
    * A$ V# I# H2 Z6 P1 S0 B( ]9 T
  25.         n_uom,5 O( {* d' Q, b5 c3 u
  26.         ii;9 G+ t$ l" p: K! @& a1 F5 s6 ]
  27.     char( d# Y2 L7 C5 ]2 w) _8 ~
  28.         *name;# q0 G) C) W4 _5 l7 v% j
  29.     tag_t
    & B3 s  R$ e: s+ L# J( \  x/ `
  30.         *uoms,. ^9 |9 X9 z# ~7 y$ V4 w( W
  31.         new_uom;! N$ _$ E. y9 S8 @/ |. X8 i2 [
  32.     ) f# d; X5 V- [& }9 b: e1 w4 [
  33.     printf("Before UOM was created...\n");   
    8 {1 ]6 Q* [3 n8 F1 F* Y
  34.     ITK_CALL(UOM_extent(&n_uom, &uoms));1 O3 n' a4 J9 U2 X; W+ V
  35.     for (ii = 0; ii < n_uom; ii++)' l5 ~8 s9 ~5 I( ?* {" B0 w( K8 p# p
  36.     {
    * p: C" ?7 T- @  C; s/ B$ X% J
  37.         ITK_CALL(AOM_ask_name(uoms[ii], &name));
    1 F& ?% ], \3 p  P/ V
  38.         printf("\t%s\n", name);
    0 U, P' n- [& L; Z$ H
  39.         if (name) MEM_free(name);
    ! ^# T2 f7 U  p3 Q, Q5 |% V5 N$ ~$ u
  40.     }' g; a! b: v8 ~2 @7 C# @3 Y3 i
  41.     if (uoms) MEM_free(uoms);
    , N& y$ z5 G: V& v
  42.     * n5 A6 w, O9 l0 m2 U. z& e) S
  43.     ITK_CALL(UOM_create("inches", "in", &new_uom));5 h1 i2 K7 \: T& D
  44.     ITK_CALL(AOM_save(new_uom));
    % [* F0 C  i2 T! G7 D
  45.     1 z! \  c9 B! E
  46.     printf("\nAfter UOM was created...\n");   
    7 {" j+ k2 n( U2 m- h6 e, d
  47.     ITK_CALL(UOM_extent(&n_uom, &uoms));8 g3 G4 V6 [4 b& l* Q: p
  48.     for (ii = 0; ii < n_uom; ii++)) B. n6 M# a; Y! Y% h  R
  49.     {
    ' k3 _" ~$ f5 I  [" c. D4 M( p: l
  50.         ITK_CALL(AOM_ask_name(uoms[ii], &name))
    & M/ n, }6 o+ Q
  51.         printf("\t%s\n", name);$ b0 B9 R/ G+ y4 V$ x, z& g
  52.         if (name) MEM_free(name);
    % j, i' h5 n  |0 E7 d
  53.     }5 I, H8 H$ a! a) F
  54.     if (uoms) MEM_free(uoms);
    + J+ a! g" r' k0 e4 r
  55. }" O$ N9 S9 ]+ T, s5 }3 S" V# Y5 ]
  56. ! p3 {2 x+ s" S7 a1 |- C0 F
  57. int ITK_user_main(int argc, char* argv[])
    ( {, B: p) R' W9 |7 V0 F' y
  58. {
    + L7 s2 t" m; m. V  b
  59.     int
    : R; w! R7 Q6 b: K% M5 M$ U
  60.         status = 0;
    ) U1 Y5 o' `: x" Z
  61.     char
    0 H. x" K+ O( I* J4 g
  62.         *message;
    ! _6 S+ N+ W. A& R) c1 z9 _
  63.    
    7 r, N& `: u& Z
  64.     ITK_initialize_text_services( 0 );0 i4 m( o  M) G% u& b! C
  65.     status = ITK_auto_login();0 t7 E* B$ y0 K$ B4 Z9 ~
  66.    
    ( ^  f! F: A4 [- {# S: K/ ~
  67.     if (  (status != ITK_ok)) printf("iMAN login NOT successful.\n");
    # A& o" {+ Y" p- F- ?
  68.     else
    5 D0 g6 T/ ~% U( k( K$ W: D; [
  69.     {/ N: |3 L# L- W& V& E
  70.         printf("iMAN login successful.\n");% N# o( B* z, U5 V; Q7 W6 k! T4 |% v
  71.         ITK_set_journalling(TRUE);( U9 B* i$ P0 O  B
  72.         do_it();
    ) A' N- i. M1 x6 {$ J/ U- K6 H: B% U1 L
  73.     }
    & o/ n2 A+ |0 U% M* i6 Z; S$ h
  74.     ITK_exit_module(TRUE);7 ]  a9 j. h8 O* f
  75.     return status;
    # x$ q0 |, Z# c4 p: V
  76. }
复制代码

* D" }. i. d: @& F
6 s( A0 ]0 Y* o' V, Z( \2 e. B, v* \. 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二次开发专题模块培训报名开始啦

    我知道了