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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
" ]+ H4 x  q( Y
NX二次开发源码分享:判断选择的面是否相切0 V- W0 D8 c1 Z5 l- [9 d% ~( [4 H1 c

' @! w9 C6 V- Z
# F, L6 R: H7 j" h8 }5 O5 E
: S9 o' I3 s1 J1 S9 ^# V- [4 M6 {
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。) D9 u# X7 L! k% f3 z

, a3 b7 q* n# F
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter7 _2 V* @/ p( L* u% S' P" ^4 C
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。
+ N& m& f& ?1 [" f% ^
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择

    & ^5 u$ w8 {: Y* u- m
* n) Q9 }# m2 m
                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    : |6 v  q  Y& c% `

    : n0 R1 |5 Y3 s9 D9 F" s: r+ R                               
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    # r7 i$ r* N$ j$ v7 d
    9 [( o, S8 \+ ~" d0 V: O$ \3 O
                                   
    登录/注册后可看大图

    % U/ v. |8 {5 j4 x# P/ i* t( r, v
1 Q% _* J2 o7 b
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮
& O% S' W$ P3 Q6 m4 u
) N; s3 G( Q/ f( q* q9 e
                               
登录/注册后可看大图
. F% }$ h4 @7 E5 e. g% H4 ]; f
                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
8 Y+ U+ |+ @; j1 d+ J4 b

1 f7 t/ z( M3 y6 P: z4 k                               
登录/注册后可看大图
: m0 ~0 ?4 d; ^# ?( A" f& e4 O
                               
登录/注册后可看大图
# x: A7 T; o6 D; t: R! Q' s- {
                               
登录/注册后可看大图
- z) ^$ N* ?* j' W- _0 D
                               
登录/注册后可看大图
8 y- G" S$ i! i: H0 a! @
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。" b) k7 t! ^4 j/ J
; q% X8 [# {# J: }9 }  z
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!
0 P1 ?- }" L8 I) 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;
                                }
                        }
                }
0 m5 m9 Z* u9 c. [/ e; N# I- @; w/ Y
        }
        UF_terminate();       
        return isTangent;
}

: [$ e% B7 B1 r1 g( J4 d+ ?- b8 s5 P% _) C( \* A. z

$ S- ]! q. `% i2 Q
/ z8 F8 W& b; V1 d
2 g* h" W3 g$ ]; S4 A" t
                               
登录/注册后可看大图

/ a+ Q, M! ]1 }( j

7 ?" i( j5 U# e6 u                               
登录/注册后可看大图
END
PLM之家plmhome

1 O/ G8 d) u' Q& E3 f                               
登录/注册后可看大图

1 r0 h% e5 G' a1 q4 I! n0 q: b▲长按二维码“识别”关注
9 E9 D  B" L& K# C1 o5 k" W6 ]2 t* o

6 i9 a& f8 }. s" c+ k4 R! w  X[mw_shl_code=cpp,true]
5 j& z' D; r3 X, S/ Q$ }: ~* H
; L2 }9 B9 G% s; S
* q1 y0 S5 K4 ]5 }; jbool CheckDTS::isTangentFaces(Face *face1 , Face *face2)5 {' l* m, `9 `9 U
{. y: {8 ?2 ]4 Y
" V5 Y& e& w! A& j5 f- S
        bool isTangent = false;
% j% q4 Z2 C* P9 Z7 p2 ?$ P3 R        int count = 0;
! @: `% }; J! a$ x8 J        std::vector<Face *> boundaryFaces1(0);* R( d% t3 a3 J. _  s- [
        FaceTangentRule *faceTangentRule1;
3 m; Y! z1 f+ f2 e        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);/ v3 {/ [" ]! _, q6 P' i/ B0 w5 l' ^7 `
        ScCollector *scCollector1;
: I  h" C& }2 z) {# _' A3 i. M$ f        scCollector1 = workPart->ScCollectors()->CreateCollector();+ p. a1 E2 ?- q% z* d* M
        std::vector<SelectionIntentRule *> rules1(1);
  t6 `% P; s) y        rules1[0] = faceTangentRule1;( T/ t9 j0 c* W8 h, `
        scCollector1->ReplaceRules(rules1, false);: ]: F* d% l* M# k) ]
        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();, P% D$ M; d( {$ K& R
        delete faceTangentRule1;  Q! j6 E! q; k8 o2 |. P
        
* r' z* a$ V2 t1 c        if (theFaces.empty())
* Y+ v: C1 h. a, v' j+ D        {
4 H; F& T+ D. O5 l# h2 F                isTangent = false;
4 G# T' D7 y9 w1 h/ ~- ~        }* b! {) E2 b* z1 l8 D
        else. P9 s0 j6 c3 u% u
        {
9 [* Z! a  H& a                for (int i  =0 ; i < theFaces.size();i++): Q3 |$ e6 x: \, H, n
                {5 C; {/ [: l0 O$ L0 u5 Q- A1 t) s
                        if (face2 == theFaces.at(i))
/ m4 i# H4 g7 A* D0 t0 z                        {1 T( f7 J% t. w  T- Y. `5 U+ x$ h
                                isTangent = true;
6 t6 L( F" S4 D9 V                                break;
) C! U* Y  t" X# f% h                        }
* V8 r$ c& q7 z* n                }" S/ `" Y3 s+ M5 w. t  V
3 g* [# ]0 r0 ?, w6 P: o1 h
        }. ~! [" ]- H9 F4 s7 J* q
        
- V( w. t8 ?0 h9 t        return isTangent;" k8 G( A* t" P) i6 U

. P4 s' W0 o2 P& ^) e}[/mw_shl_code]
7 R5 i& p6 r( D. X
* \3 ?. L% |/ l+ I! U
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了