PLM之家PLMHome-国产软件践行者

[资料] 装配和单个零件混合模式下Composite Curve曲线抽取实现方式

[复制链接]

2019-7-5 21:20:37 1808 0

admin 发表于 2019-7-5 21:20:37 |阅读模式

admin 楼主

2019-7-5 21:20:37

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

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

x
代码分享下,其实场景是这样的,我们要需要抽取一个边的线条,通过composite curve去处理,但是在非装配下,基本上是通过composite curve进行抽取,在装配下,需要通过 wave link composite curve,两个方法场景不同,这就需要进行分别判断。
8 Y; W2 [, U* `9 v& G( c; b' s7 S" w' W  ?
紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。1 ^9 H8 S# |* }, U0 ~4 T; F% `
( O( I7 E; c4 l& E$ B2 p
                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
4 {  f7 o# L8 ?) {3 U  ~$ A! }1 T                        {1 z2 i) i& c! I! s. F( z5 M: T
                                // we need add more check for the edge selection* s- I8 _! b2 i
                                for (int i = 0; i < selectCurveGroup.size();i++)
( R, g! \" z2 {                                {: V- t# A1 t+ r2 ?5 V4 c
                                        //////////////////////////////////////////////////////////////0 C1 y% n4 `2 A2 i5 g# \) X
                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));
! O( p0 Y" r* n                                        if (selectEdge->IsOccurrence() == false): Y" Y. |8 ^" T( m
                                        {
8 p0 u" z; L6 \9 p7 Y7 ^; {                                                selectedEdges.push_back(selectEdge);
6 \5 M: C$ X+ q$ v# M. D1 c8 ~                                        }
* d6 X0 e5 Y% e6 Q3 W7 D: k. w                                        else
, _# E% ^/ g2 u3 r; U1 W                                        {
9 X1 M  c' O. G: R$ ?3 `- o                                                if (selectEdge->Prototype()->OwningPart() == workPart)- X. b! R5 d4 ]/ ?
                                                {6 u, a9 J3 M9 C' |4 s6 b
                                                        selectedEdges.push_back(selectEdge);
1 ]! H) A9 O" a" L                                                }
3 T# ]( C1 Z1 |# H) j                                                else
% W# a$ E$ H+ \5 |                                                {0 A& Y) ~0 M; i) ^9 e% U
                                                        selectedEdgesOcc.push_back(selectEdge);! b: `, n/ Y0 g
                                                }
5 Y- R; j& V% ?+ u. M- I# V6 a, R                                        }
: o( C( y, D' ~8 c                                }
; C: U& E6 `3 p, b: [1 P% _, R9 n! W2 \
                                
+ g+ d! N/ ]+ [                                //2 get composite curves
' p# \' ^. J  q" b/ Q; _                                if(!selectedEdgesOcc.empty())
; d* b9 c+ V: j+ b' r, X                                {2 d9 O$ N2 W6 d. M
                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);
* |: n+ ]. ]* i                                        if (errorCode || compositeWaveCurves == NULL)
9 ]* \/ Z2 F6 P0 U; m5 a                                        {- {3 I5 X' {! {6 T5 m! Y" V
                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");3 Q& y/ O1 G' r. U) w
                                                return 1;( V' Z4 R2 V' E- T
                                        }5 a6 h' i9 \- \' {
                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();& X! `3 r% |" q5 g
5 [4 ]2 |# m0 Y+ U4 e1 }
                                        for (int i = 0; i < allCurves.size();i++)$ C7 S4 V9 D% V, p2 r  b0 i
                                        {* D: s  i0 Z; S- K- X+ _
                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
! U- N( D' _% Q0 t* J                                        }9 ~: d, p7 U! S& ?
                                }
( P: k( q! L* e4 L# ^9 K* U$ q                                if (!selectedEdges.empty())
( A7 o/ d# x! I7 C7 N3 m                                {0 ?: Q+ U9 ^  P% i# b
                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);
+ x; Q' n/ H2 @# M6 ~                                        if (errorCode || compositeCurves == NULL)+ K$ T+ N- j5 Z- i$ r
                                        {( L2 N: {3 x% ~" I( H+ h/ ~
                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");
2 M7 h# w* Q2 H7 U                                                return 1;
4 N7 w! ~8 |' A9 b                                        }) x: M5 K. b! V1 d
                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();
( N8 p8 j5 p+ C. h, e' G+ U                                        for (int i = 0; i < allCurves.size();i++)1 G% M+ R; s) G; w
                                        {
3 D9 Z. Y0 G, U2 ]# A0 I; I                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
- n% F- m$ f+ e+ ^4 u! c5 i                                        }                                        - ^4 C0 y* n" D
                                }
5 t+ a# V5 ]5 A* S8 M3 ^  y0 o' X. O! p
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了