PLM之家PLMHome-工业软件践行者

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

[复制链接]

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

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

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

x
代码分享下,其实场景是这样的,我们要需要抽取一个边的线条,通过composite curve去处理,但是在非装配下,基本上是通过composite curve进行抽取,在装配下,需要通过 wave link composite curve,两个方法场景不同,这就需要进行分别判断。
. ^6 ~) |' N7 X: w0 s* i7 Z: t, R. s( F
紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。
- {: I: z% r* D2 X" J2 p# s" Z& ?" H0 [7 ?& E. p6 }, @
                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
4 }7 x3 p& G" F9 D* ]% N1 \% l                        {; W* t9 ^% X$ m: Y
                                // we need add more check for the edge selection6 {, G3 j& Z, f$ H( l" \
                                for (int i = 0; i < selectCurveGroup.size();i++)
7 g/ @/ }3 u8 y                                {
- H4 x; U  h0 m) n$ M                                        //////////////////////////////////////////////////////////////
/ n, D. B8 K% M+ E8 ]! s' G' w                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));# a" P5 ^4 O; V# ?& F6 z/ S
                                        if (selectEdge->IsOccurrence() == false)' s0 j$ j, h/ e7 d1 @6 D7 S5 i
                                        {8 x; b9 E( g/ C1 B1 \
                                                selectedEdges.push_back(selectEdge);) {/ M5 I2 i& l% d. v
                                        }
8 G) m- Y' t% G1 B1 E* i8 t! ^) `6 U                                        else. d( y! t0 y8 }, R# {
                                        {
& e! G3 ?: ^9 P% H( t" q                                                if (selectEdge->Prototype()->OwningPart() == workPart); f5 B8 Q: H0 V5 J2 ~/ i' R) R! E
                                                {2 q9 ?- G6 J) [7 f! U3 _9 G
                                                        selectedEdges.push_back(selectEdge);
7 ?9 i& X' e  \, v                                                }
$ m- k* N+ @- l                                                else
8 j/ F3 |) n9 q+ X. I                                                {
5 z# F; D; e, k  @- [7 X                                                        selectedEdgesOcc.push_back(selectEdge);1 Z, {& ]! B+ }. X. `
                                                }& ~/ N; [2 B0 E5 ?5 a3 C
                                        }5 }; @' L# s' E) k6 i& ]' q
                                }+ k7 z* S0 e9 B+ N; e& G$ z4 F

; {# a7 Z8 |" ?8 k  ?( [& x                                4 X0 E+ V: N( b& P
                                //2 get composite curves . v; p: a" h  C7 l
                                if(!selectedEdgesOcc.empty())& r8 Q" Z$ X$ `% d- ^+ K
                                {
8 ]4 Z/ ^5 u# ]4 r3 |. q- q1 x  P                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);
' s: o+ a# I- S: Z: l+ i$ ]( p                                        if (errorCode || compositeWaveCurves == NULL)2 n9 C( k- U, w0 q
                                        {
8 B# ^/ H) ~( t& s' ]4 h6 Q& R& g% L                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");% ~( L, u4 z1 a2 I# [: k
                                                return 1;1 K8 H- U8 U  `% |
                                        }9 J1 P) \& K' ^4 s4 O0 i1 Q5 `4 H
                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();# s3 s( }, l. m  C0 W% R
3 t& S1 T- Z* _3 a, K( @+ F( o
                                        for (int i = 0; i < allCurves.size();i++)' D; ~+ i; Q5 Z* v* D; W
                                        {
7 t4 d! V+ v  J3 O                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
5 K- C* }! U1 q& H                                        }
3 U3 s/ o6 }$ a: Q0 T                                }/ P3 V  s9 j  x. w9 e8 d
                                if (!selectedEdges.empty())+ O, M. Z6 K/ S6 y' x! Z
                                {
: n+ `& k- c' P$ Y/ c                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);
6 a% @3 `# @% a8 n. b8 m, I                                        if (errorCode || compositeCurves == NULL)# L" M+ N* y) F9 k  q9 _
                                        {
0 g' M! P" n( o3 E2 _# `: N                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");/ q: d* ~2 _% p+ |$ @0 m( A
                                                return 1;, X2 X; ]1 a  V' H1 f; J3 B8 b
                                        }
# y/ ~# f& _4 `$ ^                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();! M" V4 e4 K; M% Q6 O' x
                                        for (int i = 0; i < allCurves.size();i++)
* [8 ?) c. o' Z6 z                                        {1 g2 G* K" T5 L. W. m
                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
) {0 H* R4 k. K9 K- `                                        }                                       
( f8 \' M* w- h# c$ F                                }
0 D) j2 V, \+ k: N2 z- \9 E  _; |& J4 @" I
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了