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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

$ E1 i! _# P  e' D* LNX二次开发源码分享:判断选择的面是否相切" u' i1 D2 V; `( t

$ R4 A- d% a1 w' q$ ^1 g* M2 y, z' k2 _6 Q

/ v+ |( y- @6 e9 g! p
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
$ @1 n6 m+ k0 L- x

* B' J* h7 X$ b2 ]
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
! G! o0 k- E0 e/ y% ~, c
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
& i0 c6 A" U8 z$ z. P; z
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    % C7 L" J' G( K0 v' v! y  H
7 Z+ Y% l, Y0 z9 G' F  F
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    0 ^4 G5 c  m# P( |2 O
    " D  [7 j' X- e" r
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    ! }+ Y! Q/ a. i6 @$ K  ]

    ; v. Y# W7 n9 X6 \6 c" F: e                               
    登录/注册后可看大图

    1 D5 U8 m% x4 k* d  E0 }
9 v+ g- w# b) G0 L* X* I1 D
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
+ f. D0 z* G& F3 D7 v
8 A  Q% a3 e9 z( m) O3 Y
                               
登录/注册后可看大图
" c1 [  @$ {% f" y- L6 n* V. E
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。: w- n: |& t9 U) @8 [* L' ?8 f
7 f, _4 k. z) f$ L+ T
                               
登录/注册后可看大图
6 g8 m1 L* Y- S( q7 O  b
                               
登录/注册后可看大图

1 J: j1 F& T- j0 E4 R  F7 W                               
登录/注册后可看大图
/ D: B6 I4 G; {
                               
登录/注册后可看大图

  m: g; _  S& g, t7 c* z                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。& c0 {; h2 u1 n2 C0 w
  F6 m3 R- e. M5 n& j
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
/ D) v  O( ^+ `8 X; U8 R* i
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; f5 M0 I1 p7 d0 j( q
        }
        UF_terminate();       
        return isTangent;
}

& p2 g" r  z9 v0 ~$ j( a2 H& }: L, `# F, e. ~$ `& W, h

  o6 Z5 k! @$ I/ _: x+ @
2 b8 e: b: {5 n( ]$ a) B2 ]' B( M

* m# Z& G' Q" y% _$ ~                               
登录/注册后可看大图

' S% ~$ _% v2 i* d3 i8 e! F* v
  K! J+ o  U  d, v' n. T1 K
                               
登录/注册后可看大图
END
PLM之家plmhome

$ V& T9 l2 t5 W9 d                               
登录/注册后可看大图

- |+ Y9 n- ^* W$ S▲长按二维码“识别”关注
$ \2 y6 G3 B& J+ j2 P
- ?; U( l( l- }/ |" t7 z
[mw_shl_code=cpp,true]4 C3 ?5 }" f# U3 Q. j0 ?

3 L2 M7 u0 Q9 w" \; S+ e0 {9 u$ n5 F8 a# S
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
/ S. ]$ e8 R( n/ e0 d{) f% b1 K# N& `

4 P( m2 v7 J5 v* F- w1 o% u$ h        bool isTangent = false;
+ {( C/ v) f! U; W0 O. ?        int count = 0;
. K7 d, H0 U: {& b+ K        std::vector<Face *> boundaryFaces1(0);8 D& }6 |" P- X) I
        FaceTangentRule *faceTangentRule1;
8 y8 w9 b* J+ a8 u& ?        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);( |2 F* e" n6 N( F
        ScCollector *scCollector1;7 }/ Y% a, l5 @" F/ }* R/ B
        scCollector1 = workPart->ScCollectors()->CreateCollector();9 ]$ U% o7 x) }% w
        std::vector<SelectionIntentRule *> rules1(1);
4 a' o6 y0 `# \        rules1[0] = faceTangentRule1;
5 s) [2 F& q  t        scCollector1->ReplaceRules(rules1, false);# D2 b% Q/ P3 j  W
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();! {! P; ?2 P% H. x
        delete faceTangentRule1;
/ v& R# r+ I' N" ]3 @        
4 b5 G  @! p4 a5 {9 b( F' l! v        if (theFaces.empty())
; d$ m# ~$ |8 s        {- P# E' H( E$ g+ t7 o& u
                isTangent = false;
# w1 W, W8 e( X. N1 U' P        }: [: P4 I0 [) a( P# Z1 X
        else9 p) O* P. E1 @
        {2 t: |* Z0 S; I  h, @% a, x
                for (int i  =0 ; i < theFaces.size();i++)
0 f3 M3 N: P1 ^- h3 \                {# G* o; j8 L$ x  U) a- ^# L5 d0 ]/ I; S
                        if (face2 == theFaces.at(i))' s; ]% r! l$ A1 O6 W
                        {/ Q$ B6 b; `% _6 k1 D+ C' ^
                                isTangent = true;- b' c+ k- w1 N: H& K
                                break;
5 x) p8 L6 n1 F                        }3 q! _; Z1 Q; |7 s+ l, E
                }
2 R9 o3 C# N" r, A/ A( C; V8 ^0 d0 s
        }* b; R( a$ V, K( D( Y, @
        & r' x+ ^+ C0 K. [
        return isTangent;
7 h0 d4 d7 k% f7 Y) R* R, [9 j6 ~/ t2 I3 r, @# A' k
}[/mw_shl_code]- }; p3 B5 V$ a% T

5 _3 i+ _. T; C' R  i2 {( `0 g2 U; 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二次开发专题模块培训报名开始啦

    我知道了