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二次开发源码分享: 加载所有的装配组件----全部加载

[复制链接]

2019-4-12 09:06:31 2169 0

admin 发表于 2019-4-12 09:06:31 |阅读模式

admin 楼主

2019-4-12 09:06:31

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

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

x
[mw_shl_code=csharp,true]Imports System1 k$ M8 ?- b1 j. t
Imports NXOpen
6 y+ G8 G! F3 v6 i. a; R9 E- aImports NXOpen.UF
6 }3 @1 H- z6 F: V5 ~, ]Imports NXOpen.Utilities
) j+ ~5 {, k' X7 Q! |4 E. E0 L'
7 A1 V7 q5 O6 w' The OpenComponents() parameter
) v8 z$ Y1 Q# T. G: [+ W' NXOpen.Assemblies.ComponentAssembly.OpenOption.WholeAssembly
4 S" D0 G  N3 Y* ~7 z' only opens unloaded components fully (see also PR-8406345)  k0 W: ]8 y% h8 _/ q" m" f* h
' Workaround: collect and open all components individually
8 |, s. \( S" C'+ d' \" [8 q  }! L1 _8 X8 I
Module NXJournal
5 T% E  {! l% f# b- T    Dim theSession As Session = Session.GetSession()+ Q! l( Q0 o; M1 @5 @' V2 d- d" m
    Dim theUFSession As UFSession = UFSession.GetUFSession()
7 M# H: }4 e: x4 `/ y6 a7 \# ^! b    Dim dispPart As Part = theSession.Parts.Display
% n+ i! R  ^  f
# |3 o" [9 q& Q    Sub DoIt()
& Q- `+ e9 q0 b8 n+ e5 }3 [) l; h6 q        Dim allComps() As Assemblies.Component = getAllChildren(dispPart)
+ A6 ^3 J5 h: |+ n. P        Echo("Number of Components: " & allComps.Length.ToString)* a( C8 N; J( ~5 @# S" t  v& w4 u4 |
        For ii As Integer = 0 To allComps.Length - 1# U7 Q' |* j1 T0 m5 w
            Echo(allComps(ii).DisplayName)
8 {/ b8 Z# l4 C+ c7 t        Next5 R# C1 Z# x' m! x: I
/ O) Z' X: N; f9 E4 P
        Dim option1 As Boolean = theSession.Parts.LoadOptions.UsePartialLoading$ Q* _4 g0 _! w9 G
        theSession.Parts.LoadOptions.UsePartialLoading = False+ C# V) l  {6 X' g  c
/ E2 i9 I( k1 O* g% Y
        Dim openStatus1() As NXOpen.Assemblies.ComponentAssembly.OpenComponentStatus0 ^# Q& m9 X& D0 B
        Dim partLoadStatus1 As NXOpen.PartLoadStatus = Nothing
3 Q9 r% h& B# e" w        partLoadStatus1 = dispPart.ComponentAssembly.OpenComponents(
9 T2 v. u! Q4 T4 U+ n* n& n            NXOpen.Assemblies.ComponentAssembly.OpenOption.ComponentOnly, allComps, openStatus1); ~8 Y) \- s1 y  M- h, i; A3 ^
& t2 s4 @6 E. p- a: n8 o, ?
        reportPartLoadStatus(partLoadStatus1)& _7 b. T3 k$ s2 }" l& a5 J
        partLoadStatus1.Dispose()' I5 T- l: g; i5 w' u

: V  \* A) I1 g& N2 h0 Q& H        theSession.Parts.LoadOptions.UsePartialLoading = option11 y1 U% |$ j) i# c

" v+ e- W$ }* ^. S: e1 m    End Sub9 i! g# S# x& B/ v+ K5 Q5 Q, [

' y1 _1 V) F; [. P$ @$ c# u0 Y    Function getAllChildren(ByVal assy As BasePart) As Assemblies.Component()( W5 P- k# J# E
        Dim theChildren As Collections.ArrayList = New Collections.ArrayList
+ w, ?5 Q6 \4 Y, W        Dim aChildTag As Tag = Tag.Null
5 J1 t& X+ V% ~9 @! j8 P9 D
. R5 ]! A3 B* E( _5 v        Do/ P0 L( f4 q6 g* V
            theUFSession.Obj.CycleObjsInPart(assy.Tag, UFConstants.UF_component_type, aChildTag)  i; O; H4 e$ H7 g4 v( p
            If (aChildTag = Tag.Null) Then Exit Do
: g$ b5 e# s. f$ u4 c8 U  L3 [1 S  Q# D8 J  b% F( T
            Dim aChild As Assemblies.Component = NXObjectManager.Get(aChildTag)% j* T; z! s: p$ c: @- j: ?/ s5 b+ q
            theChildren.Add(aChild)8 Y0 {- h& Y3 L
        Loop
5 Y$ h% s& K2 p& R' C' W. x        Return theChildren.ToArray(GetType(Assemblies.Component))- k! A9 ]7 _# U' o
& _/ P, o) {' u
    End Function  A3 C- `, B4 O- V" Y
" J* H5 ]. s* \1 i7 M
    Public Sub Main(ByVal args As String())
; {5 `' A: V+ F  @$ l. y        If dispPart IsNot Nothing Then
) m3 }* l) ^- _  M" F) X1 @0 Z            DoIt()
) ^* ~; u; v/ l% d            Return
& b3 D9 A* Z0 ]        End If
& N2 O7 d$ o# v* Z& P+ z' Q! O
! o5 _- k2 j$ c  g& |    End Sub, J4 e% m1 P; E! h; W1 a

! T3 e; c5 S" W4 [* V    Sub Echo(ByVal output As String)
. K: R/ N& O( S4 ~3 W2 |$ N  E        theSession.ListingWindow.Open(): N; z, c, u, V$ Y7 j
        theSession.ListingWindow.WriteLine(output)% L. J( ~! `/ a5 f; o' Z+ v
        theSession.LogFile.WriteLine(output)+ e, }5 _/ ^1 V; a( S! r  g) Q
    End Sub+ [! J' Q) m7 n& L& Y7 j* q
% I$ p; M6 _: X3 k( f8 d" e0 \. H/ u
    Sub reportPartLoadStatus(ByVal load_status As PartLoadStatus)3 Q& s+ r# S3 ~! }7 P- Q
        If load_status.NumberUnloadedParts = 0 Then8 W0 [' ]" g$ E) S
            Return0 U( m6 k$ F! A; W- N7 w$ g+ f
        End If
+ u0 Z3 b, `6 F* k1 t
% O% `* a0 o4 l$ R5 A# F& |0 J# _: ?        Echo("  Load notes:")6 G$ s/ c# B  k/ {& Z* ~( o# G+ A' @- m

: r+ D9 [( H' c9 X4 n9 _/ w        For ii As Integer = 0 To load_status.NumberUnloadedParts - 1
3 n  z; O3 z: {7 y( n3 ]            Echo("  " & load_status.GetPartName(ii) & " - " & load_status.GetStatusDescription(ii)), C! W& s/ |& d$ h0 Y
        Next
5 j+ S* z( G2 q& S  I    End Sub& g* X* N: K, K
" h' p* ~% O. `# p1 e$ ?; [& m) O
    Public Function GetUnloadOption(ByVal arg As String) As Integer+ w( c6 [- B+ E3 |
        Return Session.LibraryUnloadOption.Immediately3 }3 W7 x# A* C- h3 ^
    End Function; s3 m2 D: ?7 r4 j! {6 E1 z

# ]1 l' d$ ]) h1 @End Module[/mw_shl_code]
" e% j3 k. @  A7 M3 ]9 P
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了