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-国产软件践行者

Catia二次开发源码分享: 获取装配所有组件列表

[复制链接]

2018-1-10 10:12:25 2381 0

admin 发表于 2018-1-10 10:12:25 |阅读模式

admin 楼主

2018-1-10 10:12:25

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

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

x
( u' Q# f0 D! \* b( C
Catia二次开发源码分享: 获取装配所有组件列表
+ Y7 |* k" k7 o
; M5 n+ k+ X) d8 W
2 p& a) t& _4 u9 [[mw_shl_code=c,true]/* ----------------------------*/9 w+ G% k' ]8 |& S6 i  x
        /* 2. Retrieves Root Product   */
6 k9 t) o- R/ v: T2 Q        /* ----------------------------*/* `7 w4 l5 f# M6 o/ d. k$ o/ O
          Y' S$ Q$ w) n
        // Begin navigation throUGh the document => start with the RootProduct.9 x0 U1 d8 V) y! R: a7 M8 ]* e
        CATIDocRoots* piDocRootsOnDoc = NULL;
4 `( _$ R; q" l4 g7 M        rc = pDoc->QueryInterface(IID_CATIDocRoots,$ |! E# G: W* B7 x  ?) q
                                      (void**) &piDocRootsOnDoc);: Z: b. e, M9 H% Y
        if ( FAILED(rc) ) return 3;
6 G- g: {- L6 t  @        ; P+ k% x0 e8 p
        // get the root product which is the first element of root elements! b$ G: M( w; Z, ]) I4 n% }( }9 m& R
        CATListValCATBaseUnknown_var* pRootProducts =
7 D3 u% v* [& H3 I                piDocRootsOnDoc->GiveDocRoots();3 I# F1 k- L# ], Y. L
        CATIProduct_var spRootProduct = NULL_var;
2 x7 f' y7 }4 e" O, y       
  z( [- [( i% Z4 u# @* e1 e        if (pRootProducts && pRootProducts->Size())3 O4 X, s2 M( {) N
        {  
- T& _) o( o( a- i1 t" {3 a                spRootProduct = (*pRootProducts)[1];9 |  M4 t8 W7 a* k
                delete pRootProducts;
0 |6 W& u6 a* T                pRootProducts = NULL;2 d  r+ v7 M9 T" v1 b- u3 U" W  f3 a" q
        }% u, V* F  }( ?
/** @anchor err_1 piDocRootsOnDoc not set to NULL after release */ , |% k3 z! V6 H% V7 p# \( v2 K% O
        piDocRootsOnDoc->Release();9 L7 i+ ^# N7 q& X, ]
        piDocRootsOnDoc = NULL;
/ M# y. H3 Y8 H! l- g       
. ?, z% g- X) ^' a5 w# `4 H. r        // Get CATIProduct handle on the root product.
8 G, _: F# b% D+ N        CATIProduct *piProductOnRoot = NULL;
: E% f7 N- ^/ q1 \  z( A; n        rc = spRootProduct->QueryInterface(IID_CATIProduct,
) }/ |' |& e+ H, |- i                                               (void**) &piProductOnRoot);
' d- U# H2 ^# X' }  B        if ( FAILED(rc) ) return 3;( M" l0 N* `8 `

1 ~3 O, I- D) D, \2 p        /* ---------------------------------------*/
1 v7 ?- W" n: E2 n2 w; Z' j. k        /* 3. Retrieves children under the root   */
: ?  w8 w# F/ I3 N( ]: y) X        /* ---------------------------------------*/
7 J1 C' z& K; `. p* E        1 K3 U: _  x' b) }5 M  e
        int nbOfDirecTChidren = piProductOnRoot -> GetChildrenCount() ;! [& }1 D7 K, [$ ~0 S% Z
        cout << " Number of direct children under the root = " << nbOfDirectChidren << endl << flush;
$ T# A$ b/ s; F# Y  \- t7 q        $ B- }7 I, P# o2 k. @$ a4 v0 G0 W! c, X
        // then on a root product, get all the children agregated to it.
8 n; [8 e( r2 T* N% J4 A        CATListValCATBaseUnknown_var*   ListChildren =# P6 A% c5 W4 m, r. F9 v
                piProductOnRoot->GetAllChildren();
: O; g, [6 T' M5 a, }! C) H/** @anchor err_2 piProductOnRoot not set to NULL after release */ * ]5 {8 C" Q8 g' O4 d: D9 X
        piProductOnRoot -> Release();) g5 Z1 o# Q8 x6 m! n( h
        piProductOnRoot = NULL;
1 b  A+ W5 |. u7 b9 T* X5 }        if(NULL != ListChildren); n: A: S& R" g2 x- A
        {
: W8 w* }: c0 p& s- Y5 `5 z" ^                & \- K- A: a: T8 R4 O6 q
                int numberOfChildren = ListChildren->Size();
' v9 j3 A7 L3 p: S: a( C/ T$ }                cout << " Number of all children under the root = " << numberOfChildren << endl << flush;# a3 f% f9 A  U9 e, A2 f4 `: W
0 l+ P/ Y4 N3 L" A+ V  v4 E7 T; L* y
                /* -----------------------------------------------------------*/  X! L, q  ^7 j" b
                /*  4. For each child, get its partNumber, and InstanceName   */
+ u1 e; P% j; @                /* -----------------------------------------------------------*/
0 i% K  _, J5 m, }; k1 q3 @                CATIProduct_var spChild = NULL_var;
( v3 z( b. h, ^( l2 R2 g                for (int i=1;i<=numberOfChildren;i++)
+ W' b- E& R7 v2 S) ?* N                {$ F2 B" z! N4 d- D6 g
                        spChild = (*ListChildren);$ c% b* V9 f& G
/** @anchor err_3 spChild not tested before use ( if !! ) */ . M& ?# t8 }0 }/ W$ E/ V
                        if ( NULL_var == spChild ) return 4;
# W. M$ C0 b7 U& w% Q$ d8 v                        CATUnicodeString partNumber = spChild -> GetPartNumber();2 z; D, h; N& x
                        CATUnicodeString instanceName (" ");: I( ?( S/ M. _- ^
                        rc = spChild -> GetPrdInstanceName ( instanceName ) ;
/ ^. A5 m- j  m0 R7 N3 H                        if  ( FAILED(rc) ) return 4;( D' K( v2 m1 D
                        & v; q$ J( T% ?
                        cout << " child number : " << i << endl << flush;
" `3 H* n. j, t. |, l' O                        cout << " has as part number : " << partNumber.CastToCharPtr()  << endl << flush;& [: ~5 e" E$ i9 Q% v( d
                        cout << " and as instanceName : " << instanceName.CastToCharPtr() << endl << endl << flush;6 Q: c0 j! n" x
                }
4 X0 c. m. V0 f: E3 l2 s                delete ListChildren;
. r, z" T  [# _4 ^6 g& [: t" o- s                ListChildren=NULL;
( m6 V4 D( E, j4 J  g6 r        }       
8 j: S7 x1 Z0 @4 r2 \        /* -------------------------------------------- */
4 W8 K# R' z. [# W0 \        /*   Ends the session                        */
. m8 n  Q" O1 `/ h  [        /* -------------------------------------------- */[/mw_shl_code]4 z$ g' @+ z% u. O1 R! p, `  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二次开发专题模块培训报名开始啦

    我知道了