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

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

admin 楼主

2019-9-15 08:38:30

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

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

x

* ]' h, K) |/ s: V! r* ONX二次开发源码分享:判断选择的面是否相切
$ w# I1 b3 v0 E1 s. }3 V4 q! H2 h  `

/ Z( y7 F8 M. b1 z/ r! i) E

4 ?$ R, p& o) R
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。
% \9 I! I% I6 |1 h/ G3 a
* j" A- G; N/ ]% Y, E
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter2 W$ C" @0 |; t/ \* e: X( [: k
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。) C' G$ E' j1 r3 n
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    5 C/ c5 H; M* D! {9 P7 N

2 p( I  J5 N' ^& T) {5 _; W                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式
    . S+ P3 W; ]" ]5 N

    % C' V7 f8 F6 f# ^. v                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    $ x( L: |" {) |" v  I$ L" W

    4 K1 p1 D% c/ w/ m- Z1 w% y% k                               
    登录/注册后可看大图

    3 |9 V% N4 h* F

0 `1 z8 h. [1 ]  f6 m) ]6 y; q
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮% t& q7 m( o  F& t3 D

8 N2 M: n8 |! Y8 C" N                               
登录/注册后可看大图
$ x) ?2 V, e2 k' a" P9 N* }  }, e( T
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
+ r1 H4 D5 V/ x# M) X: T

$ |5 r# ]- ^$ X) V, }! d6 b( r% P5 v                               
登录/注册后可看大图
9 B9 z, P4 m* v; r' j+ q) x! v- x
                               
登录/注册后可看大图
% T. g- B- w' P: G( |
                               
登录/注册后可看大图
9 e  z: @6 H3 O
                               
登录/注册后可看大图
. |( R( s7 j, A0 m
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。% M+ w$ K" X: [& X
7 b7 v, X- Z) S, k& Y$ O
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

" R+ f9 s$ e6 T% x& `8 _; 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;
                                }
                        }
                }
1 D' r+ {; Q1 V0 p
        }
        UF_terminate();       
        return isTangent;
}
$ M% X' b: N: q4 C5 U. g: M7 |
& B% z5 A4 w' _9 r$ d8 u

: b* b( g# u* }# P# e" K* P
2 w# [' H2 y  f% `; A: ^- f$ C
& b) A( n( i) r' L3 L' h8 N! k2 d
                               
登录/注册后可看大图

* D+ u5 a, C# Z5 s8 M/ M

" A* E$ U' O3 |8 h% ]8 P6 n                               
登录/注册后可看大图
END
PLM之家plmhome
$ w, G8 n: g4 g0 D2 S5 _; U  H) z
                               
登录/注册后可看大图
/ N0 I0 A3 A) I
▲长按二维码“识别”关注

) o( u6 D/ j) s/ `! i2 D$ n* Z, J; J5 k, M3 r9 ]. V1 A6 n
[mw_shl_code=cpp,true]
8 n! k4 V4 h/ }, n4 i* f7 x) b# \) F) F1 ]
8 K$ B% U- I7 W# l
bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
) U2 f9 _8 v% T+ c, L7 I( i{
  {, O4 _1 s& @
% ~/ Z: c1 s5 y) Y) S2 p1 b        bool isTangent = false;$ n5 }( F8 C6 z! s4 b
        int count = 0;
5 O  m/ `9 @& ?7 e4 A        std::vector<Face *> boundaryFaces1(0);* N# d5 j8 X. ]9 L* w9 I, Q
        FaceTangentRule *faceTangentRule1;
& \6 V# Y& \9 H2 t$ j' ~1 v7 a% e! C        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);
0 ^% j( J0 q, ^  l! U% ~        ScCollector *scCollector1;
. Z$ |% Y! j1 V4 d) k8 [& H        scCollector1 = workPart->ScCollectors()->CreateCollector();
7 R1 B/ ?6 P. q1 P  d2 `        std::vector<SelectionIntentRule *> rules1(1);
. m; p* g/ f& ]        rules1[0] = faceTangentRule1;
6 X1 a; V5 {% p+ m: T; T+ t' e        scCollector1->ReplaceRules(rules1, false);
# E' \3 j* i! J0 u/ m1 a  M        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
, M: h, _( W* t) q- d        delete faceTangentRule1;
/ S7 ]% x3 Q, h        
1 W  v$ g( m% z' d        if (theFaces.empty())
9 j; p. r2 e6 F. p- ]        {. l: S1 o5 y# a
                isTangent = false;
7 h/ M, z: \( R, ~        }
: H; I3 @# ^3 O* T5 i        else
; z( Z: l. R- r  \4 p1 \6 E        {6 B  E: K- \" s/ {  Z: N* N% p
                for (int i  =0 ; i < theFaces.size();i++)
4 X+ N3 E  j, ?# B5 ^% _* d$ ?                {1 C- p5 u# T% ?4 q
                        if (face2 == theFaces.at(i))9 v$ H+ S, K: f8 R/ l
                        {
3 n5 Q/ b7 F# i                                isTangent = true;6 Q! k5 L% W0 q+ `
                                break;
5 I+ ^; _: r4 S" C3 Q, T5 o                        }1 {7 j( B. f# o8 {; t5 `
                }* ~7 P! l; M1 w7 z: r0 r# o

! w* h  {1 S2 J3 Y1 \" ~- k        }
3 ]& @% m0 {' g        
7 W: A  ?6 m, I" D        return isTangent;* r! U: X( H* N& |, }

5 R2 V+ M% d! j) q& C0 {}[/mw_shl_code]
1 ^7 P# s! N  F$ ?. t
% e. G! {* X5 \% ^- 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二次开发专题模块培训报名开始啦

    我知道了