PLM之家PLMHome-工业软件与AI结合践行者

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

[复制链接]

2019-7-5 21:20:37 1893 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,两个方法场景不同,这就需要进行分别判断。
- [5 {7 S; m' _- y0 g7 [
9 ]! n) m% H* Y4 Y: e# F3 }* E紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。  r: k$ S+ X6 P9 ~9 B4 h8 A
- t- _  O0 C, V) e, B8 h3 F
                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
2 E: m' H  R, x5 t                        {
+ A3 K7 ]) R4 U+ X5 w% A                                // we need add more check for the edge selection: U7 E& M! j, @5 j& \! A! B$ Q
                                for (int i = 0; i < selectCurveGroup.size();i++)7 ?. g  u2 o- Z5 H1 D
                                {
8 O, s7 j+ z- `) P                                        //////////////////////////////////////////////////////////////
/ J+ l" ~9 {7 R  Y& x                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));% |2 y" n. C+ Z4 q- y2 n
                                        if (selectEdge->IsOccurrence() == false)5 f  N( w- q( X  J) D3 o' g9 x7 z
                                        {
6 g. ^; H5 N0 n: A  u                                                selectedEdges.push_back(selectEdge);
0 D. z3 u! Q3 E9 X                                        }
$ I" r: b& u$ U$ s                                        else
% J& `9 z  F) _8 G" b7 n5 q                                        {* O: _8 D, b/ x1 Y
                                                if (selectEdge->Prototype()->OwningPart() == workPart)- U0 ^5 [% h* S& k& U1 M
                                                {: x( |  l, g7 l  M
                                                        selectedEdges.push_back(selectEdge);
6 f# f0 M& v7 k$ [                                                }
1 E+ p( x! o% V: m, |                                                else4 r: _* i' p( g: ~  w7 A/ v
                                                {: C( K6 }2 M4 I6 V" i
                                                        selectedEdgesOcc.push_back(selectEdge);1 c  b- u! s, T* H9 F/ \
                                                }# z" H& j; r+ B% `/ W* K3 H
                                        }. ]" Q/ t8 b* A9 m
                                }, i8 d7 L5 l; X: T4 p0 i, v

1 X4 b2 D& G; c0 Z  k$ C- r6 a4 y5 n                                6 H0 q8 ^: M1 w! t( H& J* m
                                //2 get composite curves 1 {3 \6 @; u% H5 a7 U* T& N
                                if(!selectedEdgesOcc.empty())
9 M( {% q* e4 W, A                                {
% s3 K+ |+ q  Q9 `1 r9 z+ p                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);: a% r) ^" H4 w9 ~
                                        if (errorCode || compositeWaveCurves == NULL)
( G& N  b# w5 L5 ^4 ~5 R! W) o  O                                        {
- k6 w/ {4 @/ ?. V" {" C" k% a/ ~                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");. _8 w; W, w: E0 m  k3 Q; x: f
                                                return 1;! m; b5 }2 ?5 `  r
                                        }5 @3 d7 h! V1 W
                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();  t2 E. n. l9 @+ F2 U5 p

* p& C' N; E8 @4 y                                        for (int i = 0; i < allCurves.size();i++). [1 s6 o, k. {# |5 D; W
                                        {
" C; s( ^7 F: q                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
  T& N% _" f) z' |+ Z$ X& l  r                                        }9 T! D( S3 L% w
                                }
) Y' R+ K6 l8 t- ~                                if (!selectedEdges.empty())! P$ O7 e8 |+ q, |8 X# B3 U. f7 q
                                {
/ z$ B( i3 U! i                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);9 a* }3 }9 Q- J# [$ ~2 |0 V
                                        if (errorCode || compositeCurves == NULL)
& g. d8 Z6 Z+ p0 E                                        {
' m3 q! {+ n5 f; D( r  c                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");
; m# [7 g0 S4 C5 i; r' [# N                                                return 1;
5 l2 u' b* n, K2 ?                                        }9 I$ \. b( f) o& m9 y, X' D9 s5 U3 d
                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();$ z7 C" T) U0 S# e
                                        for (int i = 0; i < allCurves.size();i++)
  J4 e( E2 B& n7 ?9 D" m! @- e/ P8 j                                        {
& ~( r: R, P- |( L9 k: m                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
8 H+ Q9 @# s5 g- ?8 b# \                                        }                                        9 \  I8 R% e- q& ^! O" ^
                                }
2 g. P3 t* v! n. }2 V$ z
+ A& I8 i( K- S0 W1 c
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了