|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
代码分享下,其实场景是这样的,我们要需要抽取一个边的线条,通过composite curve去处理,但是在非装配下,基本上是通过composite curve进行抽取,在装配下,需要通过 wave link composite curve,两个方法场景不同,这就需要进行分别判断。, h% q! ]+ x" c h2 I; [# E
" |3 `# D* g+ W, U% H% c3 j
紧紧判断是不是一个occurence还不够,因为在选择边如果零件是工作部件的话,这种情况wave link是无法使用。
4 g! I/ Q& {- }9 B/ E8 w, s z! l! {/ b2 b' n. M
if (!selectFaceGroup1.empty()&& !selectFaceGroup2.empty()&& !selecTCurveGroup.empty())
4 w( W+ u, p/ P* T$ i* g$ z {
3 d, }+ @5 O& |- [5 }# P* [ // we need add more check for the edge selection
$ T1 m6 P6 `( G" n4 e; ~4 z for (int i = 0; i < selectCurveGroup.size();i++)- C5 ~3 o. P, S, S* T
{% X1 A1 @- V2 C0 B4 V
//////////////////////////////////////////////////////////////+ n0 q2 j0 f+ h, ]) F
Edge * selectEdge = dynamic_cast<Edge*>(selectCurveGroup.at(i));
5 x4 O# V7 a" R2 ]' R l6 Z( @* X if (selectEdge->IsOccurrence() == false), J4 q$ `7 z, m, D1 |! l5 D
{
0 d' o1 k8 d/ f/ o. b selectedEdges.push_back(selectEdge);8 f* }& Q! T* ]% c; Y; [
} |9 i2 Y; C& z! J2 k9 v, I
else( F% T1 l4 M) r" b1 |+ f4 \8 U& Y
{" D& _' g% B! t+ R" b8 q# ?
if (selectEdge->Prototype()->OwningPart() == workPart); F0 p3 Q+ s4 q0 D p
{
( J- W c, O- c" y' f2 P4 }; G selectedEdges.push_back(selectEdge);
: m8 |% @8 x4 G% [$ E4 A& L }
: k: W+ T2 [6 S; A3 I- f; L# h else
3 r3 ], l a6 t) Y5 k {
6 A# r7 A& W/ T) q- K selectedEdgesOcc.push_back(selectEdge);3 p$ j' i- m/ g% e+ Z: |; i4 E
}2 @2 q: w- D- d. ^1 \; k" }
}
$ C0 u" E. K7 z6 r2 t }
- |0 `2 ~% J. o
7 C1 _* w" J9 D$ C: ]8 k
" W% r. \; U. v2 R6 k! G& { //2 get composite curves
, }8 |0 x8 n* d8 w8 z* G if(!selectedEdgesOcc.empty())" z7 M8 k. m! `# m9 r7 _" @
{
: a8 I( D* ?1 r$ t3 W! h errorCode =createWaveEdges(selectedEdgesOcc,compositeWaveCurves);6 k$ ^& u7 B* M
if (errorCode || compositeWaveCurves == NULL)& N2 q( |, ^7 ]/ D Y
{" h5 [5 G8 {% f# F
CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Wave Composite Curves failed!");
* E$ v. I& \$ d0 t/ ]* D return 1;9 ^* w# Y$ d! S) `, D3 D' Z1 D
}
/ N: K; j" u4 f& ?! [) Z2 x vector<NXObject *> allCurves = compositeWaveCurves->GetEntities();
% H! O" s6 b3 K# @- O0 K% B1 q0 T7 k7 f! v6 l e9 h
for (int i = 0; i < allCurves.size();i++)) k9 Z; Y7 l+ h! Y% X5 A
{
" a, @5 D0 @0 e$ J. |6 ] sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));; k$ E4 v$ b" e# x
}
' _2 m: I8 v$ T1 L7 U, }( I8 E }
4 { Y7 L& T' f6 O+ j, ~ if (!selectedEdges.empty())
) d6 h* o' v9 {" {" n: B {
! i7 `# _( `6 ] errorCode =createCurvesFromEdges(selectedEdges,compositeCurves);
8 v2 k2 g, F! `/ i, V, s" M% A if (errorCode || compositeCurves == NULL). k( _/ D; k) T- G, k
{
) T# B' X* G( T8 s. V: s A CheckDTS::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeWarning,"Create Composite Curves failed!");0 z- u0 C5 ^1 Q: ~" @
return 1;
* ~& p) J$ S+ D% Y6 E* m }) V7 K+ l& O8 ~1 r0 `' s
vector<NXObject *> allCurves = compositeCurves->GetEntities();
8 m6 l( e6 H1 l8 T/ ?4 U for (int i = 0; i < allCurves.size();i++)% G8 t) j! N6 q0 \; A! t
{
5 ~3 K8 r7 H0 O$ @ H7 v9 B sectionCurves.push_back(dynamic_cast<TaggedObject*>(allCurves.at(i)));: s* Y) L- @) L& _; A
}
. m% \. f+ u. E! E: l( O }
: T6 {+ V$ @& z
1 M( q# ?2 z0 v3 l |
|