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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
% N/ z8 b. \3 |8 H4 }3 H& M6 V& i
NX二次开发源码分享:判断选择的面是否相切
$ f: [5 q6 T8 S) r: G! n/ q, @+ B5 Z# [- h. l& Q) L. [: I5 D4 a6 Z

' C) v0 y( q9 P3 `. y  K
: b. v* M# C) q
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
3 t2 C* H- a( D5 ~# L! ^9 S* x7 ]

- M2 v! K$ k; A3 T; c
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
  W1 J2 |! U7 o( j* J0 x
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
$ D$ F- ~3 \6 Z* ^9 W" [/ N
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    - Y! Z# @6 O7 f/ z

: I" p0 h9 u, Z% e+ I3 ?6 j% A* q0 i                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    $ I9 Z# s  G7 H# t
    . @* y8 y, }9 Q: @1 h& c4 ^
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    ( i( u: T- y& m& u" @, R8 V2 k" S

    / r8 ?- N4 k  d                               
    登录/注册后可看大图

    . W% Z' c9 W! o! @: b. L2 O

+ Y/ L, J2 L! g
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
6 d* V; ], Z8 R, X. j3 J

( {! K  C* s, b3 v                               
登录/注册后可看大图

) Y# X" q' o% d' r6 }                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
, j# `  p: v3 A5 U2 a8 D' X
4 B) ]. b1 \6 b* z+ V
                               
登录/注册后可看大图

4 }; J) l+ v. E8 k5 ^' c8 k                               
登录/注册后可看大图

3 p5 s/ T) ^  f2 P% p. t. y2 n                               
登录/注册后可看大图

# i0 }# @: U2 M4 L: i* D                               
登录/注册后可看大图
& Q4 n. Y5 A- [
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
" f, E. ?$ m$ X  t; s4 @
" c7 n' V: p9 q* f; N9 p+ i9 ~/ X3 [
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

! N# ^8 T  B# K- i% f: C+ ^
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;
                                }
                        }
                }
1 I. W- @: P$ v! X7 P
        }
        UF_terminate();       
        return isTangent;
}

& e6 D3 Z) y) H* y9 h2 E. @& k/ ~" Q9 j1 D

. p# B$ o" P, y/ s& }! `
: U9 O& T6 |& Q- Y' M# e

: B2 o! f) s( Z                               
登录/注册后可看大图

; V2 k" d; w) ^! ]- _4 y! S# Z
% i% V5 S2 r: }: Z) \+ U! n
                               
登录/注册后可看大图
END
PLM之家plmhome
# C6 T; D2 ?0 G  u: o
                               
登录/注册后可看大图

" R1 l) S$ k$ d. c% K4 v▲长按二维码“识别”关注

* H. n0 j! p( z2 l3 h5 m0 d
+ z9 f6 v  m1 f2 F- h& q/ e. V[mw_shl_code=cpp,true]4 G" v+ @! l- ?* C- D- ?  z
' O: s4 y- X( r5 s3 L' h' L/ S
( D. A( O! g: c
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)5 A' V$ k! [0 b, H
{
) U& D( n# K& Y; _& w4 H6 {$ s* \0 e% v8 t, x8 z1 x/ ]& H
        bool isTangent = false;
# N; B$ \, |4 T/ z" ^( t9 o# y        int count = 0;2 ?* y; v0 m6 o! H/ R: ]! J! t
        std::vector<Face *> boundaryFaces1(0);
( X. R' x5 b0 {9 ^        FaceTangentRule *faceTangentRule1;
9 V* j8 ^$ ~: |5 N6 r        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
- w3 r" z- S' ?5 j* F        ScCollector *scCollector1;7 Q( y/ b; T+ n! R# ^
        scCollector1 = workPart->ScCollectors()->CreateCollector();- z) @" O* m& r8 ?0 `, u  F8 a
        std::vector<SelectionIntentRule *> rules1(1);9 D2 v  @& F% |
        rules1[0] = faceTangentRule1;
  c4 Q7 c# L9 V        scCollector1->ReplaceRules(rules1, false);
0 s! w! }# K  Q$ m, I5 f        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();" X* e- P2 z' u, w( l$ p- {* l9 H7 K
        delete faceTangentRule1;
2 a6 }9 Z, h, }$ n" A$ H        
: L- i8 |/ d% u/ u5 U& @9 n, q2 s        if (theFaces.empty())
& k8 Y6 O& T/ {( K' E% N        {
5 X( _1 K! O: U+ A+ x                isTangent = false;
0 z9 O7 n! }9 D8 S+ c        }- W8 X% i4 O& P/ J4 p
        else
. D- _$ k7 s: c) f& H1 A        {
7 j4 f; E0 |7 A- ^                for (int i  =0 ; i < theFaces.size();i++)
: F8 d3 P# T( T; x5 g                {& d, p, _+ s: A' V
                        if (face2 == theFaces.at(i))
, C9 _! U8 ~4 T. p                        {! \2 j# L: Q/ C  [8 M
                                isTangent = true;
6 I- f' }/ ?( Z" ~( H; I; L+ @                                break;! E+ l7 X7 D% }
                        }
& d+ U( l( ?# O, s5 y                }$ r# |" E" K1 K1 e1 }' N
# @6 j% q' ~/ C+ ]+ U! V  q! G/ }1 E: z
        }1 g2 p3 z, Y  Z/ u  \& S8 i
        $ N: ^5 q7 q/ H. U( g
        return isTangent;
! x' F5 G. W  g! }; D7 P) x3 g( [, z% c1 f9 v
}[/mw_shl_code]
5 ?! ]! H" z6 w% a1 _' O* I
7 f' ~/ n% U+ G7 Z. u3 s
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了