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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

" ?7 L0 R! A# s0 g$ XNX二次开发源码分享:判断选择的面是否相切
5 Z$ E" r7 ?+ O- a, E- U( T
- ~$ U- D$ O7 F! c' o
. }6 B# w  {3 S
7 j+ d! c9 X: Y# G, g0 R. B2 E
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
7 u! R9 _4 _* E$ H/ o( `
% b' f: M3 w$ ~1 J/ T
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
4 \' Q) C; f  R% g, [
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。1 G7 j: R7 J, B7 @  O" ?
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    ( ~# k; O% g7 L. A7 w

6 e) c2 N# s$ w                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    7 [" T+ y, X6 e; E: [- B( s2 b' {

    ' ~- c9 g8 b( b2 }                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    2 {" I$ `: s  m/ E, G7 u

    + a+ x5 r) K! `3 J                               
    登录/注册后可看大图

    - u6 M* f6 ~2 I+ e. Z$ O

9 y! o5 J3 f2 C( l" v. V! P
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
3 E. L) A7 ?3 M. Q

3 E* {. \, }9 L+ j+ m                               
登录/注册后可看大图
' U) |4 |  q( M  ]# K
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
7 u+ O: X; E& w, A0 r5 {

7 d, V# a1 k' v) m2 y- z                               
登录/注册后可看大图
) l' w: f/ T& M0 U6 Q% c
                               
登录/注册后可看大图
5 `0 f3 L5 Y" o
                               
登录/注册后可看大图
( x, J; L; ^* r4 n( v- \) W+ V
                               
登录/注册后可看大图

8 S1 a" p: |6 [; r4 R$ M                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。6 {0 W& P; Q4 [  w8 z" w
; g! @8 Y/ u% i5 a
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

3 E. _- v! {6 x1 E
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;
                                }
                        }
                }
# g! z+ s1 ?) a' x0 b
        }
        UF_terminate();       
        return isTangent;
}

3 N" a; _# t6 f2 ?- t  J- h+ v
6 G- s5 [+ e/ t) u$ q. A' b5 X, ?
3 R6 s0 Z  I/ j" ]- j4 U1 d  D3 p- N& t% i2 b

9 H) I% F, Q7 `0 P                               
登录/注册后可看大图
# H. w+ z3 x* P$ ?4 G! x& w
) n! Z' v# r" d+ W; [1 J, i
                               
登录/注册后可看大图
END
PLM之家plmhome
5 W0 J  K$ ^8 J+ W6 Z
                               
登录/注册后可看大图

( j+ R+ z& O' W2 Y▲长按二维码“识别”关注
4 ]& v* E+ \4 ]; b

& o# J3 E6 ~: a[mw_shl_code=cpp,true]5 S4 I( ]" w  n3 u# o$ J

( `- h+ y% z4 }2 @2 m5 }2 ?) f" b- l2 ^) ~: {* H
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
3 L6 H1 ^7 L6 b+ A* A' h{
, c2 B2 s4 ?6 ?4 \2 w8 }! M0 z% }/ U8 ]( A; h3 p
        bool isTangent = false;
7 @! }. ^- _! H6 l% B0 k( y6 B        int count = 0;- o  M' `- f  M% e
        std::vector<Face *> boundaryFaces1(0);. d1 |! F6 T6 i  y
        FaceTangentRule *faceTangentRule1;
1 N  U& I! U$ g' m        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
7 ]3 h/ y# f3 `8 p7 O. C3 e6 n8 a+ u        ScCollector *scCollector1;, ^; a/ B' J5 d$ |* i/ j2 ~9 F
        scCollector1 = workPart->ScCollectors()->CreateCollector();7 ~. g' r6 P: D' o% w
        std::vector<SelectionIntentRule *> rules1(1);
$ u* H- |/ z# C4 j        rules1[0] = faceTangentRule1;
+ i+ C( a0 {$ H) [7 C% S0 s        scCollector1->ReplaceRules(rules1, false);
" w* l! f+ \# C0 E2 c  _8 b        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
- S- j, c2 ^* p; g( \" y5 N+ [        delete faceTangentRule1;) ~, D7 b' E' r+ a+ `2 |/ R  G
        . c. ]) m0 h% C7 M- V; |( E
        if (theFaces.empty())# Y. v& V% y0 e$ o  Z
        {
0 q8 {  X/ C7 l- |. s                isTangent = false;
" j2 Q4 g& T# I# g) ]/ S        }
$ a1 a  Z. Q% x  ]# w; [; f$ k        else4 V+ B# t- O+ o$ S9 L3 M' f
        {
- d: |7 x+ l8 a/ E7 j/ N: `  x                for (int i  =0 ; i < theFaces.size();i++)
" y0 d* G8 P$ i0 E' e. Q9 F9 _                {' i/ b- }& f; r0 H
                        if (face2 == theFaces.at(i))
5 ^0 f7 l' N, ~/ s                        {
+ N: S0 ]1 y8 H8 d9 Z                                isTangent = true;+ h1 k- D0 h/ Z7 d9 a
                                break;+ ]* `! p2 _2 Y* r" |5 f2 T/ v
                        }1 y/ n( J( E* z
                }1 ~+ b/ Y  y% ]

: @  l7 \4 j& P        }
- ?- g3 o! H7 E6 @. B        0 p) ^  B3 p- k9 m8 w
        return isTangent;6 l- ?/ \* O5 g7 C0 @. j

: j* w4 ^2 R; n  d; A6 O}[/mw_shl_code]8 r: m$ H. H7 R
; w! q1 V' J% N1 F
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了