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

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

[复制链接]

2019-7-5 21:20:37 1690 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,两个方法场景不同,这就需要进行分别判断。1 w+ ]* T  l1 }) D8 S
* A, C: V! p/ w3 {6 _8 E
紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。4 s+ ^; q0 v1 b& m1 K

7 V0 t, h9 i$ t0 b9 w- ]                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
1 K# ?& m% m+ j0 L/ ?0 t5 ^                        {# t! ?/ ?$ y! x. H
                                // we need add more check for the edge selection1 F$ A" Q5 p$ u8 Z- \# ^
                                for (int i = 0; i < selectCurveGroup.size();i++); v' O9 v3 E5 k! Z: w
                                {7 ]' ^2 I* Y; a, z
                                        //////////////////////////////////////////////////////////////
9 x6 X* z* a6 K- Q: c; P                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));$ e! V" J% o$ ?: f0 L) b6 B
                                        if (selectEdge->IsOccurrence() == false)9 P" a! }6 v" l, z% G: P0 N7 p5 j+ b) }
                                        {2 v! p1 t! j0 h( X" d0 {% ~4 [& v
                                                selectedEdges.push_back(selectEdge);
# d! E2 L3 N4 j                                        }! _- Y* r: l  \& c& _/ t
                                        else" N8 L, k, \5 x" F7 O
                                        {$ j- ?! B, c4 q6 k6 h
                                                if (selectEdge->Prototype()->OwningPart() == workPart)
! O) k+ r4 e" T7 J2 h: O                                                {2 D4 ^9 R! [, S& T& j' n1 t
                                                        selectedEdges.push_back(selectEdge);7 N, x" T7 {  f  O  `# J: ~3 A
                                                }
# C: V; ]3 S' S                                                else
& i/ U. V5 `* r% B) i4 n                                                {; D% N& u# [5 A3 l
                                                        selectedEdgesOcc.push_back(selectEdge);
; u4 n9 K% u% [1 M" o$ p                                                }  ~6 u, ~, O1 J% p: }+ m
                                        }
9 Q5 g8 h; ~$ u! v$ _! Y                                }# v. k4 ?, F1 d  N% @+ n1 S
" B- a1 k* @/ B
                                ) x# B( A! e) l  u. l- ~
                                //2 get composite curves , _( n8 E' o( X( r, y/ |& e; s4 M
                                if(!selectedEdgesOcc.empty())6 ~6 y. n  H) S( c# s& J
                                {
& i1 C# E2 p% {5 P7 O. e8 |                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);9 V/ L8 C( @9 n$ ?
                                        if (errorCode || compositeWaveCurves == NULL)
" i" @( H3 b/ k                                        {2 J& @5 F2 m& ?8 Q: ?
                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");
- w" ~  Q/ D& f- x) Z& j% d3 T  Y                                                return 1;) _4 ~2 w0 ^% l* e( L. R
                                        }( Z' X  c" w; |5 v
                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();6 ~, h; X# H4 i: z1 B

8 X- B  ]% }9 u: h* }                                        for (int i = 0; i < allCurves.size();i++)
8 _) P) j( P7 N+ m- p7 G9 F2 f                                        {
8 ?- Q5 U9 o6 b                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
9 Q* t9 w! Q3 E* g                                        }
! W4 |1 j( T6 p: W( ]# n                                }
( [' z5 h' j9 i) }$ K* {                                if (!selectedEdges.empty())
8 d! s  X" P, m' y1 `                                {' ^, Y. p$ _+ w2 x6 e  W- T
                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);/ b7 J) q! ~! ?2 i, q" O6 N
                                        if (errorCode || compositeCurves == NULL)
" U6 F" D* [0 p0 K) f/ ]                                        {
4 J( Z+ j7 M* G* F                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");
0 ~# R' P7 d: j5 J. ^$ Q4 q8 }                                                return 1;
  v% a7 I0 {0 t+ ]- d& h% N/ k                                        }
; X! x/ g0 B7 H$ P) t                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();
# x7 o: c3 x) i7 H* c9 R                                        for (int i = 0; i < allCurves.size();i++)
, r+ K/ n0 ]2 N! u/ V# \5 N: T                                        {
) U4 K9 s1 }( \; p                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
& l: e5 D, m# c/ Z/ F& p- F                                        }                                        & r2 \( C' w  `% ]
                                }6 T5 `/ n" W9 y
- W; g1 {" O" a- K: s% V3 o
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了