PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

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

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

[复制链接]

2019-7-5 21:20:37 1618 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,两个方法场景不同,这就需要进行分别判断。
9 ^! @: y0 d2 ?8 M& o- g+ F8 K1 a6 \/ q; ]2 ~
紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。1 ~$ p0 _, g. ?
5 M$ m! y3 P. i5 Z0 k$ h6 n
                        if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
2 x7 n1 o! d* E+ C                        {
* |2 Y5 c- Q0 `) E* R& b                                // we need add more check for the edge selection
& k: {6 n0 v- w- `& U- t, b                                for (int i = 0; i < selectCurveGroup.size();i++)
3 b2 S7 S- Q7 k. P+ m3 T; @: ]                                {' b, a% Y3 E+ i0 d! C, ~
                                        //////////////////////////////////////////////////////////////2 w5 T: \, E) v& c: j1 K7 n+ b
                                        Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));
* {6 @# H+ B* J                                        if (selectEdge->IsOccurrence() == false)
6 k4 t; d- s! e+ C; e1 d$ j' |: k                                        {
* G- [! T# |4 b& w0 u, c0 r                                                selectedEdges.push_back(selectEdge);; \& M( o4 o$ @  R6 X2 L7 F
                                        }7 @. U2 _5 O' _2 m
                                        else2 Z; ^* J/ R) P; s8 q( g0 Y/ d
                                        {  m9 [/ v0 E* H, ~7 O
                                                if (selectEdge->Prototype()->OwningPart() == workPart)' H6 s1 A. m% q- X) J( W
                                                {
3 b# o" S8 r4 O: ]0 G                                                        selectedEdges.push_back(selectEdge);
( W9 {- f' o! |- Z3 z# H" ?5 b                                                }
, v8 m: {8 K4 d) y3 ^                                                else
7 G1 N+ b6 g& f" y; Q                                                {) |8 H7 q* U0 J' ?5 K/ ^, e% B
                                                        selectedEdgesOcc.push_back(selectEdge);
0 q# J# U; Y" K7 J                                                }, S, F# x4 X/ C
                                        }* Q) T/ U8 s* h! F/ q% c6 u9 m
                                }
, f% O- L4 X+ Q$ ?0 v: T4 x% g: [( `# [; m% U" ~2 ?
                                & G/ G0 |% a9 F& g+ \0 s* \
                                //2 get composite curves
( n- x; F7 K' ?' h                                if(!selectedEdgesOcc.empty())
9 K- I% e5 D: c# n0 g                                {2 j- O% N+ i! V- c' Z9 s" c8 M
                                        errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);
$ _, Z5 |; X9 h! ]! C                                        if (errorCode || compositeWaveCurves == NULL)
& k: `# b/ G1 n7 ?# b" i$ h                                        {
& j3 A" E! f& ^. |; a. j                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves  failed!");
2 k5 N2 b; V: h. c) I$ B- W                                                return 1;0 Q0 {! o, A8 e
                                        }
$ {2 f) T, B' n, Q  D, f6 \                                        vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();# t' j# y9 l1 X" z4 b

: x! c  ?! Z1 `; J  \8 |                                        for (int i = 0; i < allCurves.size();i++)) F5 T! a% y" ?! Y3 ~; u1 ?
                                        {
, y- F  F) ]3 y( W) M' s, `                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));: o; \9 ?2 J$ t% c
                                        }  e# j" e9 d0 c7 [, R
                                }
1 T! I$ t1 ^$ A) ?( K                                if (!selectedEdges.empty())4 g% l9 B. O8 o4 P  r
                                {1 K3 I) v) O" V' q+ C9 _; g5 T! N
                                        errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);
! Z: T- d- Z% ~6 l/ k9 z& k                                        if (errorCode || compositeCurves == NULL): t& B8 h7 R2 k9 @
                                        {
$ U- M6 w' @9 x! M# b                                                CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves  failed!");
% Z3 L5 {$ A( k3 E$ X                                                return 1;
! p  n, Y& E+ ~7 p                                        }: q3 M9 ]6 @9 e7 {4 s8 v  k
                                        vector<NXObject *> allCurves = compositeCurves->GetEntities();
+ x& O- m5 G" J                                        for (int i = 0; i < allCurves.size();i++)3 \" m  o) m4 @7 f  E5 z* g
                                        {0 ^& g. z0 j7 S# v  o8 h
                                                sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));
/ _/ O0 d# [$ x% I7 Z2 k4 f                                        }                                        # T$ a& Z9 k4 w# [  Z; [
                                }
& T! I! N5 B# h% c* _2 `& d5 @7 b- w" d* 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二次开发专题模块培训报名开始啦

    我知道了