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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
5 p* N  e, l2 |; {* a; b+ A
NX二次开发源码分享:判断选择的面是否相切
% M- W' z* h6 |" H$ |! T1 C
" `0 v4 a2 \; v8 c, b6 N+ f; H
: T  d" h6 |1 w& c" ~  c& Q
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
$ B/ p. e  M! H/ y6 W& k0 j) q& K
% e7 T: r+ g* x7 ]: v9 y5 s
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
5 E0 _; E+ ~9 Q- ?- u2 S
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。0 N# k2 Y* R( z5 }9 [# t# x' P
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    3 v) I0 P0 T2 _

- p; u7 ?3 V' \8 W9 ^; `                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    / S# V5 P/ j# M- A; Y4 V7 o
    4 r: Z8 z) ^! x
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    0 s8 M3 m, m  K, p
    5 }( R7 _7 K. ?& q$ O
                                   
    登录/注册后可看大图
    + g3 f" S# _4 \( W

/ w5 X' R/ y4 S" `+ E4 f1 i
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮3 `! r2 h5 g$ _' y1 ^# c
; \" C- Q6 w5 f
                               
登录/注册后可看大图

) x/ K5 G+ N2 c" y                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
3 i! y/ Z) E+ f5 f

; \( Y/ [5 Y  C( f. u                               
登录/注册后可看大图
$ \) p1 f; `" u, n
                               
登录/注册后可看大图
1 z7 H2 u& `) H8 j7 V( L1 z
                               
登录/注册后可看大图
9 K8 h8 D3 f8 n# q3 w+ O) A
                               
登录/注册后可看大图
# y7 y( r4 T' U. S3 e- ~& H3 `
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。
; x/ Q: c% S9 L6 E( \( k' q
) U2 v/ A+ H0 J! J! d3 F/ v
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

/ U$ V8 R( m0 \/ [2 A
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;
                                }
                        }
                }
- e; B8 b9 \$ q
        }
        UF_terminate();       
        return isTangent;
}

- n: ?# M0 s( L2 _( H% T" d8 U
  x# F6 t8 p5 E  c4 O+ D" c0 z0 U! b$ @
5 p3 d) |8 C* y9 R7 |5 g

. ?  H2 T0 w; [- u$ K) l                               
登录/注册后可看大图
- w9 Y0 @$ M9 s3 e' e6 l1 L
& v+ V" E2 G6 z: k7 L
                               
登录/注册后可看大图
END
PLM之家plmhome

  E1 L: `/ V% ~; C1 d, m  L% X                               
登录/注册后可看大图

4 k3 J7 M, m5 ]' |, y▲长按二维码“识别”关注

( P2 F% m, N- P% l& S/ ~9 g0 f) w0 J
[mw_shl_code=cpp,true]
+ t/ e5 B# {" \: _( P
! `9 o, |$ q8 T# w& D, f
2 a5 Q* q% w/ f6 ^6 q( z( r, Z/ Wbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)4 J+ o: x( q* i& b) S
{
7 _% T2 O9 K* g7 z( i' {) B! t) y" v, n: x5 y2 I
        bool isTangent = false;
0 d6 o/ a/ U7 Y- R( y5 Y) M        int count = 0;* x! d- @: L. v  @/ w8 l8 ^
        std::vector<Face *> boundaryFaces1(0);+ L! |. p0 l' P; T+ G5 U& E
        FaceTangentRule *faceTangentRule1;
) J% N" b6 w- s        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
( V, t) k) Q/ t9 E& i# D' ^5 }8 K        ScCollector *scCollector1;' x$ r. ]. B$ c
        scCollector1 = workPart->ScCollectors()->CreateCollector();/ g4 Y4 @  O/ T; v- D! ~, Q3 c
        std::vector<SelectionIntentRule *> rules1(1);
- R! V/ G' B  q6 V- G+ d        rules1[0] = faceTangentRule1;
# U/ T$ x* C& G% I' p+ d# a* J, E        scCollector1->ReplaceRules(rules1, false);  X7 u, ^9 X7 |
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();( _1 q( z4 {8 O# q% O
        delete faceTangentRule1;
1 \1 ?7 A7 P: G        & X; {/ }% N: p! l' W' X
        if (theFaces.empty())  ^" f7 V8 D9 l
        {" U2 t0 B4 Q3 e7 B
                isTangent = false;
/ s1 H) z6 S7 Q; ?4 o& O7 u% W( W        }" C, y9 B6 W/ S0 F3 x* y
        else
* w, H% A0 X% T: V- g" U        {  o# U1 v$ A- H6 x7 `) W
                for (int i  =0 ; i < theFaces.size();i++)# z$ C5 y5 I8 D
                {
8 O& _9 x$ ^  Q0 h. c! s: y                        if (face2 == theFaces.at(i))
+ G8 j( ?  [- l* L" v                        {) ~0 C5 c; y4 b7 }- i9 f
                                isTangent = true;# h! a  Y7 f/ I# U* j" ~$ U
                                break;
2 j+ Q0 d+ ~; B1 E) z: w                        }. {8 T9 a% q. c" i5 {" U7 q
                }
' f' y9 B4 `! _1 ?# p! h' g
  G4 y2 ]: t( S" w        }
, v  A4 u- V1 e, F. g        
! E3 E; u" l/ C* R5 y1 ]        return isTangent;
7 M) T* K9 U0 Z6 m0 h, s5 C$ N" n9 q5 m  G8 a- S( D4 ?( c+ k
}[/mw_shl_code]! [& Z/ U6 F4 B$ d( j  R
/ p' s0 X2 g- f4 k' X
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ 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二次开发专题模块培训报名开始啦

    我知道了