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 2249 1

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

admin 楼主

2019-9-15 08:38:30

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

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

x
6 U% ^6 D: \! u8 B- u
NX二次开发源码分享:判断选择的面是否相切" D) G: Z5 ^! F4 C5 Z# N( y
! P9 _5 V6 ?2 b4 S* |3 ^

- L# [, f1 S1 h5 l2 N/ E0 }6 F( t
. j) l( E3 ~2 X
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
/ s8 o# F; z1 x7 e
; J0 n% ?$ O  [
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter- b: K) ?2 n* |5 P8 t- [. z! g8 g# b$ @
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。! |' b. u5 W  O; @3 v8 F- n
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    % \2 H, g4 D/ R+ n: x

( V9 v! k' `$ |- `                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    - J7 O8 c+ z2 u* ]6 ~; V1 e
    8 Y% U8 T9 w2 S/ V2 P
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式
    ' O0 X; y: N( Y9 e; S0 M& [

    + X) k  k& p7 Q& S$ w                               
    登录/注册后可看大图
    : N! K9 e( |3 H, t, S7 k% F
# }3 [# V8 M1 E: h0 u6 `
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
7 |/ n6 k4 N5 E- ~
' e0 W# G" V% o" ~3 ~5 F
                               
登录/注册后可看大图
6 }" J4 }  y" ^! u$ D
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
& h" p- e! b0 M

( f- X# c% c; ?                               
登录/注册后可看大图

, s7 Z' D- b( M                               
登录/注册后可看大图
. J. B, g% ^6 o" \% ^/ Y9 \8 ^- l
                               
登录/注册后可看大图
9 `' z7 e2 j$ F/ B* R' F) U
                               
登录/注册后可看大图
( }/ l9 v+ R1 C: x) k- Y; x4 ~: ^  ^
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。, B7 y1 L0 U' l2 L

8 s% V, G7 \' ]5 T; b
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
. c9 c( U8 L& P# a" V( m9 E2 v
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;
                                }
                        }
                }
* N5 o; n" b3 Q/ w( ~% {
        }
        UF_terminate();       
        return isTangent;
}

) M" b  g" |! D% O. b
- h5 O; i) s' L4 P  n4 ^" O& A3 E: Y. r, a  Z, H

3 I9 z/ v5 m0 H$ ?
( B5 A7 ~$ g  N; C7 i- l3 ^8 X; ^
                               
登录/注册后可看大图
& i! M8 a: o# F2 p4 [0 S9 ]

0 w( r& c3 {. I1 l                               
登录/注册后可看大图
END
PLM之家plmhome

$ ^3 X* J9 Q3 w  e' c/ s4 ~1 R                               
登录/注册后可看大图
4 ^0 R" C) b! M+ z2 r
▲长按二维码“识别”关注
. d2 e4 q  n/ S

5 H9 Z3 [, X. t  q) |[mw_shl_code=cpp,true]7 q; [1 u4 L0 Y8 ~
! s; F& K! a' b4 ?9 y
6 M, v8 G% p2 t/ B
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2). x  p9 m" D4 @8 W( t
{
+ e+ }- ~5 |7 \- [6 t  v' X, b, k$ ~% y" Q) C, K$ T
        bool isTangent = false;
+ R" t' ?# m' e0 B        int count = 0;
9 I0 Q) {. o( w        std::vector<Face *> boundaryFaces1(0);
; ?3 q$ {2 J! O1 D+ M/ \        FaceTangentRule *faceTangentRule1;
- o3 E4 O' }  h3 e9 Y        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
1 k0 C6 M5 G" |% N5 v        ScCollector *scCollector1;; x' Z/ r( K; n( \
        scCollector1 = workPart->ScCollectors()->CreateCollector();: w1 V5 G' y0 h$ G0 l
        std::vector<SelectionIntentRule *> rules1(1);
3 g9 L  U. A4 Y5 D# U& M        rules1[0] = faceTangentRule1;$ k- h7 R' m  g3 m3 u: `
        scCollector1->ReplaceRules(rules1, false);" v( z1 M+ v  X, q
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();' _. u' `- Y5 @  h# s
        delete faceTangentRule1;
- ^. p2 r0 @% Q* R        
& b1 l. p0 K( u8 U5 |, O        if (theFaces.empty())# t' o; e1 H  e, H$ f/ D8 f
        {
5 p4 h7 [: f# X  G                isTangent = false;
) q2 D8 [# i3 k: E2 m; D0 H! Q4 C9 w        }, U/ T' g3 p2 a/ j. n. O. Z* g4 h+ H6 g
        else
$ N7 d% |$ m8 g6 {) A. }0 v        {; S4 ]% S7 w) f6 `+ b* @+ I8 k
                for (int i  =0 ; i < theFaces.size();i++)+ Y. b: f" q5 f3 M$ k
                {
7 H  E, `( V& \# t2 T% J8 r                        if (face2 == theFaces.at(i))
& }4 O1 G2 G# H+ G                        {- @& S6 ~* M& x+ [
                                isTangent = true;
4 K% c: R- H' Z+ \9 ]                                break;
% D# A! T# S8 n7 y4 L7 C                        }
5 t7 ^# K% x* I0 o$ U                }: z! [# w/ g7 K! \- E
! i* V3 T$ n2 m8 ~' R# w
        }
5 ~! S  \. o& ^, P! F# j- b/ \        
: w. _6 K+ g) o        return isTangent;
9 D0 _4 S: d, N* G5 o+ j8 c) _" E, N
}[/mw_shl_code]2 t! Q% [$ o, c  G" G+ M) n2 i6 n

- G& @$ q9 s4 F+ S
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了