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

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

[复制链接]

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

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

admin 楼主

2019-9-15 08:38:30

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

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

x
' d1 x1 P( _, p4 C' Z- `$ @7 G- i
NX二次开发源码分享:判断选择的面是否相切
' ]/ V3 f, X  o6 {
: `9 T# [5 W7 {* [8 b
, X+ K& _" Z- a& ^2 l
4 c# \& D/ U, F
通常情况下,我们需要通过输入的面获取相关几何关系,如果两个面是否相切,目前并没有直接的方法去处理,如果通过自己去构造一套相切算法或者标准去处理,显然太浪费时间,而且结果是否适合,性能是否ok,都值得考量。: |, C6 x' l% t' w) |9 \

9 H, G2 d0 S7 i0 T- P
接下来我们来给大家借用目前强大的选择意图功能,来利用这个特性处理下,其实大部分几何关系都可以捕捉,掌握了这种技巧,其他的选择方式都可以以此类推的进行相关处理。
(1)先看看选择意图 Select Intention中的Selection Filter
8 _/ O; c" o8 Y$ N# ]  f
选择意图主要是帮助用户在界面上进行相关对象的选取,比如选择范围,包含有整个装配范围,装配和工作部件范围,仅仅工作部件范围。选择过滤主要是针对当前选择器的选项进行相关类型的过滤,目的是帮助用户快速完成相关内容的选择。: C6 y/ D1 c( c! `" P% r
譬如:
  • 当您选择曲线类型时候,NX会提供曲线相关选择
    5 M* A- U- ~/ w% ~& F# n5 z

! ~5 r5 e) Y) \0 w; x                               
登录/注册后可看大图
  • 当您选择边对象时候,NX会提供边的相关选择方式

    & I5 i! o  T% T  m
    3 o. o0 h+ H2 x7 W- e+ t: m* e) I, A7 L
                                   
    登录/注册后可看大图
  • 当您选择曲面时候,NX会提供曲面的相关选择方式

    6 [2 f; {4 b/ }7 v. {# t
    5 h3 c2 o6 s2 V  Y) [5 E
                                   
    登录/注册后可看大图

    0 a1 A: ~. g3 ^; o' f, ^4 D

% G! g% u/ A/ }
(2)选择相切面的效果,如果我们选中图示高亮部分的面,通过Tangent Faces,系统会自动获取所有和这个面相切的面,并进行高亮& [2 J& c1 g. X, j; x7 S

7 x  _* u: r* _" @1 a% d                               
登录/注册后可看大图

) H3 t* W$ H8 F$ r                               
登录/注册后可看大图
(3)代码中思路就简单了,输入的面获取很多相切面,只要要检查的面在获取的面中就够了吗? 显然还需要一个条件,就是两个面之间要有公共边,也就是说是相邻的。以下的集中测试结果,高亮的面是我们要判断之间是否相切的面。
- x! f+ l4 \/ _. R; Y2 B

. Y% C2 Q( v! X- N; D5 X. }                               
登录/注册后可看大图
& f) D* q/ e- X' N9 A6 v% l
                               
登录/注册后可看大图

: h4 ?4 ^, }5 C1 }) w/ y                               
登录/注册后可看大图

6 U$ ?3 @- @- E4 C: e! x                               
登录/注册后可看大图
2 h5 y% S/ o7 {8 e) U  b6 Z+ s
                               
登录/注册后可看大图
(4)这种方式是非常高可用的,如何通过选择的面快速获取Slot faces,获取Boss Faces等等都值得使用。传统的做法,可能去遍历所有的面,通过面的法相方向,边的关系等进行处理,如果合理使用现有的NX提供的方式,可见更加快捷方便。) M9 z* x# E5 s# w; \5 ?: n; g0 g

  Z! b8 i- H* m+ i7 G8 c
最后把这段代码提供上来,仅供参考!
PLM之家NX二次开发板块,提供了很多源码分享,感兴趣可以常去看看哦!也欢迎大家发帖,提供好的案例分享。送人玫瑰,手有余香!

; t8 V  v( X! _. _! F
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;
                                }
                        }
                }

% m2 f1 q9 j; h6 S/ w3 o
        }
        UF_terminate();       
        return isTangent;
}

1 m: _$ l) G5 D; `# ~
, @6 K+ f- Z9 r* F/ ]0 r4 o, X$ h7 _. ~1 v% V( S+ M; K
, W1 t; A) y# B" b8 m" O2 E

5 f+ ]: x5 [8 P8 I+ a9 e+ \                               
登录/注册后可看大图
3 E1 n: r2 n4 }; }% d

; c/ @, A! L) b, Y* W4 ^                               
登录/注册后可看大图
END
PLM之家plmhome

  _) l5 w2 Z9 k8 Q' u7 \1 i                               
登录/注册后可看大图

: }* ~& k$ m: x0 I▲长按二维码“识别”关注

% `. D6 @8 ~+ H7 ]% C: k" J7 r! S3 D; \% [/ h
[mw_shl_code=cpp,true]6 S3 c$ C9 ]; P! _5 n

, g  g% f( J" i$ A! l/ c8 Q
/ h, M- A9 }5 G, o3 q$ S5 `bool CheckDTS::isTangentFaces(Face *face1 , Face *face2)
, v% f) q( _+ U{
* S  c2 w! K: F1 A" E1 W1 f) b; L7 ^1 q) L- G1 M
        bool isTangent = false;. u# Y6 r' |, Z1 ]' [* o. l
        int count = 0;" L: G6 Q+ y3 r( S0 F$ b. m
        std::vector<Face *> boundaryFaces1(0);; i8 o2 H) Q& H' D  }' O2 W) S
        FaceTangentRule *faceTangentRule1;
/ Y8 a* F+ y5 L( h1 ~        faceTangentRule1 = workPart->ScRuleFactory()->CreateRuleFaceTangent(face1, boundaryFaces1);  I3 p9 Y: t. i# b7 o! s
        ScCollector *scCollector1;" U& L/ o# E: b" F: ]
        scCollector1 = workPart->ScCollectors()->CreateCollector();
+ i$ T$ F, C( T( R% ?        std::vector<SelectionIntentRule *> rules1(1);
9 f# Q: w0 u, C        rules1[0] = faceTangentRule1;
0 S! s, [4 h: l# N; i: k* I3 K        scCollector1->ReplaceRules(rules1, false);
* G- p1 z! A0 z, U7 K- e. A        std::vector<TaggedObject *> theFaces = scCollector1->GetObjects();
) U7 W0 Z, z6 _        delete faceTangentRule1;
. y8 q5 M$ @+ e2 H) Z        + ?2 d5 |1 A8 C. F7 f
        if (theFaces.empty())
. L7 \0 `: `7 u1 W4 ^( Z# [& l  P8 N        {; |! m6 E8 J7 S. d) X
                isTangent = false;* z% o( V  F2 i. o. @
        }
: ~& q. ?. m4 g3 P* b* q        else& b2 ~$ A2 ^1 W- a1 s5 N1 d
        {5 j; L3 q1 [8 m% c1 a# ~2 B' f# s
                for (int i  =0 ; i < theFaces.size();i++)
4 K( E9 T$ V: {, x2 M/ d+ U* U                {
4 O3 ~4 ?3 I) x" c3 j2 h7 B9 k                        if (face2 == theFaces.at(i))
5 D; C+ x1 w) Y; ?$ y+ E# F0 l+ @                        {
& P/ Z4 K) c/ R8 X$ w# J& s) z                                isTangent = true;
. d) _5 \- J0 }6 q                                break;
# ?3 O3 k' @( G                        }+ b6 |0 t7 F; S) x% l  F5 s7 l
                }
+ N- G$ e$ l4 z5 E  [6 y
3 ~' b1 b0 p) J' O# U        }9 q6 t3 O5 x* _. `
        , x, R( _( g9 H  V" ^5 z
        return isTangent;0 o! c8 b7 r; _0 v2 v( U
2 ]- M% Y1 R" K2 Q# o" @7 m  T7 D
}[/mw_shl_code]
8 U& z. }  b% ?1 s
. E; V. w6 r' l! S6 v& ~6 V. G$ W
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了