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

[二次开发源码] NX 二次开发源码:从整个装配上获取所有的实体

[复制链接]

2013-10-30 13:46:00 3618 0

admin 发表于 2013-10-30 13:46:00 |阅读模式

admin 楼主

2013-10-30 13:46:00

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

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

x

) S+ R4 Y5 m! s" u, \( |; v  k3 z
  1. Option Strict Off: {* N. \% M* m+ C9 ~
  2. . r5 H% o$ k9 U( n* c- \( {! ]8 U
  3. Imports System
    * S) G, B9 v( b
  4. Imports NXOpen
    $ G1 u5 P$ P& L6 z
  5. Imports NXOpen.UF
    6 M, q' a  d: s' ?6 O0 r% j# T
  6. Imports NXOpen.UI2 b  Y$ W7 ?) _% D/ x1 E' c
  7. Imports NXOpen.Utilities! @" M; E% E8 Q' o2 k6 j
  8. Imports NXOpen.Assemblies: q$ A9 \, w' z0 s' }% T
  9. / L  P# k. i1 R! Z4 T& y
  10. Module create_array_of_all_bodies_in_assembly2 U& X! `% N- d" A

  11. 0 O1 c. z& ?( Q( h7 @" t
  12.    Dim s As Session = Session.GetSession()
    ! v7 ~4 L: L6 I6 n/ b
  13.    Dim ufs As UFSession = UFSession.GetUFSession()2 D1 W% q! J: B
  14.    Dim lw As ListingWindow = s.ListingWindow
    - [& z( c0 m& B3 j( P- A

  15. 4 W6 w6 q/ Z9 S( U3 A
  16.    Sub Main(). m5 V* V/ R+ H: M1 P; i
  17.       lw.Open(): @* U( M; h& h  _0 a
  18. 0 Z4 d/ w$ p; f5 g+ w
  19.       Dim dispPart As Part = s.Parts.Display()6 ?% [! m, H% |6 R4 P7 z' Y
  20. # V: v5 Z8 t; h- @! u0 T9 S$ B" ^
  21.       Dim root As Component = _+ O) ~; {2 Z" p% W( N; t1 N( `+ I9 Z) d- I
  22.                   dispPart.ComponentAssembly.RooTComponent
    # V5 A3 e. r2 C0 u( k5 V

  23. # y  J8 V( m  p: {
  24.       Dim compArray(-1) As Component
    . h2 n# e( u; }# x
  25. 8 ^7 f' E4 C& M: E* U
  26.       stuffComponentArray(root, compArray)
    7 R' Y- F: B+ @
  27. 9 S0 C# L8 x  o7 j1 |
  28.       lw.WriteLine("Component Array Size: " & compArray.Length.ToString())
    , J, b; K9 {) O; B9 e3 A; a) I
  29.       Dim bodyArray(-1) As Body) a5 N; V5 @7 M% X' J

  30. # B) ?4 D6 w& l2 ^# G! j
  31.       stuffBodyArray(compArray, bodyArray)% u* W- L2 Z& k6 H# j( x7 R

  32. / a: Q0 w) s9 j2 X- }( p' @
  33.       lw.WriteLine("Count of bodies in array: " & _8 S, m  v. B# c$ {0 h& n
  34.                    bodyArray.Length.ToString()): H% b! T7 v+ c* N! o

  35. 0 K5 r% {" ~  O8 P0 G2 W- `: M% ~

  36. . n4 I# k9 Q, }" Y6 a) i8 J0 j1 h2 ]
  37.    End Sub
    4 `" }* h* f+ C4 o$ D9 W& u

  38. ' y: N- N) z  }2 A
  39.    Public Sub stuffBodyArray(ByVal ca As Component(), ByRef ba As Body())% Z* p2 r1 v& q9 R

  40. ' `: _  Q$ D: r7 f
  41.       For Each comp As Component In ca9 K& `2 k9 v$ I: P8 u/ d
  42.          Dim c_part As Part = comp.Prototype
    5 \4 b( R( X% v* R' s: A8 v& G
  43.          Dim localBodies() As Body = c_part.Bodies.ToArray()
    1 K& X% ~1 f  f0 o! o
  44.          For Each thisBody As Body In localBodies* ~/ ^& n! o0 q  g
  45.             ReDim Preserve ba(ba.GetUpperBound(0) + 1)
    . Q. k1 t* q# ^
  46.             ba(ba.GetUpperBound(0)) = thisBody- s/ }+ Y" ^6 x: f
  47.          Next
    " y& G+ _3 ?$ B  \$ K5 X0 Q" a

  48. 0 ?! m6 m2 ]' M: r% M# l
  49.       Next
    % I& I& l5 K" x. W0 @$ Q
  50.    End Sub
    + r6 d! N& D3 n, r3 {) r

  51. $ c( d: [4 Q2 C( \6 D) M) H# J
  52.    Public Sub stuffComponentArray(ByVal cmp As Component, ByRef ca As Component())2 e# P: D0 k" @' ~
  53.       Dim child As Component = Nothing* g& \; s9 [; i+ p+ [
  54.       For Each child In cmp.GetChildren()
    6 G7 \, O  k, q- s' X
  55.          ReDim Preserve ca(ca.GetUpperBound(0) + 1)
    # S! m4 B" y' R) o( |8 A
  56.          ca(ca.GetUpperBound(0)) = child7 k% o$ w+ U4 G. {9 X, M
  57.          stuffComponentArray(child, ca)
    ; d- k8 R5 T* c2 a4 l1 R" t
  58.       Next
    / ?7 D0 P. m1 L4 d
  59.    End Sub
    ' R; L& @, n) O& I4 p
  60. ) t- O2 @+ m- ?( E
  61.    Public Function GetUnloadOption(ByVal dummy As String) As Integer
    $ o" {$ s; Z1 t/ l  e% T, `

  62. / ~$ Q" \7 e# ?) l- K6 k8 n
  63.       Return Session.LibraryUnloadOption.Immediately9 l! s  q% Z- I
  64. : p* n+ [4 S/ z! C2 U( f
  65.    End Function
    8 X, B( l! W* n5 _9 c
  66. + S, n5 @2 `% Q/ C
  67. End Module
    . {- Z5 }4 p: S) J8 |' V: m
复制代码
9 k& [7 T7 p3 n" R$ {
; j1 ?. ]( E- f. T: X

9 r) a4 m4 b0 \4 x4 J- t
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了