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

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

admin 楼主

2013-10-30 13:46:00

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

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

x

  V+ O( T: B& p, D5 Y# P  w
  1. Option Strict Off: v! E  z2 x+ [$ D  c/ @
  2. 2 {4 A+ \; T5 I4 c$ s0 u7 G# P( h
  3. Imports System
    / l" |- U, f$ u" C" h3 g
  4. Imports NXOpen
    ( L! Y+ p, J3 k' N) F
  5. Imports NXOpen.UF! k" W2 k4 g6 M6 v. B6 V9 I
  6. Imports NXOpen.UI4 T! M- k' l* x
  7. Imports NXOpen.Utilities
    9 I0 f, D  Y+ t: v* C
  8. Imports NXOpen.Assemblies
    8 D* m- q( d5 [; _; p' \

  9. 5 S5 U8 F4 k5 a# T# U7 F4 k
  10. Module create_array_of_all_bodies_in_assembly8 d: E; {4 O% K0 O% b: [

  11. ( e9 `) V6 P& v0 k4 C* {
  12.    Dim s As Session = Session.GetSession()5 i. s& x8 n1 l  ^5 `, s
  13.    Dim ufs As UFSession = UFSession.GetUFSession()
    % D: c( M# ~/ i" e" f2 O4 l+ b
  14.    Dim lw As ListingWindow = s.ListingWindow" m+ v0 Y% R$ ?
  15. , S/ c- ?, ]0 y1 ~0 a2 r- t
  16.    Sub Main()* Z) s) ?, f9 x4 V0 z' C
  17.       lw.Open()# {( y1 {' [: v! A5 \9 l

  18. ) ]- \7 k. B2 y& o
  19.       Dim dispPart As Part = s.Parts.Display()
    3 R  K# j% v$ [5 U
  20. ; q0 n+ M8 U1 g" L
  21.       Dim root As Component = _
    ; V/ o3 s, v6 g7 E3 G& `- p
  22.                   dispPart.ComponentAssembly.RooTComponent2 m% M% H* f" i& g

  23. 7 P3 h; Z& S. ^% \7 t
  24.       Dim compArray(-1) As Component2 T: e% N1 X' }7 U& W* ^
  25. ' B' T' W2 k3 b( u
  26.       stuffComponentArray(root, compArray)
    $ G. J% q0 ?+ f# @% M

  27. 2 G. q  n2 R. `; H2 |
  28.       lw.WriteLine("Component Array Size: " & compArray.Length.ToString())
    ! ^2 T: k* t/ n
  29.       Dim bodyArray(-1) As Body
    0 Y, [% s& J! \: w* h
  30. # Z  q$ C# i- a) d" L
  31.       stuffBodyArray(compArray, bodyArray)4 x: y; y/ G# T: s* L: S! R5 A

  32. 4 y+ O& ]& ~% m, C
  33.       lw.WriteLine("Count of bodies in array: " & _: I4 j) B1 Z* l; [
  34.                    bodyArray.Length.ToString())
    6 `/ W0 g6 w1 I* S
  35. # O% ~* n$ E- t, j
  36. 5 ~$ @! o- G1 ]# P7 [; R7 R: g- B, W
  37.    End Sub+ c6 a& Z: H# o

  38. 6 a4 B0 K2 k8 g# f* x
  39.    Public Sub stuffBodyArray(ByVal ca As Component(), ByRef ba As Body())
    * ?% u6 C- {6 E: O  O; z
  40. 7 X$ [& x0 p- V& ?( L+ G! m7 ^
  41.       For Each comp As Component In ca
    % ~# z. \# ~3 B; J" H2 E' V: V
  42.          Dim c_part As Part = comp.Prototype
    9 J1 V& \, G% C7 U& Q4 c8 ^. H
  43.          Dim localBodies() As Body = c_part.Bodies.ToArray()& w! v. q6 E$ x
  44.          For Each thisBody As Body In localBodies8 J$ ]& x$ i% E  j+ q7 Z2 @( G
  45.             ReDim Preserve ba(ba.GetUpperBound(0) + 1)
    % X  d' j6 c  |. G( K7 h3 x
  46.             ba(ba.GetUpperBound(0)) = thisBody
    . V5 s, N1 v5 p8 X( n2 D) F
  47.          Next
    / z  [% c9 B% ~

  48. " M, ]( y4 ]% q3 _: a
  49.       Next
    " @1 ]7 O6 x0 A% \0 |9 }
  50.    End Sub! i; i+ J* N* d

  51. % K5 T* p% {- H9 _& r8 K; S8 P4 d
  52.    Public Sub stuffComponentArray(ByVal cmp As Component, ByRef ca As Component())
    : {. e0 H% Y5 V. W) r2 B- t
  53.       Dim child As Component = Nothing) [& ]' w  q( h( O( z# c
  54.       For Each child In cmp.GetChildren()3 M+ j/ a; `/ k1 O! U8 C$ z5 N
  55.          ReDim Preserve ca(ca.GetUpperBound(0) + 1)  }' P8 P+ H3 }5 e7 g# S( ?. ^/ J
  56.          ca(ca.GetUpperBound(0)) = child
    * H1 B0 \7 h* ]1 M$ E
  57.          stuffComponentArray(child, ca)
    ! B3 b8 Q0 A% C! V+ L- _
  58.       Next: S* K7 G( L9 T
  59.    End Sub
    8 o/ I' r) [, ?! \

  60. ' f3 O% ]3 L+ I& b2 [% o1 p
  61.    Public Function GetUnloadOption(ByVal dummy As String) As Integer
    " ?( N  B( j/ }" o3 {0 W
  62. 6 z! b2 O  R: [3 @+ `
  63.       Return Session.LibraryUnloadOption.Immediately
    ; u8 T/ a$ L: U/ L- R# p$ r
  64. ( {  K) w5 `" g/ Y# ~
  65.    End Function
    3 L% F* d7 s7 n
  66. ) M/ E0 L5 ?: I( {  |
  67. End Module8 z; z; M0 X. z$ P
复制代码

- P$ }! q7 O' `; q
- m9 |. ^/ v5 ^* r7 U8 N  s: q( l! V+ 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二次开发专题模块培训报名开始啦

    我知道了