请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
) Y( i8 n7 J8 r. z
NX二次开发源码分享:判断选择的面是否相切
- U" _! \# l5 p; Z5 `0 U, n. _: O3 M4 N/ I$ H
) d l) ^ K; _' v x2 v7 P
0 [$ g4 E" I0 `3 [ y% B
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。 J( v O7 X" n3 X7 l2 ?
" E" D3 D: i: L% w/ x$ w! T5 p% z
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。 (1)先看看选择意图 Select Intention中的Selection Filter' O# T( @6 B* C) W) Z; H! o/ l
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
' u4 D+ {- F! v R( A 譬如: 当您选择曲线类型时候,NX会提供曲线相关选择 1 {' \2 w( T/ u5 }
当您选择边对象时候,NX会提供边的相关选择方式
7 i9 {+ N! _, c! j# f当您选择曲面时候,NX会提供曲面的相关选择方式 # t; m3 K3 K! B7 A" F
7 O5 ]" C8 o8 D; a
8 z: t7 m+ \* f: `! \% k6 u9 z, Z(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
! j7 u6 s. I4 H3 S (3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
1 w2 K" L% ]) _0 K D ?: i# `5 f (4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
0 J& H9 b% w g. ^
+ Q4 |+ q3 O! Q8 d' s" K最后把这段代码提供上来,仅供参考! PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
; I2 U J2 s' K$ @% Ubool isTangentFaces(Face *face1 , Face *face2) { UF_initialize(); bool isTangent = false; int count = 0; int edgeCount = 0 ; std::vector<Face *> boundaryFaces1(0); FaceTangentRule *faceTangentRule1; ScCollector *scCollector1; std::vector<SelectionIntentRule *> rules1(1); uf_list_p_t sharedEdges = NULL; faceTangentRule1=workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1); scCollector1 = workPart->ScCollectors()->CreateCollector(); rules1[0] = faceTangentRule1; scCollector1->ReplaceRules(rules1, false); std::vector<TaggedObject *> theFaces = scCollector1->GetObjects(); delete faceTangentRule1; if (theFaces.empty()) { isTangent = false; } else { for (int i =0 ; i < theFaces.size();i++) { if (face2 == theFaces.at(i)) //checked face in the tangent faces list { UF_MODL_ask_shared_edges(face1->Tag(),face2->Tag(),&sharedEdges); if (sharedEdges != NULL) //confirm has shared edges { UF_MODL_delete_list(&sharedEdges); //free the memory isTangent = true; break; } } }
; p# i) r; m* z. i* o) C6 m } UF_terminate(); return isTangent; }
( n/ k+ x$ l- j& _4 k' m
2 R7 c* b* L+ z. T9 w) X
, m# T% B( w X% ~0 i' ?4 D% @
5 l4 M. l1 h8 e+ FEND PLM之家plmhome # A N2 |7 d/ F! ~ ?
▲长按二维码“识别”关注 7 G& e) t3 ], b9 ?, Z, G
- S, ^7 L3 l# b[mw_shl_code=cpp,true]
: f: \( M+ O3 J" U6 | q& O7 Q8 n7 ?/ K* ?# q* m5 [
$ k! A7 R& w8 X- y. Y$ `# P ^5 lbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
+ d# V, T* p6 a% y# }{
2 G6 ^9 B# w6 t' j& Z
* Y' J2 [; O7 k* [* W: b* B- l& ]# g bool isTangent = false;
, |9 p+ {. ~$ X; A' S0 ? int count = 0;) T$ A+ l( R) h8 l# G! R3 ~
std::vector<Face *> boundaryFaces1(0);
9 `) t% Z# Q# C FaceTangentRule *faceTangentRule1;* ]4 y2 v: W9 v9 v0 |% f
faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);4 _2 {' X( N" L+ R9 D. s
ScCollector *scCollector1;
3 q c! i3 w; p" G) m! C scCollector1 = workPart->ScCollectors()->CreateCollector();! W% ]0 }: L! C) K% k# @2 U {
std::vector<SelectionIntentRule *> rules1(1); r& |2 u0 |3 W8 Q% \- A4 t- P
rules1[0] = faceTangentRule1;
9 ~) `- } i+ c2 w. J' L scCollector1->ReplaceRules(rules1, false); Z9 s+ [% x+ w/ J7 w, c
std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();0 G; z/ i9 C4 T
delete faceTangentRule1;5 {, K8 I0 `( g& Z
) G5 v/ R" E- p- ~0 R, G, R if (theFaces.empty())% i7 U+ F3 [5 l- ^( `$ X( o2 o
{
3 Y0 c) Q4 v) S6 Y/ q/ D0 t isTangent = false;
8 B+ _2 i" H7 ^) p% m! w: F }
5 s4 n6 E1 {) `- P# T else/ |! s2 e' r3 y9 {& `) S
{' t; h5 @4 n8 d
for (int i =0 ; i < theFaces.size();i++)$ z& [/ D6 d" }7 |* d
{
6 Q; t1 {. d- ~2 r if (face2 == theFaces.at(i))
3 v- A Z" ~0 y, i' A. Y {0 V9 q% g: O" b: {8 }
isTangent = true;
. h- ]# p a8 x+ l4 y8 x/ e break;* e- n3 j% L) g( L) ^5 d% O& w, X
}; X/ l5 z$ |2 R- J, q* W8 v* A
}
. K# u/ ~8 N. R/ G) X, g: r/ {4 m1 V# `) U: N. a8 j" T
}( I5 h1 g. Q4 F2 A' F) w9 p% y! b# B
6 o/ M( U2 P; u: h4 b' L( j( e2 O
return isTangent;
8 `! ?% U- R y+ j5 j* c- N
! [8 A; [' m! H( X8 s/ [" B}[/mw_shl_code]
! Z6 n' ]/ d" e& ]7 z: w. x- |- V! I! B. y. [
|