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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
' h. N) y; E2 h7 [$ ^
NX二次开发源码分享:判断选择的面是否相切& T; l3 P9 _3 g8 v4 Z8 V4 E

6 \' Z! l# y9 s
& y6 @7 y* m. N
0 n5 X9 Z6 r. \1 f2 C, c
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。* G* W6 R; }* M9 U; Q- T

9 X4 p, p- R) G- W
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
; K, b/ E) J( N1 e' C' c
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
1 ]4 r0 o, S! S$ C0 v
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    4 h, _2 e2 o- B2 h: Q( y
0 r( Q! m) f. D, W
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    6 c& d+ O( D6 Z  o6 q7 B
    $ Q# u% N  C8 E7 _2 T4 T4 t( I
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    9 y0 K9 C4 y+ c3 }/ R+ _8 [  p
    / ~; x0 {) B! G1 x" y
                                   
    登录/注册后可看大图

    * A0 B% y& P4 _8 ~

. `& P  o: Y$ o5 F
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
: ^3 q& t1 i+ v( `
: M* @7 j% R# H6 V
                               
登录/注册后可看大图

8 `( i& e: ~7 Y) f' d; ~, }1 U                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
) e1 b; c* p' Z8 c& Q; X0 u

2 z- Z3 b* j: e5 y                               
登录/注册后可看大图

0 Y7 L5 c  p/ |! Y/ }3 z                               
登录/注册后可看大图

7 x2 @0 v. J) i                               
登录/注册后可看大图

, y* N- T& m. O8 d7 t) n5 e                               
登录/注册后可看大图

2 Y! D( g, O9 a( _                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
, |9 w* A6 t9 g5 z. R' z

* p5 f* V2 A/ v8 @: o1 _: i! a+ e, @5 w
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
$ a, E* V3 G2 d7 R: J4 T- H7 J  G
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;
                                }
                        }
                }

7 E  }0 g; m0 a' P2 j6 @4 G5 m0 g
        }
        UF_terminate();       
        return isTangent;
}

' {, q  A& Z5 d& N4 _6 U+ }
" [; e0 Y" A( i* K1 D. |
4 q# R% C" O3 ]$ P/ T
/ s, L, e* X( T, W7 N; `
# r) i3 }4 D( S- a" g7 b+ o( E
                               
登录/注册后可看大图
+ n7 H/ ~  J, d, m1 [: y9 a& F/ G0 f
, U5 h' e4 v6 v! E2 i1 F
                               
登录/注册后可看大图
END
PLM之家plmhome
# A1 O$ n/ s. t
                               
登录/注册后可看大图
4 v  ?7 y; L, y7 f) g0 x1 J
▲长按二维码“识别”关注
; q$ ~" g) D) {7 `1 f/ }" c1 i
8 w) p4 c6 }* v
[mw_shl_code=cpp,true]- {8 m6 u" @# q6 F7 R

' _. q7 I$ J/ _; K
' E0 Z8 H4 g# y4 U' u7 }+ s6 S: dbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
4 F3 l6 a6 o9 m  |{. \& o# w+ a  c# D- k  D8 o4 Y

5 m1 [) O( c$ x7 B        bool isTangent = false;* v. O$ e4 |( G; Q6 k9 u( q4 j
        int count = 0;  _6 Q* ]9 T2 y5 }8 T! X
        std::vector<Face *> boundaryFaces1(0);, X7 D: i1 _9 [' _/ V% K
        FaceTangentRule *faceTangentRule1;
& C4 [! r3 u1 ~) H4 X6 ~) `+ e        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);' L) C4 |  j5 g; b5 J
        ScCollector *scCollector1;
( c: u1 w7 L- S. v* Z        scCollector1 = workPart->ScCollectors()->CreateCollector();% n- D9 g3 F, M, P
        std::vector<SelectionIntentRule *> rules1(1);
& ^. |4 {; t/ m- V  A  S        rules1[0] = faceTangentRule1;" \0 {  F1 T& @/ ^3 F- A9 ?
        scCollector1->ReplaceRules(rules1, false);
# l4 p( [9 {  R, a        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
9 A; V: W/ h+ k0 }4 }, X7 b        delete faceTangentRule1;  |1 b& u6 I2 o& m
        
2 D" x1 O' N9 F( {        if (theFaces.empty())
$ P/ j' B& q6 R  V        {+ W7 \6 h) _; _- F9 s
                isTangent = false;
8 X) r  v; r+ a$ w& ]  |! ?$ ?; P        }
1 c# |4 R, P  J4 p& A" _- Y        else
9 K. A+ V/ t9 E2 \, ?        {& h  \, ^* _5 X9 G4 [7 s
                for (int i  =0 ; i < theFaces.size();i++)0 T. @8 n9 _2 F0 i& r$ K
                {
1 W! @3 z; V  l* R3 a5 W; S3 d' W0 l                        if (face2 == theFaces.at(i))7 A" `, O! U* [7 d% Q- e
                        {' M( z/ U# J7 ?3 U( s6 ?9 ]. o
                                isTangent = true;
! g5 n  Z8 ?# B, b3 h$ n                                break;
; [/ z6 w2 m  q. g6 y: k8 x, ~                        }
$ z$ \3 j# N6 y! ~! |; F1 b                }5 F2 T; E0 x' G
1 o( u* P' D9 Q: m
        }
2 \5 f6 B: D1 y8 l- x        
! g) |3 j  r& U- X/ _        return isTangent;
5 a2 s% V) \1 [" ^/ e6 q: v/ [% n6 m7 E! ~9 B3 w: Y# o; A: Z
}[/mw_shl_code]! v1 a. L, E, ^) [
) W, j. I8 E' ?0 C6 t! y/ u
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了