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二次开发源码分享: 如何判断当前零件的类型,很聪明...

[复制链接]

2018-7-27 11:00:30 1981 0

admin 发表于 2018-7-27 11:00:30 |阅读模式

admin 楼主

2018-7-27 11:00:30

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

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

x
- T* F4 f% P, l/ k
. F4 z- v: m/ j0 k( [
NX二次开发源码分享: 如何判断当前零件的类型,很聪明...' y" @. s6 M: O, f
  u4 z: E6 u2 i# O# u2 [
' }! W" p1 u# a) ^
大体思路如下!!2 F9 T7 f3 i6 J; E

4 K; I: a2 I8 }- z+ o; r
4 m( J8 T7 N7 c  j* S   enum PartTypes {Empty=0, Model=1, Drawing=2, MasterDrawing=3, Assembly=4, Undefined=5, MasterModelDrawing=6, Invalid=7};% R* g$ A. [; ^) r: ^9 A; B% O
  
( S, e( o3 t9 J9 F  void DoIt(string[] args)/ H3 D5 {, h! g* V- i% ~' |3 \3 N
    {4 H0 M7 a  o3 L) v& K
        Part displayPart = theSession.Parts.Display;- I5 N' s2 a& l$ F3 X. K2 L( L
        if (displayPart != null) 1 \1 j. z0 ]9 o# S
        {& ^  E+ C* P8 e
            GetPartType(displayPart);+ [; k' u% |9 T$ f  ~
            return;- a- v5 b6 g. v% Z. O
        }) d& {( ]7 x, A, }6 S

/ u8 G# {$ j( R1 Z2 y
  G% K- x" [4 C, V, U
        for (int ii = 0; ii < args.Length; ii++)
2 \3 d( e! _" @- z0 J        {
( f/ m6 I0 V2 t: F& l$ O            Echo("Processing: " + args[ii]);7 h2 K: _! j6 b3 d! V* N2 t# |
            try , M! v- ]! B5 R$ @
            {
( ]" S2 t: n4 ]4 x                PartLoadStatus loadStatus;
" b; @  @. D3 O7 c                displayPart = (Part) theSession.Parts.OpenBaseDisplay(args[ii], out loadStatus);% l$ P6 S8 I/ V8 l+ u( n% M
                reportPartLoadStatus(loadStatus);; q  P' {" h! Q3 x/ }/ C% ?$ P

, H, v% D" P/ M% Y$ P
; \1 L2 q8 h0 Q
                GetPartType(displayPart);
1 I( C% b9 G+ N  s3 _9 @, X% u! e
; V$ @% t: T2 w% A  K
2 E6 u# J) f4 @8 p# @: ]
                displayPart.Close(BasePart.CloseWholeTree.True, BasePart.CloseModified.CloseModified, null);/ x' v3 ?- L" {6 q* s7 w- M
            }
9 X* z* k6 t9 f2 u            caTCh (NXException ex)! X" g# e6 `4 a3 i+ L. q
            {3 |% B3 Q- a0 ~% L! S; `" W
                Echo("   " + ex.Message);1 P3 O6 f+ F8 J7 H* o  O
            }( N" j2 w8 C* G3 \
        }
4 v8 }! O  R# d) g    }
9 _; a( o3 w. {2 C7 |+ E2 ~, N
# S6 v" \8 ~$ ~+ i# Y+ [. G

2 S" ]0 S! F  Q( n    void GetPartType(Part thePart)6 |8 K( ?- h" x5 h! v1 d, C$ L8 b
    {
' b% U7 _9 F. R        int nPartType = 0;: T- ]6 ^* d, F1 D4 j6 o" x9 r" D
% \0 {6 ]7 p: I0 z( S+ d
+ N& h1 M/ }# B5 s
        if (thePart.Bodies.ToArray().Length > 0) nPartType += 1;. U  k" }- E: U! t
        if (thePart.DrawingSheets.ToArray().Length > 0) nPartType += 2;& r7 R" ?6 m! z4 C
        if (thePart.ComponentAssembly.RootComponent != null) nPartType += 4;
) d! ]1 l8 r2 A7 c3 B8 _7 p# X) [# i, D! w: u& N

$ X) h6 r& ?" P7 _        Echo( String.Format("Part Type = {0}", (PartTypes)nPartType) );
  ^2 K. o- I& @5 o3 T    }* v, C. Z, @3 m2 U* X

7 C- D* I9 h8 S6 Y
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了