PLM之家PLMHome-国产软件践行者

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

' R% _+ T  N) ?) d. p6 H) aNX二次开发源码分享:判断选择的面是否相切) e% t/ a- w4 O$ E) U- u

5 z# I6 \0 ^0 n: T. @# F+ Q/ l# Y( B# n+ L4 ]" X3 U, s% q3 E1 N

, D) T& }8 I* y  x
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。5 B6 C& L# W) X( N- _5 P

' z/ P% {$ @" ~2 d- s
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
: G! S. m7 m& A1 N
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
5 ~6 y7 T4 z" p' R% h
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    5 o0 U" U, p& g4 g
1 J: @5 o* z+ ?! R
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    0 G# Q+ _7 A$ l$ e% _8 Y, f" R$ Y

    7 Q& \' z! w. I, h' ]                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    / ?. o% K1 C6 E
    2 |1 h0 d: N8 I
                                   
    登录/注册后可看大图

      |  X3 h- G/ K  v( M
  g1 N- K% v& \4 F- G) W9 m; T# w' [8 m& [: E
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
9 G  ?4 |: y  p
3 L$ u: n5 w8 S" b& C( N5 a
                               
登录/注册后可看大图

3 N( S7 s( }9 m( ], g  [0 b                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。7 V& d. A+ l6 c

9 l1 v! {, S6 ~4 p: X+ }                               
登录/注册后可看大图

  X9 l. M0 a8 @( |1 ~                               
登录/注册后可看大图

( y' m# `9 f7 C$ U& l  {$ b0 E                               
登录/注册后可看大图

4 C& v+ P- g4 j  j                               
登录/注册后可看大图

7 ~1 N. S( v; m9 S' S                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。$ U! |  X" _5 ]8 C
- U) z0 s% K  U6 Z
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
* u) g. M2 ~2 S* d2 h
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;
                                }
                        }
                }
4 i4 S' v5 u6 `
        }
        UF_terminate();       
        return isTangent;
}
/ y2 J" Y3 ^" A1 ]! n
. }1 r  O; s5 W6 d$ [

+ e+ d3 Z6 m) `: h8 X9 O- I  S3 s+ a5 m- C  C8 T
. f6 t( m% ~1 q) g7 ~( g
                               
登录/注册后可看大图

3 ^* S+ @7 p( O  @( h" `
$ i; l3 c* [$ s7 I! a
                               
登录/注册后可看大图
END
PLM之家plmhome

$ B, l* K+ i, Q8 D# ^3 K" V4 N, r                               
登录/注册后可看大图
8 }6 [/ [$ m, l! I1 l
▲长按二维码“识别”关注

0 i/ j' v% k$ G. \6 y& y
. s  Z$ z9 d$ Y: ~) S2 f& w. g[mw_shl_code=cpp,true]* x+ {$ a4 N6 b, k  Z1 I
* a; U$ B% r0 `' s( L8 k! d3 G
7 v5 ~% @/ Y; z! ?5 x  C5 k, G4 I% ?
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
$ q3 \  ]7 R2 O- }; l{, e9 ?( @4 m5 y, ]8 y% u
6 I7 w9 m- h( N/ x( S
        bool isTangent = false;3 }) B( o  |' Z) }2 i5 l' K* _
        int count = 0;  [3 [! |; X9 W8 {( {, Y% B
        std::vector<Face *> boundaryFaces1(0);/ i; T' O) r$ W8 O! m/ a( a
        FaceTangentRule *faceTangentRule1;$ j5 K/ d) S3 [
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
4 u+ {. G9 h. f0 r" l9 C% }        ScCollector *scCollector1;1 l( r- o( w; T: |8 M
        scCollector1 = workPart->ScCollectors()->CreateCollector();
% ]$ `7 _& L7 h$ z: R6 l3 ?. x! F/ U        std::vector<SelectionIntentRule *> rules1(1);
8 u; ?$ D5 t: i% S2 c# K        rules1[0] = faceTangentRule1;
- B5 B5 s" g) `$ s- ~. K$ H        scCollector1->ReplaceRules(rules1, false);  R7 g6 ]; d2 I" j
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();+ M, v* Y" v* d
        delete faceTangentRule1;
. [( }  Z: m! c, j. W        0 m, u+ z$ |+ f1 u& _
        if (theFaces.empty())! B3 z! k- r* v
        {- U2 p9 f1 d) P; S$ c5 l. @
                isTangent = false;
, R" ?! v. X7 F0 t  s) N) i/ T        }
) [  t! K% y" x- D. Y        else2 {! x" |- S) {
        {6 O) q4 O- w  ?* m4 C0 Y# D- y
                for (int i  =0 ; i < theFaces.size();i++)* X2 J. x" S+ f9 D
                {/ r) H! V7 u. a* {
                        if (face2 == theFaces.at(i))0 B' m1 Q5 o, D/ A
                        {0 |% f8 R9 F7 q- a! s
                                isTangent = true;2 z; C8 c) x, j, o9 c
                                break;) Z8 x" }2 r$ p( A% q
                        }1 M" k3 Q7 y0 \/ \$ z
                }0 m* c0 E0 j2 X, q
; [  w4 v. o1 f5 M2 \
        }
* l( n& x6 K* [% x        
/ W& J/ d& [4 L& u0 K        return isTangent;
+ B7 }) u" B7 l3 G. H
- g8 `# p9 p( B4 A}[/mw_shl_code]9 S$ \5 S& I9 o1 X
* O1 t8 T8 @& e+ X! 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二次开发专题模块培训报名开始啦

    我知道了