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

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

admin 楼主

2013-10-30 13:46:00

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

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

x
6 ^! E* O8 u; S" |9 o( U& S
  1. Option Strict Off/ I" `0 e1 i3 ~. R0 \; Z

  2. ! ^" V9 G1 W+ ^- Z& W; Q9 O
  3. Imports System, _/ T% s% M) G' w( Y0 \4 ^
  4. Imports NXOpen3 }' u3 O$ T. L- f
  5. Imports NXOpen.UF+ B9 u: X, ^5 H2 E/ r. |" Q
  6. Imports NXOpen.UI4 `+ g& E  G: a, X5 K2 L
  7. Imports NXOpen.Utilities
    7 V' Y# _2 y2 W: r# ^/ w3 \
  8. Imports NXOpen.Assemblies
      O* j* S1 r0 `+ z) W9 ~! F

  9. 6 H; F- M; f1 Z4 t+ W+ m: K, }
  10. Module create_array_of_all_bodies_in_assembly
    8 a( b- P2 J  v( E! U3 w# a

  11. 4 M- `$ Z+ }& ^; _
  12.    Dim s As Session = Session.GetSession()" h8 B! @8 F  L, n+ n6 \& N% \
  13.    Dim ufs As UFSession = UFSession.GetUFSession()) `( a, p3 M! Z) s+ I! B
  14.    Dim lw As ListingWindow = s.ListingWindow
    * y: f1 u$ l# H+ j1 w) x6 h
  15. / R  V, E% M: g* K  ?" j5 f
  16.    Sub Main()6 n0 k0 |  X1 a( K) ]2 F7 D' j
  17.       lw.Open(); j* T; P' p6 o8 M3 Q2 O

  18. " y1 T/ o# q( U2 F2 O, d/ t
  19.       Dim dispPart As Part = s.Parts.Display()/ N. M* [) ~9 S2 e3 g
  20. 9 c$ \0 e# V: m% C5 l5 G. f
  21.       Dim root As Component = _1 G2 j( e4 M) P# o6 q( U
  22.                   dispPart.ComponentAssembly.RooTComponent( K3 p8 y$ S: K3 y& A, w1 Y
  23. $ ^. K! ~/ H0 n* q
  24.       Dim compArray(-1) As Component
    ! X9 I) T( J4 j- f4 R1 @

  25. + p2 |' H4 Y( _( |
  26.       stuffComponentArray(root, compArray)+ e! p$ h  q1 a& Q
  27. # x" @! j# U3 F; @
  28.       lw.WriteLine("Component Array Size: " & compArray.Length.ToString())
    9 G: `$ U4 W3 ^3 N. h9 [
  29.       Dim bodyArray(-1) As Body# f, r: v' i# k2 M9 a# b& U

  30. 5 ~/ e! p: g: C+ P; q
  31.       stuffBodyArray(compArray, bodyArray)5 t( t! @3 O; s' s( K: U1 l  s
  32. , K( b( h/ S4 h, r2 S7 H
  33.       lw.WriteLine("Count of bodies in array: " & _
    5 K. _  M6 z  [2 O. V, C) K* G5 r- ~
  34.                    bodyArray.Length.ToString())
    * c1 R" h0 g. D7 Q5 }3 \) i; g0 o* g
  35. . ~$ D, D- t+ J; x- W1 |
  36. 3 W6 m* V& Y6 f: _3 I7 E* J
  37.    End Sub
    " }4 ]7 d8 h) E2 u! p4 Y
  38. 1 w4 b/ l% R! [7 S" y5 \! O
  39.    Public Sub stuffBodyArray(ByVal ca As Component(), ByRef ba As Body())
    ) H  ^' N  o+ l, }4 ]0 |2 R6 W
  40. : }8 O7 y" ~; ?5 ^
  41.       For Each comp As Component In ca" n7 o* M8 P9 z0 `) Q- V6 Z
  42.          Dim c_part As Part = comp.Prototype
    6 X% `+ f9 _( y! D( X% r
  43.          Dim localBodies() As Body = c_part.Bodies.ToArray()
    - X# z) s3 d4 }) v  F0 T5 r
  44.          For Each thisBody As Body In localBodies0 G$ }- p: D' n  Q4 o, U' H; f
  45.             ReDim Preserve ba(ba.GetUpperBound(0) + 1)6 t0 w, }, e8 w( g* V
  46.             ba(ba.GetUpperBound(0)) = thisBody
    2 t! u& ?; P) {+ V8 q
  47.          Next
    ) E- c6 U  r8 c4 F( h" X5 E' Y
  48. 0 I- p1 G. a5 u, u2 [2 ]
  49.       Next
    / D8 }" Y1 P5 \0 l! y9 H
  50.    End Sub* f& ]: B5 T( J  R9 P2 v

  51. 3 p' u7 W- }/ R: k0 @. D1 N
  52.    Public Sub stuffComponentArray(ByVal cmp As Component, ByRef ca As Component())' S. U2 D4 M5 q' `! H+ |6 j
  53.       Dim child As Component = Nothing8 |% f7 Q( Q0 y
  54.       For Each child In cmp.GetChildren()  W$ o, N! ?* k1 S, C" F" q" V
  55.          ReDim Preserve ca(ca.GetUpperBound(0) + 1)( g! W  d& Z4 E& Y  q
  56.          ca(ca.GetUpperBound(0)) = child
    9 b# n0 o, X" }
  57.          stuffComponentArray(child, ca)' K# n4 k& Z2 }# E$ q+ c5 ]- G
  58.       Next" B" h4 s, `' ?
  59.    End Sub' U' z/ Q* O% g* @! N8 y

  60. 9 N) N: P7 Q2 T0 u4 H
  61.    Public Function GetUnloadOption(ByVal dummy As String) As Integer0 K2 J- ?) M$ c% i) X6 E& q, D( k
  62.   Y- K) g& F9 K! n
  63.       Return Session.LibraryUnloadOption.Immediately# w. ?0 @; V! b6 h

  64. # O; ^$ Q$ ^1 c, u. d$ v7 q, e
  65.    End Function; C& D% h: Z. e& [- [, [
  66. 5 B# S) o) E& Q
  67. End Module$ P. x* S1 u, J" `- }1 W; w
复制代码
% @+ u3 K5 o8 \5 p" O7 ?- T% k9 ?" {
. W7 J: [, r% O1 V/ B
4 A& L/ M0 c$ r) x
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了