PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
# I9 M9 y4 ^- X4 D7 f' b
NX二次开发源码分享:判断选择的面是否相切
5 H* q/ J- }: {1 S5 ^$ Z7 I4 q% r4 C) O$ I5 \7 i
8 X' n5 N8 q7 S8 ]9 ]  \

+ [# v9 M$ e, l2 l7 A$ g$ [: Z
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。" N% ~# ?9 L* j. i& ]" `: O4 f
0 Z4 j' Q# D7 o2 u6 V
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter( G) B( E( c8 ^8 Z+ A4 k5 ]
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
6 s' [4 |- b7 n2 B( J) C
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    . _# F  m- U8 l, q4 I1 X( |- @) s
2 b7 _& X9 G+ Y3 e  N* d, O/ |
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    , X& c& }+ H* `

    ( u# C+ Y- J2 b9 w0 K' y+ J                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    4 T6 T3 F5 ]- _4 X, F
    & {. C5 S( W- D# K' d
                                   
    登录/注册后可看大图

    % d9 w% E+ [4 c/ w0 f
# s% V" ^& p% I/ s) e
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
1 h$ z6 K  z$ a: P
  D" @9 s9 y9 X" N
                               
登录/注册后可看大图

( w3 G. R. |7 U8 u# Q1 |( S( e% z                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
% b* B% U  f5 v2 Y4 ]  {- ]' P7 w
1 i1 \) Y8 ?4 t3 b, L0 @6 X! d
                               
登录/注册后可看大图
1 [: `- M* [) V- R. y5 [6 @
                               
登录/注册后可看大图
7 I3 ]: t; [1 D2 ?5 c
                               
登录/注册后可看大图
) t, D9 E0 v9 B3 [' B: n
                               
登录/注册后可看大图

9 o. |/ s( C, a. y9 @                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。# j( I" I& i& N1 s# Z& P
' [3 O; N# A( ]
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
5 D, d& p: \* h+ q
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;
                                }
                        }
                }
9 ]" J4 ?  n3 ?4 e: g5 s" Y
        }
        UF_terminate();       
        return isTangent;
}

- ?) s- V$ f, |7 u# B3 }
5 [' p& c6 q0 g% o
& G8 C: j( _- I8 y% ^. S4 K! }, r8 d7 W7 t+ ~( h$ ~: b

; o! ]' E: n3 r# V* i                               
登录/注册后可看大图

8 `& {6 D2 |& ~- e0 v. C
' w3 a. D' [) \- G  k& q: p( V
                               
登录/注册后可看大图
END
PLM之家plmhome

5 }* v, Q% N. f% D' G' h! I- Q. o                               
登录/注册后可看大图
+ P4 n0 Q; O3 w: E/ X
▲长按二维码“识别”关注

) ]2 S4 f6 t, O7 [$ D- ?! A, i2 t6 b. y5 i' u2 P7 `- t
[mw_shl_code=cpp,true]4 C) p0 y! i% L% ?, {6 b

5 b0 W3 h" t$ r+ D+ ]+ d
% l' {" Z6 G3 N; z1 \" Y0 ibool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
+ W1 [, E  Y$ V' ^5 f" ]1 N{/ ]  \5 s2 L& N5 h  @

+ m$ |4 v9 H. @' Z' r        bool isTangent = false;
; _/ C# @, J2 [" i: ^% u/ i: \        int count = 0;
2 g8 v4 Y! {0 c# S9 Y9 ~# X, P        std::vector<Face *> boundaryFaces1(0);
6 y; U3 n/ W: E. U5 Q) d        FaceTangentRule *faceTangentRule1;
- K2 r! k2 Y8 N        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);( p- q; y% f/ t. U2 n" k5 {* b
        ScCollector *scCollector1;
7 e0 l' i7 |4 v- _# D3 ^        scCollector1 = workPart->ScCollectors()->CreateCollector();! W0 d1 c2 T' t* {. Z- ]% T
        std::vector<SelectionIntentRule *> rules1(1);
+ W2 e5 M' F( }; E        rules1[0] = faceTangentRule1;
; L" H2 V. x; H: u        scCollector1->ReplaceRules(rules1, false);7 h) x4 r' p; m+ H/ o' s- f
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
1 \. \: R) u7 a2 v, e  H        delete faceTangentRule1;
) i- ^4 @7 B+ |7 @" c  ?        
4 y* f: a7 s5 p6 f        if (theFaces.empty())
$ p3 ]) z4 n7 {$ x% D; J, B2 @2 D* L$ P        {
+ H0 [8 z# w+ q  u" Q                isTangent = false;
! I) K/ o. N; f2 s4 l! ?5 M        }6 a# A* {- g1 K& ^$ ?
        else7 r) v2 Q5 ?) e+ N4 A/ g; ^
        {6 f) F6 X; E- }5 G; k6 D
                for (int i  =0 ; i < theFaces.size();i++)% F; F7 [5 k6 k- Z% S
                {
: O/ k. p' k* k( H" q  }' K" p                        if (face2 == theFaces.at(i))% u0 {( l' c. l( j' N$ Y
                        {
3 z( p3 w  S/ L. V6 K                                isTangent = true;/ k" h% l, Q: O4 E/ ?; I( |
                                break;% a0 v; K; b; Y$ _6 r8 T% v8 Z& A
                        }$ R; p  v9 g5 J5 M
                }
' ?8 Q6 L5 Y+ y& \/ O% ]" u! {! b- N) p
        }! F  j" |6 \' ^7 |( S
        
  a5 U1 e  K6 V  U5 x( O5 T* A* U        return isTangent;
! R7 Q7 V8 m7 W( D7 f
* V' q) I2 _0 q2 a& r4 @) f}[/mw_shl_code]
$ F% g) Z. l% y. f5 v8 ^
7 R  [1 `2 ]2 g1 j9 Z2 ^% h, F2 R
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了