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

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

[复制链接]

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

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

admin 楼主

2013-10-30 13:46:00

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

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

x
0 n7 w/ R( n. S& z7 T
  1. Option Strict Off
    ! l* W9 k) {3 d! e$ M8 t# o: ~
  2. * E5 O* `$ N' F- `
  3. Imports System0 ~# j. t# x( B& l+ @9 p6 ?9 D$ ?
  4. Imports NXOpen( W, i$ J( ~: x
  5. Imports NXOpen.UF$ D9 V' _, l+ W5 |* B) Y
  6. Imports NXOpen.UI! q- ~0 ], ^: g- D$ ^
  7. Imports NXOpen.Utilities) n/ l0 i$ S: E* `
  8. Imports NXOpen.Assemblies$ \9 j0 r8 b1 j' s  M

  9. & F8 l8 I5 @, L# Z. O& p2 j
  10. Module create_array_of_all_bodies_in_assembly+ Q5 Q% I, K, ?& e

  11. 7 m! g, L9 J" O. z- d
  12.    Dim s As Session = Session.GetSession(), d# U( e; M  V  Z- P7 F2 z" F' f
  13.    Dim ufs As UFSession = UFSession.GetUFSession()
    8 D- L" H' y/ m  L/ C
  14.    Dim lw As ListingWindow = s.ListingWindow
    0 O! y9 j4 l, a1 w0 y

  15. 8 o- s, O/ O, }
  16.    Sub Main()
    " ]# K- r  o( C4 A& q
  17.       lw.Open()
    - q- n8 S3 Q9 S7 P

  18. + @/ |" D+ s" a, m# ?  M) L
  19.       Dim dispPart As Part = s.Parts.Display()
    2 I. D* H" y2 p8 z. a. n3 h

  20. ( N% V/ O+ y* Y6 a, Y
  21.       Dim root As Component = _
    . W4 F" O8 o7 q# X  r* }) D/ Y+ [
  22.                   dispPart.ComponentAssembly.RooTComponent' G& ~& O* w. _& q) ^  f& m
  23. 7 n) }' R  v# t; b8 e: M
  24.       Dim compArray(-1) As Component
    - b7 k  q  g+ r! S. |) q/ y

  25. 5 `, i% x, w& q8 r
  26.       stuffComponentArray(root, compArray)
    7 [. J: g+ Q# }
  27. + k$ r: i4 p) Q6 r
  28.       lw.WriteLine("Component Array Size: " & compArray.Length.ToString())
    : U/ d+ H: {0 m1 J
  29.       Dim bodyArray(-1) As Body9 A1 s. B" h8 h* h
  30. 8 L: Z$ [% ?% a; P) U
  31.       stuffBodyArray(compArray, bodyArray)
    ( m1 t' N7 @$ \3 Q9 H

  32. * ?) P8 R9 V  [1 V
  33.       lw.WriteLine("Count of bodies in array: " & _
    $ o6 C4 S/ X% e2 m( E) [$ T) [2 S
  34.                    bodyArray.Length.ToString())' v) g' V: _* H/ }# ^
  35. : F. p6 r( u* [; @9 S; M
  36. ' H" w6 B. g0 f3 L' `$ @& c
  37.    End Sub1 Z2 r9 T3 B+ ^- c3 j. U- D+ }) [

  38. & r) c0 k! G% p0 D8 I
  39.    Public Sub stuffBodyArray(ByVal ca As Component(), ByRef ba As Body())
    3 i2 T" x+ l# d+ F
  40. 1 Y8 C, p4 c( ]! j+ c3 F
  41.       For Each comp As Component In ca
    # O, m/ I6 o) O
  42.          Dim c_part As Part = comp.Prototype
    ! S# a, T9 G" v* V% ]- l
  43.          Dim localBodies() As Body = c_part.Bodies.ToArray()# r' Z9 }& c6 p/ i, n( O
  44.          For Each thisBody As Body In localBodies
    ) F4 H5 b% c3 o# n
  45.             ReDim Preserve ba(ba.GetUpperBound(0) + 1)
    * O4 H+ F7 w8 s  Y& b, ^
  46.             ba(ba.GetUpperBound(0)) = thisBody0 ?; `$ j5 z! {: E0 F
  47.          Next! ]. I& V7 l- n
  48. 8 ^% k/ Z( R( H1 ~1 k
  49.       Next7 F: T3 ~- h' e7 c; q) p6 m* D
  50.    End Sub
    # a9 M6 L* d0 \6 j2 f" t

  51. & ?* }1 d. o6 y" K5 A5 w
  52.    Public Sub stuffComponentArray(ByVal cmp As Component, ByRef ca As Component())
    0 Q9 b0 r7 j8 ^5 m
  53.       Dim child As Component = Nothing) w: S& `" x* a  ?5 g9 I
  54.       For Each child In cmp.GetChildren()2 S6 U- p" N% m' Y
  55.          ReDim Preserve ca(ca.GetUpperBound(0) + 1)
    3 v. d% L4 B6 f/ Y
  56.          ca(ca.GetUpperBound(0)) = child) m* B2 r1 d1 G$ W: p
  57.          stuffComponentArray(child, ca)
    0 Q  o7 a" y# S% b  \2 f! H
  58.       Next
    6 z: Z+ |7 o* B* L/ E
  59.    End Sub' \5 u2 `$ \' _/ y3 c

  60. % k  h; M; A, |9 s/ E2 }3 f
  61.    Public Function GetUnloadOption(ByVal dummy As String) As Integer8 O7 ?& A- N4 ], f) _  X% j

  62. 3 h  T) q' N2 g/ s* C: o5 H! o/ T6 J
  63.       Return Session.LibraryUnloadOption.Immediately
      M7 R% v1 }2 ~( y% Q

  64. , j# P6 c$ Y+ ]: G& u2 M' f
  65.    End Function; C* N5 G) @& k* l' X& T6 ~

  66. 2 j( Q9 Y# z  Q, A/ B
  67. End Module' b& W8 Z4 X% ]! a
复制代码

4 q  g/ H5 y" x* I4 L- z2 r, R2 t5 t/ S) @4 u, D3 K4 O; r. r+ r

) l( f; L8 T, i* O
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了