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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

0 @) y1 ^: D5 \4 N8 G, LNX二次开发源码分享:判断选择的面是否相切
, m# Q( w$ h& T0 T+ t, i4 t) P' i% T5 w

6 v) q  s3 [7 D! i% {/ r
' b3 C+ Q$ n% q- `" I; p4 D. z
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。# f/ ~: m% L+ s( \, z" `
! w9 f/ p# e3 [( l9 @5 m
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
% S# V. n7 ~/ Y9 S8 a" S+ }2 x! X5 b5 j0 Y
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。, ]( S1 u% I( D" R: ?
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    # H1 `% G. I2 ^& r

, L. g0 Y1 ]/ [! q                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    ( P# G8 M5 a$ e5 O' Z) I5 ~

    ' _7 F- }2 d" d9 c! A0 N  f                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    8 }( j' m5 y1 Z/ E' E+ A

    2 u* j  P0 ^* i# Q* l( Q  k. a                               
    登录/注册后可看大图
    # H6 f6 V% f; e" m- }
0 T% q! X. q2 P& J' c: M
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮6 j3 h% @2 [! e* r0 `
1 _. @, k! z$ p: o% G6 [
                               
登录/注册后可看大图

, x  ~$ k% K, J% u0 f                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。8 G7 E+ s$ \; b0 I5 U

6 R4 s% N! a' `: W4 d                               
登录/注册后可看大图
5 `/ v# {# D2 N* j0 t0 k1 i& w
                               
登录/注册后可看大图
. n$ K, a5 Z- u; W9 O8 K% s+ K" \
                               
登录/注册后可看大图

. U& D, o0 e9 i- c2 i+ Q+ L3 n                               
登录/注册后可看大图

5 r( Q6 N4 s# S1 O                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。4 [4 M6 q. \3 T" b+ B" t0 E/ E$ B+ k
- h, O% w+ b6 n7 L  \
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

7 Q* B7 o9 R9 ]: G& J% G7 m
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- }( P/ u& B: p% \* Y/ m, t" \
        }
        UF_terminate();       
        return isTangent;
}

8 _7 H7 h) l& G9 @' ^, c* E8 D8 o" P9 X

5 A2 K" f9 o. ~9 E( v) c' H
. q) L: B( z( }; ?) }
  {% c: v- }0 d6 M7 k3 L
                               
登录/注册后可看大图

# {3 I: K$ a& C$ _" b0 A
1 T  U( P3 ?6 ?* K) n! ]
                               
登录/注册后可看大图
END
PLM之家plmhome

6 Q: a% A! Z" p* n  A3 S, J                               
登录/注册后可看大图

5 E( b) b% F1 @+ R/ z- G▲长按二维码“识别”关注
) e0 ]' K6 y9 W

( B" h1 q' Z5 b/ j[mw_shl_code=cpp,true]! P+ Z2 M  S7 y& ?4 t3 Y

& e) }, n9 k$ p$ |7 T& c. V, ]; M  s4 ]9 |# i
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)4 P; ]8 l% D( Y' j0 ?$ v
{8 c$ q* f+ R$ D/ b" _

! }; S0 O6 L  Q6 Q2 _        bool isTangent = false;
; d7 n4 B* N6 B8 x) c) Q        int count = 0;/ M* E! a9 N  O8 \, k
        std::vector<Face *> boundaryFaces1(0);+ V5 j. D3 H& m  V6 T3 i: [
        FaceTangentRule *faceTangentRule1;3 e/ d$ A0 T" V0 M# r; l4 s& B
        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);. c7 E* O! o/ K) m
        ScCollector *scCollector1;
/ _+ ]7 B' k6 Y1 s" K- b' e7 w        scCollector1 = workPart->ScCollectors()->CreateCollector();
2 S# y& ?% [2 v8 w+ B        std::vector<SelectionIntentRule *> rules1(1);( q% p9 t& N" ]! i; _
        rules1[0] = faceTangentRule1;
' b% r) k* I7 E3 q0 X5 j# _" J7 @        scCollector1->ReplaceRules(rules1, false);
; C8 i  p, p' e4 A. o. Q. X# |3 _9 b9 k        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
5 Z6 O2 c) D  a% F5 X5 j        delete faceTangentRule1;$ d( q+ J- d, P/ B$ @
        ; q) C8 C; |# m& w4 ~4 y
        if (theFaces.empty())0 f" b* J* J. K# i, N: Q
        {) `- W0 V6 A. P7 |
                isTangent = false;, ^- u" {" F. ~# V- X' b
        }2 ~, \1 h' _9 J$ X
        else
, [* L1 c& K0 L% t: d  j* J        {; _2 k7 ~* ?& \7 c$ [* H0 ]
                for (int i  =0 ; i < theFaces.size();i++)5 A( t! q6 R( ~# ^! l. n7 g
                {# o0 B& A/ O+ T! z+ k6 X2 F7 |
                        if (face2 == theFaces.at(i))
. [7 |- f+ n! A                        {4 n* C( p" n! T3 ^  Z* L9 N2 x
                                isTangent = true;
0 w4 J) [8 |& I5 ^3 w                                break;
; O  k) W/ p% c3 ]3 r3 R; R                        }0 [8 T+ x, j. m8 @
                }
% O: b2 J* C: c4 {+ U: A! u  \" K7 c
        }
3 \* s9 y1 J# j7 L        
- s' T0 C& C4 p        return isTangent;
+ A, ]6 K  @" W  q* d2 E
8 O3 Q; x) f' P% R8 Y9 u}[/mw_shl_code]
( S! Z- U* Q5 z# J+ Y5 ^
6 L1 U; Y. f# e, f$ X  ]: K
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了