PLM之家PLMHome-工业软件与AI结合践行者

[二次开发源码] NX二次开发源码分享:判断选择的面是否相切

[复制链接]

2019-12-24 19:06:37 2575 1

admin 发表于 2019-9-15 08:38:30 |阅读模式

admin 楼主

2019-9-15 08:38:30

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x

2 K: z. x: h4 xNX二次开发源码分享:判断选择的面是否相切
7 ^1 m- ~9 h4 Q1 d! _
+ q' ]6 ?  n. u- @" t; n
! p0 m' i( ^3 F, P$ o5 G" z+ l
4 G  f; g1 V& i
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。9 Y9 r7 X3 f3 a; P3 O+ d/ u. Q9 O

( N" n' x  g: r5 U% k# z
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter5 N( B% M4 S; Q7 T. C, }
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。4 f9 r" I9 v$ u3 q& ?# f0 J
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    & r0 B4 [3 V! ^/ e
% K4 N6 d6 w( \# n% U4 Q3 k! m
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    ! L7 J7 d# `) v4 ?' z8 c% L

    ; m" U6 D4 m* N1 U( n5 J; n6 C+ p                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    & j3 F8 e; z9 _

    7 ]0 v. {6 q1 `, M% ]' l4 j                               
    登录/注册后可看大图
    . s, I& D: s  h0 D6 v

" _9 p$ R: B' }* p* m/ v
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
. M4 J# F9 b. @( E5 K( B+ G; s

  `9 T8 o0 K) a5 c- m                               
登录/注册后可看大图
( n# S9 T) q5 v9 L( @6 o' B
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。7 `* o( t( R! b3 g/ `

7 C' `" E& [; L* h% G                               
登录/注册后可看大图

) F# M- G4 C0 n/ e4 y( B$ F# ?                               
登录/注册后可看大图
# N9 r- e/ ^! E) }* c( C3 V
                               
登录/注册后可看大图

' l7 G, m6 B7 g* S6 s- z) S                               
登录/注册后可看大图
1 ]; A' q; b  H( f+ p: p
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
, m6 j4 Y: S1 i1 P* k

. {1 a; k/ f3 p5 q' b2 R& T
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

" a# S' J1 b  N$ t4 |* p! }% D
bool 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;
                                }
                        }
                }
8 I: ^4 J1 R" y
        }
        UF_terminate();       
        return isTangent;
}
+ a" d: a+ M3 }$ O, P
" [5 w& `5 R' O9 M# r/ p7 X
% _& p2 j! y: M( X
' m: p: I4 ~0 n8 C. [6 G
, s2 e6 u" M6 F7 w! R0 z
                               
登录/注册后可看大图

4 x( x/ [( ]) o5 l& k$ r
9 [) u; i: E( p3 ]0 |- d9 l
                               
登录/注册后可看大图
END
PLM之家plmhome

% N6 T8 o- }: P" l5 Y0 n7 z                               
登录/注册后可看大图

2 i0 J  h* ]9 i  O: A1 `▲长按二维码“识别”关注

2 A- @) ]3 E' m3 T$ \0 J
1 T. }# V. j5 P" i, Y[mw_shl_code=cpp,true]: a) m  C  L+ a. o8 O* ~8 T

( @8 p% g1 P( h; R4 U+ A- w$ p# E; K8 P
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2); v6 i6 m# z3 [* @; W5 p: x
{! ?: a3 X+ Q  q7 q! ]% a: K

; H. G/ k4 K* a% B$ r- M. b        bool isTangent = false;2 k! r5 R" R: R5 L4 w$ Z* m
        int count = 0;& ^$ @+ y" s, f& S
        std::vector<Face *> boundaryFaces1(0);) f9 S+ p2 O, v/ b4 ]$ }8 {* R
        FaceTangentRule *faceTangentRule1;" k* M6 F: I. S3 D1 X. I' R
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
* _% j/ Y9 {* L" W" P* `        ScCollector *scCollector1;
% n( T" P$ |5 p% Q5 j        scCollector1 = workPart->ScCollectors()->CreateCollector();0 @+ c% A/ q$ ~# O1 A
        std::vector<SelectionIntentRule *> rules1(1);
2 D1 M: w" o2 s( p        rules1[0] = faceTangentRule1;
0 y& L' B" A  p1 o# B        scCollector1->ReplaceRules(rules1, false);5 T( H; Q+ E4 q
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
: T! o! m1 n: h8 S) T! w* e+ x# D! o        delete faceTangentRule1;: [/ b( B- D/ {6 _& A2 b3 [
        
* R2 z# w$ z- r; M        if (theFaces.empty())" q4 V$ t& a, Y' D* v/ W* L
        {
6 E! z9 o* _% L% r) w# `( h( B                isTangent = false;( o+ ~" R1 i/ m( e# ?6 Q0 R0 ], N
        }
( j# y# D3 b0 H6 i% Z0 e3 i        else
( g" N( X+ I+ \' f/ H* y        {* k4 q- j9 A/ o3 t/ O
                for (int i  =0 ; i < theFaces.size();i++); }# v; L+ J$ O; [
                {+ n5 j, M7 H; g
                        if (face2 == theFaces.at(i))& N. \/ e  a: {
                        {
, g0 x" H7 Z+ w5 }. M' l% ?; z                                isTangent = true;( P' U0 \2 v! H; u7 N; i
                                break;7 l1 }5 H+ T& q9 U4 a
                        }9 N" d# V' v! _& E6 w
                }. }, g& ~" H) ]- Y
- U; s9 S( W4 E$ i6 h
        }
; m: \/ Q/ p) L4 @        , `+ O" A! j. K
        return isTangent;) d5 w$ q- Y7 I  p# c; b

1 `& I& D6 _) @) n* n* W}[/mw_shl_code]
7 P1 n2 J1 G* r2 Z* S8 K- w- j, Z3 `3 I9 i
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

全部回复1

licxsw 发表于 2019-12-24 19:06:37

licxsw 沙发

2019-12-24 19:06:37

学习了  谢谢 分享
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了