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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

5 t/ ?  ~+ n0 rNX二次开发源码分享:判断选择的面是否相切
/ Q1 G# P" S0 w8 \1 |. [0 R/ {8 R1 Z3 }" F. }. y8 o" \
: c- i9 a4 y( H  @
  I* G) X8 D: E
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。: x5 w: k7 o$ Z; ?
1 f4 L; c0 {: o, g7 X
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter8 w/ k9 w8 w$ M  X) v4 _
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。* P0 G! q) c8 M" W( X
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    ; V- \0 S0 G* Z6 g9 @# ?; W
. ]5 [+ W! y. h; ?, P
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    3 _# O3 O1 i7 Y4 V3 F# }+ h
    # R+ Y, c8 J8 o; a
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    / L1 u. A6 m! S; F6 L8 b

    : f$ `& c# e* r                               
    登录/注册后可看大图

    0 L) ]7 {7 d6 I& N' K4 }
& a2 P9 m0 l& a) \3 P5 S# ]# }8 O
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮) j3 p( z" N. Y) v1 f
1 k4 n4 m; {' g2 P9 [: E5 D* ~4 Y
                               
登录/注册后可看大图

, M: O: C& E) v5 ?7 E  q9 O                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。8 t, h' {  E. k/ d6 b' n$ ~9 b

3 p& b& {: K+ U& V1 q# d                               
登录/注册后可看大图

# j& p; i2 N  v6 O                               
登录/注册后可看大图

, t9 A2 S+ U% `9 ^$ z: z. h" u+ D" L                               
登录/注册后可看大图
" |. H; w( v/ U5 s& K7 W! g
                               
登录/注册后可看大图

0 h& s# ~' S4 s" K                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
4 B% k+ q; @; W9 s9 r
& D1 a3 @1 w! U- p& u! I3 o
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
7 z( b, j# Y! d! G) a  S
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;
                                }
                        }
                }

. S# L. j" Q% Q: P: q+ a2 y
        }
        UF_terminate();       
        return isTangent;
}

8 B1 e& h0 z/ x2 v8 Q3 w2 m# w* @# T; h& d7 z

7 N6 h4 C; x$ Q, p  n4 p: {; M/ b8 ]$ x- u
/ s  \6 P! E5 o, B# k- I( ]0 N
                               
登录/注册后可看大图

" o/ S. M; G( U2 Y& {' }1 ~- s  w! [) b8 W
& j- R5 F1 N$ W1 N! s: D' K
                               
登录/注册后可看大图
END
PLM之家plmhome
* E: H/ D/ o! M
                               
登录/注册后可看大图
) {( _0 j9 c. G! b; S; X( S
▲长按二维码“识别”关注

, i* i0 E5 C  E- {) n, s
0 T, `0 T2 _6 t& S: Q[mw_shl_code=cpp,true]3 u  c$ W# @3 ^  M- e
3 m, \) |* e, S# b

2 p5 S- U, y" X2 k/ L! sbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)% b& @$ n! A6 [: i/ W; X5 X
{& ~! Z- T3 t# g8 X" k
7 s' [: O" Q9 g! B
        bool isTangent = false;
, r3 }6 g9 Q* f9 R        int count = 0;
7 n+ o; O" {& E$ l        std::vector<Face *> boundaryFaces1(0);/ ?& v. e: `8 l1 W8 s
        FaceTangentRule *faceTangentRule1;
- U4 ^8 g' c& e8 a        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
6 H2 Y' j2 H+ T, d        ScCollector *scCollector1;
5 k9 }$ L1 }  f) o* o/ G9 W        scCollector1 = workPart->ScCollectors()->CreateCollector();
1 s* R( ?& y7 h( a  a        std::vector<SelectionIntentRule *> rules1(1);" W7 E; I  _% P# x
        rules1[0] = faceTangentRule1;
3 r0 A7 ~( P; @% n2 M1 v, ^        scCollector1->ReplaceRules(rules1, false);! S/ n. M1 _9 _' a/ {3 F
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();. }- w3 m6 `( M5 c+ G: A
        delete faceTangentRule1;0 r, |% w2 b6 M. x, m
        
- A3 n6 U0 _3 d5 |        if (theFaces.empty())4 W- N1 L( E& m
        {) Q) W$ e3 e! S3 X
                isTangent = false;! O1 |$ e# ^$ l& f
        }
0 b7 x' K! F+ Z8 L" [% X        else
9 L, b' [, j" p        {
8 ?& m0 z7 w3 _1 T  c' b                for (int i  =0 ; i < theFaces.size();i++)
  I' W. J# b1 p" s1 c, ?                {
' b; t- H0 r, D7 j4 |1 J" E' r                        if (face2 == theFaces.at(i))
- O: L9 a! S7 W: g                        {
; y- ^7 P/ e5 f. a( j                                isTangent = true;
' m8 I* W0 l5 m3 c, w                                break;- r0 l9 y% E# t8 p, |! x/ m6 [/ @( T# H
                        }0 I$ t% H; C. V' T. i( y% b
                }
7 E! H6 m% c1 I, c5 G; V1 }: j& ^2 m3 Q# Q& g1 X! H7 t
        }
4 |* x3 w: M$ @* m% I3 |  L        % m1 g. @0 F( D; v4 A+ i, V1 O: C* T
        return isTangent;
; |- ^( \8 `( i3 E- n. s+ X7 u( d% L2 g! I1 T0 |- b1 K. v, _
}[/mw_shl_code]3 @, e( T: d; c9 N; j8 f! p# X
4 _0 V- E, H& M
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了