PLM之家精品课程培训

PLM之家精品课程培训

联系电话:18301858168   |   QQ咨询:939801026
NX二次开发培训

NX二次开发培训

UFUN/NXOpen C++和实战案例

适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术。
公众号二维码

关注公众号

点击扫描二维码免费在线高清教程

课程详情
Catia二次开发培训

Catia二次开发培训

市场需求大,掌握核心技术前景广阔

Catia二次开发的市场需求大,人才稀缺。掌握开发技能潜力巨大,随着经验积累将在汽车、航空等领域有所作为。
B站二维码

在线原创B站视频

点击关注工业软件传道士主页

课程详情
Teamcenter培训

Teamcenter培训

全方位培训,从基础应用到高级开发全覆盖

涵盖用户应用基础培训、管理员基础培训、管理员高级培训及二次开发培训等全方位内容,由多年经验讲师打造。
QQ群二维码

加入同行交流

点击扫描二维码加入QQ群

课程详情
×

PLM之家plmhome公众号

课程涵盖: PLM之家所有原创视频

×

关注B站视频

所有高清视频一览无余,全部在线播放学习

×

加入PLM之家QQ群

同行交流,疑问解答,更多互助

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

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

[复制链接]

2019-7-5 21:20:37 1670 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,两个方法场景不同,这就需要进行分别判断。
! n4 D1 n  i; A+ \! g
# ~" \9 C+ l4 Q) R, O  @7 ?紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。
8 J; p" T4 u% I& Y
7 n% M0 c! x, N; H3 I  Z4 p                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
9 t9 b' Q1 @3 U. |                        {, P# ~- ^. m' R- K
                                // we need add more check for the edge selection
5 Y' Y* u& @2 j9 y, m                                for (int i = 0; i < selectCurveGroup.size();i++)6 Q3 H4 U6 F% z/ v  S
                                {. }, y! K7 u, ~& E
                                        //////////////////////////////////////////////////////////////5 u/ n+ C2 m3 ?# C9 Y
                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));
" o3 G1 P: V% h4 s                                        if (selectEdge->IsOccurrence() == false)
( Z6 L4 ~/ j& M: a2 z" x                                        {; l) j% y( _( E0 H1 h$ I- H6 D2 n1 B
                                                selectedEdges.push_back(selectEdge);
: s1 W$ k; g/ T. O1 f                                        }
5 `* a' e& _- V' F2 \# T/ X; L                                        else1 e, `  M; J5 L! w5 W/ ~
                                        {: P. G+ J: W8 L
                                                if (selectEdge->Prototype()->OwningPart() == workPart)3 k+ q2 B3 c  [! w
                                                {1 K* V4 A# H# y) f
                                                        selectedEdges.push_back(selectEdge);
) l) ~5 O1 Z2 _! |                                                }# q% a0 e2 G3 g/ ~9 C# M  \
                                                else  }& ]! E; O1 d) Z: K
                                                {
, ]: p* M: q+ `; A                                                        selectedEdgesOcc.push_back(selectEdge);7 f( c7 d& z7 ~) T+ B; Z( o# U1 N
                                                }+ \" h8 T# B4 c/ Q
                                        }7 Z. B/ h# Z$ V8 G. c
                                }
' x( v, G4 E; m1 t
. @; }7 }# u% R! n  R6 t                                
0 `  c7 L# h# O4 \) `8 j$ ^                                //2 get composite curves
! N& n* E4 t' B3 N8 v, H# O( x  c                                if(!selectedEdgesOcc.empty())
' w0 T: ^3 S3 l! x' |$ |3 _                                {
6 U$ E8 _2 A; o  G3 c/ X6 R0 H                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);
$ \* g* N/ U+ ]- @& d& Z                                        if (errorCode || compositeWaveCurves == NULL)
" X( f3 ^# x# R$ W                                        {0 `# D+ h- p, K2 ^, A0 {/ s- L7 [( l' \
                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");
. G5 i$ S4 z8 D7 i/ P% G                                                return 1;
4 h4 V6 X7 t/ d+ u                                        }
. ?' S. R; y: ^. g' F                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();
6 h- m/ Q* C2 e; n/ m
5 ^0 B$ q6 y/ J2 b  E                                        for (int i = 0; i < allCurves.size();i++)+ \# `8 I& d: k- j+ b5 D  R
                                        {& A- H) A; u3 J  K6 u" |* ^
                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));# k- m- X, Z# B( l" W; o
                                        }7 _; l' o" d. P" @: Z
                                }
4 N0 L. u* T9 A6 h; U5 Q8 O                                if (!selectedEdges.empty())
& d) V0 {) ^) E+ q# x' L' @* T                                {
. @1 G0 G) E$ V& a* X/ |                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);
" c6 z2 i4 Z: f; M                                        if (errorCode || compositeCurves == NULL)- K, n( D% N% y9 a
                                        {
- U/ c9 ?: o% n$ C& @4 l                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");4 R0 y" ]  p1 L3 Q2 i+ g
                                                return 1;
* N3 W# f( U& n( s* e9 r6 X1 Q                                        }/ E) X7 g/ f- u8 g
                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();, N) |# N# ?2 |
                                        for (int i = 0; i < allCurves.size();i++)
' Y! |" ]: P/ B- e9 D" ]7 H                                        {2 I9 g/ J9 ^" i2 B; A
                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));% Y# u: Q, E$ F) `2 C( E1 z. G$ n2 ^
                                        }                                        ' E4 }$ S% }6 ~: {4 k
                                }
# ^9 l3 A1 t6 N
6 }: F! S& r4 X$ }2 L$ X
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了