|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
/ x: B! \5 G4 F7 |! G9 m' [
! E( T( b$ j) o6 z' Y& a: a/ U3 R2 t Z- ?
UG NX二次开发源码分享: NX Open C++ 创建投影曲线 project curves% J V5 B$ [6 l, N3 j
/ h+ u8 `) s0 w N此处使用的是 通过面的法向创建投影曲线,可以参考下!
; o$ l1 [7 _4 l6 U/ A5 B# {0 ]
! p0 n5 H3 D1 P
7 I$ c9 r, D4 j: c7 S! v" M6 s/ a& W
3 y: r" Q& r o2 f4 e" ~( B0 j5 A
) m) d% v4 ^' e3 \' B5 |# v+ E5 U7 K+ A
k( B! F& g" c4 B. b$ S* P
( [: F; ], Q; M$ p; U; r
NX Open C++ 创建投影曲线 project curves
" v! T8 ]) ?1 [" R- C1 j* n! F5 c: O( }! h9 t
+ W% p7 B* }2 n8 q% Z- ' v a% ~& u8 j* l! F) `; h
- int trimSteels::project_curves(vector<TaggedObject *>inputObjects,Plane *plane1)
/ r- @& O# |& H( Y1 g - {
4 l2 i% U) |$ n. I# H, h9 Y - int errorCode = 0;
* s( z- w* @9 K3 m$ ? h& U% q - try
" V) [$ |! W9 V ?( U( h6 L, C/ V1 k - {; m8 m) h* {# \. P& B Y
- // createProject curves
) s2 [, ^& y8 G% j: Q - 5 T( @5 ]* ]/ ?7 U8 o
- Features::Feature *nullFeatures_Feature(NULL);
7 y: W6 [0 Z5 |3 Z- `! v. U% E - 8 m" R0 m! ^0 k
- Features::ProjecTCurveBuilder *projectCurveBuilder1;
7 X! `( u1 h7 c3 e! x
?; _2 t) ^% Y0 f0 l: n+ Z- projectCurveBuilder1 = workPart->Features()->CreateProjectCurveBuilder(nullFeatures_Feature);
/ H6 m: Y) \* \; G( Z
4 I2 ]/ c& B! K7 R! K- q8 Z- projectCurveBuilder1->SectionToProject()->SetDistanceTolerance(DISTANCETOLERANCE);/ K, T& N" ]( d; ]8 e- o
- ( z6 p% s( S2 b8 A% L* N
- projectCurveBuilder1->SectionToProject()->SetChainingTolerance(CHAININGTOLERANCE);* }( Y4 w+ H, n4 W& _
- 0 j: N9 {4 k8 f
- projectCurveBuilder1->SectionToProject()->SetAngleTolerance(ANGLETOLERANCE);! d3 r p* M' @4 ^5 @, l& w& }
- % c' C! |$ _+ J" I
- projectCurveBuilder1->SectionToProject()->SetAllowedEntityTypes(Section::AllowTypesOnlyCurves);
4 A1 e3 {& `: \
9 w6 J0 v& j" f( q$ U, C1 ^- projectCurveBuilder1->CurveFitData()->SetTolerance(DISTANCETOLERANCE);
$ ~$ H% F" N; @3 ~2 ~' _ - ( u* R6 t' P- k$ \8 }. t. H2 b
- projectCurveBuilder1->CurveFitData()->SetAngleTolerance(ANGLETOLERANCE);
b D1 F: w7 u% u% X n; U - / X9 J' v# W1 Q' @& l- O: q
- int size = (int)inputObjects.size();0 H5 x$ n1 b( ?6 ^6 }0 d
- std::vector<IBaseCurve *> curves1;
. v+ ?. u" L* o7 I5 p5 s - for (int ii = 0 ; ii < size; ++ii)
* x0 `- g$ V1 u# m; U9 O - {
: Y! Q: N. o# }. u. s& j: W9 M# D - curves1.push_back(dynamic_cast<IBaseCurve*>(inputObjects[ii]));; a8 x0 P' U: d% P0 P
- }
# _# ~5 E: W. | - $ k, @3 s: ^2 C/ v
- NXOpen::CurveDumbRule *curveDumbRule1;* b* K) I4 ~' l5 v/ S8 p
; O h& C% m- {# E. ^- curveDumbRule1 = workPart->ScRuleFactory()->CreateRuleBaseCurveDumb(curves1);$ x- @7 W4 H7 S; b0 n5 r; k
- 3 L# e$ x1 e/ n4 _5 V
- projectCurveBuilder1->SectionToProject()->AllowSelfIntersection(true);
& |: a5 E6 h. X% C4 u
/ Y7 G& b; A' _ T5 I9 Z- std::vector<SelectionIntentRule *> rules1(1);
, {! S! r% u1 I; ~+ S - rules1[0] = curveDumbRule1;
2 Z2 r- z, d: z - NXObject *nullNXObject(NULL);
6 R. C: Z* X2 \) S* U - Point3d helpPoint1(0, 0, 0);
) |* f" @; v% F+ x: w - projectCurveBuilder1->SectionToProject()->AddToSection(rules1, nullNXObject, nullNXObject, nullNXObject, helpPoint1, Section::ModeCreate, false);/ D4 D" R5 Q( q* J/ o5 e
: E+ O7 l$ B$ L1 S$ |- plane1->Evaluate();
( O ^. e% b" o
3 j% z& m) ?# W4 k$ C- projectCurveBuilder1->SetPlaneToProjectTo(plane1);
7 e2 M3 {; }4 d. G: F& s - 9 Z7 w4 z1 o4 S9 k
- projectCurveBuilder1->SetGapOption(true);8 U5 _% P8 R7 u$ h; L1 |1 p
0 ~: K3 p O, c- projectCurveBuilder1->CurveFitData()->SetCurveJoinMethod(GeometricUtilities::CurveFitData::JoinGeneral);
0 T+ n* I7 O8 t; o1 _ - 2 ?. o0 M, x9 V* y8 x. ?. p* l
- NXObject *nXObject1;0 q0 Z- _: a3 h, B7 {, a$ i% V
- nXObject1 = projectCurveBuilder1->Commit();" c, ]" |. ~! x
- 7 o C& [& k" L& M; P
- projectCurveBuilder1->SectionToProject()->CleanMappingData();
6 O- s1 C1 Q) Z/ \: R
1 B/ X2 r" @. E) F* [- projectCurveBuilder1->Destroy();
; M* K3 z9 I1 J% d7 Z
0 M$ f0 e+ `5 z# [ b* l- }
( T: e& x( z/ |$ P3 f8 H* B - catch(exception& ex)- n6 `% Y: S( s
- {8 @9 {& _4 q6 r4 D8 Q
- //---- Enter your exception handling code here ------ I, P/ [! Z: n2 [3 N
- errorCode = 1;/ b" L$ I" ]: W, q3 |
- trimSteels::theUI->NXMessageBox()->Show("Block Styler", NXOpen::NXMessageBox::DialogTypeError, ex.what());
1 a! \ ?, E) C, \ - }9 |* D0 \7 q) G, K! g6 d
2 K; B$ P1 |, X- _' n0 x q- return errorCode;. b2 t6 R! Q/ c8 p
- }$ N2 W- X! w |7 I
复制代码 - |* y; O3 e5 s$ v- T. c
" ^ O4 @% p5 K2 y6 _0 M
3 t5 e$ T; |* E$ ` |
|